From e90a59efab16ce64ea2157160866356be6a14372 Mon Sep 17 00:00:00 2001
From: Scott Macdonald <57190223+scmacdon@users.noreply.github.com>
Date: Wed, 24 Apr 2024 14:59:20 -0400
Subject: [PATCH] Java V2 Add the SSM Getting Started Scenario (#6341)
* added draft Eng spec for this getting started scenario
* added SSM Java getting started scenatio
* updated Java file to include another service operation
* added SSM Agent information to Java example
---
.doc_gen/metadata/ssm_metadata.yaml | 158 ++++-
.../ssm_scenario/Readme.md | 45 ++
.../ssm_scenario/SPECIFICATION.md | 121 ++++
javav2/example_code/sns/pom.xml | 5 +
javav2/example_code/ssm/Readme.md | 49 +-
.../com/example/scenario/SSMScenario.java | 559 ++++++++++++++++++
.../java/com/example/ssm/CreateOpsItem.java | 83 ---
.../com/example/ssm/DescribeOpsItems.java | 55 --
.../main/java/com/example/ssm/GetOpsItem.java | 72 ---
.../main/java/com/example/ssm/HelloSSM.java | 66 +++
.../java/com/example/ssm/ResolveOpsItem.java | 62 --
.../ssm/src/test/java/AWSSSMTest.java | 91 +--
12 files changed, 1042 insertions(+), 324 deletions(-)
create mode 100644 getting_started_scenarios/ssm_scenario/Readme.md
create mode 100644 getting_started_scenarios/ssm_scenario/SPECIFICATION.md
create mode 100644 javav2/example_code/ssm/src/main/java/com/example/scenario/SSMScenario.java
delete mode 100644 javav2/example_code/ssm/src/main/java/com/example/ssm/CreateOpsItem.java
delete mode 100644 javav2/example_code/ssm/src/main/java/com/example/ssm/DescribeOpsItems.java
delete mode 100644 javav2/example_code/ssm/src/main/java/com/example/ssm/GetOpsItem.java
create mode 100644 javav2/example_code/ssm/src/main/java/com/example/ssm/HelloSSM.java
delete mode 100644 javav2/example_code/ssm/src/main/java/com/example/ssm/ResolveOpsItem.java
diff --git a/.doc_gen/metadata/ssm_metadata.yaml b/.doc_gen/metadata/ssm_metadata.yaml
index 69c88fe7952..ee2f6556a85 100644
--- a/.doc_gen/metadata/ssm_metadata.yaml
+++ b/.doc_gen/metadata/ssm_metadata.yaml
@@ -1,4 +1,21 @@
# zexi 0.4.0
+ssm_Hello:
+ title: Hello &SYS;
+ title_abbrev: Hello &SYS;
+ synopsis: get started using &SYS;.
+ category: Hello
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.java2.hello.main
+ services:
+ ssm: {listThings}
ssm_DescribeParameters:
title: Get information about &SYS; parameters using an &AWS; SDK
title_abbrev: Get parameters information
@@ -49,10 +66,10 @@ ssm_PutParameter:
- ssm.rust.create-parameter
services:
ssm: {PutParameter}
-ssm_CreateOpsItem:
- title: Create a new OpsItem using an &AWS; SDK
- title_abbrev: Create a new OpsItem
- synopsis: create a new OpsItem.
+ssm_createOpsItem:
+ title: Create an opsItem using the &SYS; SDK
+ title_abbrev: Create an opsItem
+ synopsis: create an opsItem.
category:
languages:
Java:
@@ -66,10 +83,78 @@ ssm_CreateOpsItem:
- ssm.java2.create_ops.main
services:
ssm: {CreateOpsItem}
-ssm_DescribeOpsItems:
- title: Describe an OpsItem using an &AWS; SDK
- title_abbrev: Describe an OpsItem
- synopsis: describe an OpsItem.
+ssm_updateMaintenanceWindow:
+ title: Update a maintenance window using the &SYS; SDK
+ title_abbrev: Update a maintenance window
+ synopsis: update a maintenance window.
+ category:
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.java2.update_window.main
+ services:
+ ssm: {UpdateMaintenanceWindow}
+ssm_createMaintenanceWindow:
+ title: Create a maintenance window using the &SYS; SDK
+ title_abbrev: Create a maintenance window
+ synopsis: create a maintenance window.
+ category:
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.java2.create_window.main
+ services:
+ ssm: {CreateMaintenanceWindow}
+ssm_sendCommand:
+ title: Send a command using the &SYS; SDK
+ title_abbrev: Send a command
+ synopsis: send a command.
+ category:
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.Java2.send_command.main
+ services:
+ ssm: {SendCommand}
+ssm_createDocument:
+ title: Create a document using the &SYS; SDK
+ title_abbrev: Create a document
+ synopsis: create a document.
+ category:
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.java2.create_doc.main
+ services:
+ ssm: {CreateDocument}
+ssm_describeOpsItems:
+ title: Describe an &SYS; Opsitem using the SDK
+ title_abbrev: Describe an Opsitem
+ synopsis: describe an Opsitem.
category:
languages:
Java:
@@ -82,10 +167,44 @@ ssm_DescribeOpsItems:
snippet_tags:
- ssm.java2.describe_ops.main
services:
- ssm: {DescribeOpsItems}
+ ssm: {DescribeOpsItems}
+ssm_deleteMaintenanceWindow:
+ title: Delete a maintenance window using the &SYS; SDK
+ title_abbrev: Delete a maintenance window
+ synopsis: delete a maintenance window.
+ category:
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.java2.delete_window.main
+ services:
+ ssm: {DeleteMaintenanceWindow}
+ssm_deleteDocument:
+ title: Delete a document using the &SYS; SDK
+ title_abbrev: Delete a document
+ synopsis: delete a document.
+ category:
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.Java2.delete_doc.main
+ services:
+ ssm: {DeleteDocument}
ssm_UpdateOpsItem:
- title: Updates an OpsItem using an &AWS; SDK
- title_abbrev: Updates an OpsItem
+ title: Update an OpsItem using a &SYS; SDK
+ title_abbrev: Update an OpsItem
synopsis: updates an OpsItem.
category:
languages:
@@ -100,3 +219,20 @@ ssm_UpdateOpsItem:
- ssm.Java2.resolve_ops.main
services:
ssm: {UpdateOpsItem}
+ssm_Scenario:
+ title: Get started with &SYS; using an &AWS; SDK
+ title_abbrev: Get started with &SYS;
+ synopsis: work with &SYS; maintenance windows, documents, and OpsItems.
+ category: Scenarios
+ languages:
+ Java:
+ versions:
+ - sdk_version: 2
+ github: javav2/example_code/ssm
+ sdkguide:
+ excerpts:
+ - description:
+ snippet_tags:
+ - ssm.java2.scenario.main
+ services:
+ ssm: {CreateOpsItem, CreateMaintenanceWindow, CreateDocument, SendCommand, CommandInvocations, DeleteMaintenanceWindow, UpdateOpsItem}
diff --git a/getting_started_scenarios/ssm_scenario/Readme.md b/getting_started_scenarios/ssm_scenario/Readme.md
new file mode 100644
index 00000000000..521dbd23580
--- /dev/null
+++ b/getting_started_scenarios/ssm_scenario/Readme.md
@@ -0,0 +1,45 @@
+# AWS Systems Management Getting Started Scenario
+
+## Introduction
+This AWS Systems Manager getting started scenario demonstrates how to interact with the AWS Systems Manager service using an AWS SDK. The scenario covers various operations such as creating a maintenance window, creating an SSM document, sending a command to a managed node, creating an OpsItem, updating an OpsItem, and deleting SSM resources.
+
+## Setting up Resources
+AWS Systems Manager Agent is Amazon software that runs on Amazon Elastic Compute Cloud (Amazon EC2) instances, edge devices, on-premises servers, and virtual machines (VMs). A Systems Manager Agent makes it possible for Systems Manager to update, manage, and configure these resources. To successfully run this getting started scenario, the EC2 instance must have a Systems Manager Agent. For more information, see [Working with SSM Agent](https://docs.aws.amazon.com/systems-manager/latest/userguide/ssm-agent.html).
+
+## Service Operations Invoked
+The program performs the following tasks:
+
+1. Creates a Systems Manager maintenance window.
+2. Modifies the maintenance window by changing the schedule.
+3. Creates a Systems Manager document that defines the actions Systems Manager performs on managed nodes.
+4. Sends a command to an EC2 instance using the created Systems Manager document.
+5. Retrieves the time when the specific command was sent to the managed node.
+6. Creates a Systems Manager OpsItem to track and manage an operational issue.
+7. Updates the created OpsItem and gets the status.
+8. Resolves the OpsItem.
+9. Optionally deletes the Systems Manager resources (maintenance window, OpsItem, and document).
+
+## Usage
+1. Clone the repository or download the source code.
+2. Open the code in your preferred IDE.
+3. This scenario requires the following variables:
+ - `instanceId`: The ID of the EC2 instance to send the command to.
+ - `title`: The title of the OpsItem to create.
+ - `source`: The source of the OpsItem.
+ - `category`: The category of the OpsItem.
+ - `severity`: The severity of the OpsItem.
+4. Run the `SSMScenario` class.
+
+The program will guide you through the scenario, prompting you to enter the maintenance window name and the document name. The program will also display the progress and results of the various operations.
+
+## Code Explanation
+The provided code demonstrates the following key features of the AWS SDK and the AWS Systems Manager service:
+
+1. **Maintenance Window Management**: The code uses the `SsmClient` to create, modify, and delete an SSM maintenance window.
+2. **SSM Document Management**: The code creates an SSM document that defines the actions Systems Manager performs on managed nodes.
+3. **Command Execution**: The code sends a command to an EC2 instance using the created SSM document and retrieves the timestamp of the command execution.
+4. **OpsItem Management**: The code creates, updates, and resolves an SSM OpsItem to track and manage an operational issue.
+5. **Error Handling**: The code includes exception handling for various SSM-related exceptions.
+6. **User Interaction**: The code prompts the user for input, such as the maintenance window name and the document name.
+
+Overall, this AWS SDK Systems Manager code example is a resource for developers new to AWS Systems Manager and the AWS SDK. It provides a solid foundation for understanding and building applications that interact with the AWS Systems Manager service.
\ No newline at end of file
diff --git a/getting_started_scenarios/ssm_scenario/SPECIFICATION.md b/getting_started_scenarios/ssm_scenario/SPECIFICATION.md
new file mode 100644
index 00000000000..5650e7dd090
--- /dev/null
+++ b/getting_started_scenarios/ssm_scenario/SPECIFICATION.md
@@ -0,0 +1,121 @@
+# AWS Systems Manager Engineering Specification
+
+## Overview
+ This SDK getting started scenario demonstrates how to interact with AWS Systems Manager using an AWS SDK. The provided code is an AWS application that demonstrates the usage of the AWS Systems Manager SDK to interact with various AWS Systems Manager service operations.
+
+## Scenario Program Flow
+ - Creates a Systems Manager maintenance window with a default name or a user-provided name.
+ - Modifies the maintenance window schedule.
+ - Creates a Systems Manager document with a default name or a user-provided name.
+ - Sends a command to a specified EC2 instance using the created document and display the time when the command was invoked.
+ - Creates a Systems Manager OpsItem with a predefined title, source, category, and severity.
+ - Updates and resolves the created OpsItem.
+ - Deletes the Systems Manager maintenance window, OpsItem, and document.
+
+## Hello SSM
+This program is intended for users not familiar with Systems Manager SDK to easily get up and running. The logic is to show use of listDocumentsPaginator().
+
+### Program execution
+The following shows the output of the program in the console.
+
+```
+ Document Name: AWSMigration-ConvertCentOsToRockyLinuxDistribution
+ Document Name: AWSMigration-CreateLoadBalanceAutoScaleGroup
+ Document Name: AWSMigration-EnableInspector
+```
+
+
+## Scenario Program execution
+The following shows the output of the program in the console.
+
+
+```
+--------------------------------------------------------------------------------
+Welcome to the AWS Systems Manager SDK Getting Started scenario.
+This Java program demonstrates how to interact with AWS Systems Manager using the AWS SDK.
+AWS Systems Manager is the operations hub for your AWS applications and resources and a secure end-to-end management solution.
+The program's primary functionalities include creating a maintenance window, creating a document, sending a command to a document,
+listing documents, listing commands, creating an OpsItem, modifying an OpsItem, and deleting AWS SSM resources.
+Upon completion of the program, all AWS resources are cleaned up.
+Let's get started...
+Please hit Enter
+
+
+--------------------------------------------------------------------------------
+Create an SSM maintenance window.
+Please enter the maintenance window name (default is ssm-maintenance-window):
+
+The maintenance window id is mw-0a782f69416fa2d68
+--------------------------------------------------------------------------------
+Modify the maintenance window by changing the schedule
+Please hit Enter
+
+The SSM maintenance window was successfully updated
+--------------------------------------------------------------------------------
+Create an SSM document that defines the actions that Systems Manager performs on your managed nodes.
+Please enter the document name (default is ssmdocument):
+
+The status of the SSM document is Creating
+--------------------------------------------------------------------------------
+Now we are going to run a command on an EC2 instance
+Please hit Enter
+
+The SSM document is active and ready to use.
+Command ID: ac4aef03-7d60-4fba-8d71-051defea89e2
+Wait 5 secs
+Command execution successful
+--------------------------------------------------------------------------------
+Lets get the time when the specific command was sent to the specific managed node
+Please hit Enter
+
+The time of the command invocation is 2024-04-09 14:52:50
+--------------------------------------------------------------------------------
+--------------------------------------------------------------------------------
+ Now we will create an SSM OpsItem.
+ SSM OpsItem is a feature provided by the Systems Manager service.
+ It is a type of operational data item that allows you to manage and track various operational issues,
+ events, or tasks within your AWS environment.
+
+ You can create OpsItems to track and manage operational issues as they arise.
+ For example, you could create an OpsItem whenever your application detects a critical error
+ or an anomaly in your infrastructure.
+
+Please hit Enter
+
+--------------------------------------------------------------------------------
+--------------------------------------------------------------------------------
+Now we will update SSM OpsItem oi-c1e5435471e9
+Please hit Enter
+
+Now we will resolve the SSM OpsItem oi-c1e5435471e9
+Please hit Enter
+
+--------------------------------------------------------------------------------
+--------------------------------------------------------------------------------
+Would you like to delete the AWS Systems Manager resources? (y/n)
+
+The AWS Systems Manager resources will not be deleted
+--------------------------------------------------------------------------------
+This concludes the AWS Systems Manager SDK Getting Started scenario.
+--------------------------------------------------------------------------------
+
+```
+```
+
+## Metadata
+
+The following table describes the metadata used in this SDK Getting Started Scenario.
+
+
+| action | metadata file | metadata key |
+|------------------------------|------------------------------|---------------------------------------- |
+| `CreateOpsItem` | ssm_metadata.yaml | ssm_CreateOpsItem |
+| `CreateMaintenanceWindow` | ssm_metadata.yaml | ssm_CreateMainWindow |
+| `UpdateMaintenanceWindow` | ssm_metadata.yaml | ssm_UpdateMainWindow |
+| `CreateDocument` | ssm_metadata.yaml | ssm_CreateDocument |
+| `SendCommand ` | ssm_metadata.yaml | ssm_SendCommand |
+| `CommandInvocations` | ssm_metadata.yaml | ssm_DescribeInvocation |
+| `UpdateOpsItem` | ssm_metadata.yaml | ssm_UpdateOpsItem |
+| `DeleteMaintenanceWindow ` | ssm_metadata.yaml | ssm_DeleteMainWindow |
+| `DeleteDocument` | ssm_metadata.yaml | ssm_DeleteMainWindow |
+| `DescribeOpsItems ` | ssm_metadata.yaml | ssm_DescribeOpsItems |
diff --git a/javav2/example_code/sns/pom.xml b/javav2/example_code/sns/pom.xml
index bf4682a1b26..76ea0aac09a 100644
--- a/javav2/example_code/sns/pom.xml
+++ b/javav2/example_code/sns/pom.xml
@@ -61,6 +61,11 @@
5.9.2test
+
+ software.amazon.sns
+ sns-extended-client
+ 2.1.0
+ org.junit.platformjunit-platform-commons
diff --git a/javav2/example_code/ssm/Readme.md b/javav2/example_code/ssm/Readme.md
index bf7fe9f7648..bfd9ef9b50e 100644
--- a/javav2/example_code/ssm/Readme.md
+++ b/javav2/example_code/ssm/Readme.md
@@ -29,15 +29,35 @@ For prerequisites, see the [README](../../README.md#Prerequisites) in the `javav
+### Get started
+
+- [Hello Systems Manager](src/main/java/com/example/ssm/HelloSSM.java#L6) (`listThings`)
+
+
### Single actions
Code excerpts that show you how to call individual service functions.
- [Add a parameter](src/main/java/com/example/ssm/PutParameter.java#L6) (`PutParameter`)
-- [Create a new OpsItem](src/main/java/com/example/ssm/CreateOpsItem.java#L6) (`CreateOpsItem`)
-- [Describe an OpsItem](src/main/java/com/example/ssm/DescribeOpsItems.java#L6) (`DescribeOpsItems`)
+- [Create a document](src/main/java/com/example/scenario/SSMScenario.java#L474) (`CreateDocument`)
+- [Create a maintenance window](src/main/java/com/example/scenario/SSMScenario.java#L428) (`CreateMaintenanceWindow`)
+- [Create an OpsItem](src/main/java/com/example/scenario/SSMScenario.java#L226) (`CreateOpsItem`)
+- [Create an opsItem](src/main/java/com/example/scenario/SSMScenario.java#L226) (`CreateOpsItem`)
+- [Delete a document](src/main/java/com/example/scenario/SSMScenario.java#L370) (`DeleteDocument`)
+- [Delete a maintenance window](src/main/java/com/example/scenario/SSMScenario.java#L388) (`DeleteMaintenanceWindow`)
+- [Describe an OpsItem](src/main/java/com/example/scenario/SSMScenario.java#L516) (`DescribeOpsItems`)
+- [Describe an Opsitem](src/main/java/com/example/scenario/SSMScenario.java#L516) (`DescribeOpsItems`)
- [Get parameters information](src/main/java/com/example/ssm/GetParameter.java#L6) (`DescribeParameters`)
-- [Updates an OpsItem](src/main/java/com/example/ssm/ResolveOpsItem.java#L6) (`UpdateOpsItem`)
+- [Send a command](src/main/java/com/example/scenario/SSMScenario.java#L310) (`SendCommand`)
+- [Update a maintenance window](src/main/java/com/example/scenario/SSMScenario.java#L405) (`UpdateMaintenanceWindow`)
+- [Update an OpsItem](src/main/java/com/example/scenario/SSMScenario.java#L274) (`UpdateOpsItem`)
+
+### Scenarios
+
+Code examples that show you how to accomplish a specific task by calling multiple
+functions within the same service.
+
+- [Get started with Systems Manager](src/main/java/com/example/scenario/SSMScenario.java)
@@ -47,6 +67,13 @@ Code excerpts that show you how to call individual service functions.
### Instructions
+AWS Systems Manager Agent (SSM Agent) is Amazon software that runs on Amazon Elastic Compute Cloud (Amazon EC2) instances,
+edge devices, on-premises servers, and virtual machines (VMs). SSM Agent makes it possible for Systems Manager to
+update, manage, and configure these resources.
+
+To successfully run this getting started scenario, the EC2 instance must have an SSM Agent.
+For more information, see the following documentation topic [Working with SSM Agent](https://docs.aws.amazon.com/systems-manager/latest/userguide/ssm-agent.html).
+
@@ -64,7 +91,23 @@ Define these values to successfully run the JUnit tests:
+#### Hello Systems Manager
+
+This example shows you how to get started using Systems Manager.
+
+
+
+#### Get started with Systems Manager
+
+This example shows you how to work with Systems Manager maintenance windows, documents, and Opsitems.
+
+
+
+
+
+
+
### Tests
diff --git a/javav2/example_code/ssm/src/main/java/com/example/scenario/SSMScenario.java b/javav2/example_code/ssm/src/main/java/com/example/scenario/SSMScenario.java
new file mode 100644
index 00000000000..6a1ec33f079
--- /dev/null
+++ b/javav2/example_code/ssm/src/main/java/com/example/scenario/SSMScenario.java
@@ -0,0 +1,559 @@
+// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
+// SPDX-License-Identifier: Apache-2.0
+
+package com.example.scenario;
+
+// snippet-start:[ssm.java2.scenario.main]
+import software.amazon.awssdk.regions.Region;
+import software.amazon.awssdk.services.ssm.SsmClient;
+import software.amazon.awssdk.services.ssm.model.CommandInvocation;
+import software.amazon.awssdk.services.ssm.model.CommandInvocationStatus;
+import software.amazon.awssdk.services.ssm.model.CreateDocumentRequest;
+import software.amazon.awssdk.services.ssm.model.CreateDocumentResponse;
+import software.amazon.awssdk.services.ssm.model.CreateMaintenanceWindowRequest;
+import software.amazon.awssdk.services.ssm.model.CreateMaintenanceWindowResponse;
+import software.amazon.awssdk.services.ssm.model.CreateOpsItemRequest;
+import software.amazon.awssdk.services.ssm.model.CreateOpsItemResponse;
+import software.amazon.awssdk.services.ssm.model.DeleteDocumentRequest;
+import software.amazon.awssdk.services.ssm.model.DeleteMaintenanceWindowRequest;
+import software.amazon.awssdk.services.ssm.model.DeleteOpsItemRequest;
+import software.amazon.awssdk.services.ssm.model.DescribeDocumentRequest;
+import software.amazon.awssdk.services.ssm.model.DescribeDocumentResponse;
+import software.amazon.awssdk.services.ssm.model.DescribeMaintenanceWindowsRequest;
+import software.amazon.awssdk.services.ssm.model.DescribeMaintenanceWindowsResponse;
+import software.amazon.awssdk.services.ssm.model.DescribeOpsItemsRequest;
+import software.amazon.awssdk.services.ssm.model.DescribeOpsItemsResponse;
+import software.amazon.awssdk.services.ssm.model.DocumentAlreadyExistsException;
+import software.amazon.awssdk.services.ssm.model.DocumentType;
+import software.amazon.awssdk.services.ssm.model.GetCommandInvocationRequest;
+import software.amazon.awssdk.services.ssm.model.GetCommandInvocationResponse;
+import software.amazon.awssdk.services.ssm.model.GetOpsItemRequest;
+import software.amazon.awssdk.services.ssm.model.GetOpsItemResponse;
+import software.amazon.awssdk.services.ssm.model.ListCommandInvocationsRequest;
+import software.amazon.awssdk.services.ssm.model.ListCommandInvocationsResponse;
+import software.amazon.awssdk.services.ssm.model.MaintenanceWindowFilter;
+import software.amazon.awssdk.services.ssm.model.MaintenanceWindowIdentity;
+import software.amazon.awssdk.services.ssm.model.OpsItemDataValue;
+import software.amazon.awssdk.services.ssm.model.OpsItemFilter;
+import software.amazon.awssdk.services.ssm.model.OpsItemFilterKey;
+import software.amazon.awssdk.services.ssm.model.OpsItemFilterOperator;
+import software.amazon.awssdk.services.ssm.model.OpsItemStatus;
+import software.amazon.awssdk.services.ssm.model.OpsItemSummary;
+import software.amazon.awssdk.services.ssm.model.SendCommandRequest;
+import software.amazon.awssdk.services.ssm.model.SendCommandResponse;
+import software.amazon.awssdk.services.ssm.model.SsmException;
+import software.amazon.awssdk.services.ssm.model.UpdateMaintenanceWindowRequest;
+import software.amazon.awssdk.services.ssm.model.UpdateOpsItemRequest;
+import java.time.ZoneId;
+import java.time.format.DateTimeFormatter;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Scanner;
+import java.util.concurrent.TimeUnit;
+
+/**
+ * Before running this Java V2 code example, set up your development
+ * environment, including your credentials.
+ *
+ * For more information, see the following documentation topic:
+ *
+ * https://docs.aws.amazon.com/sdk-for-java/latest/developer-guide/setup.html
+ *
+ *
+ * This Java program performs these tasks:
+ * 1. Creates an AWS Systems Manager maintenance window with a default name or a user-provided name.
+ * 2. Modifies the maintenance window schedule.
+ * 3. Creates a Systems Manager document with a default name or a user-provided name.
+ * 4. Sends a command to a specified EC2 instance using the created Systems Manager document and displays the time when the command was invoked.
+ * 5. Creates a Systems Manager OpsItem with a predefined title, source, category, and severity.
+ * 6. Updates and resolves the created OpsItem.
+ * 7. Deletes the Systems Manager maintenance window, OpsItem, and document.
+ */
+
+public class SSMScenario {
+ public static final String DASHES = new String(new char[80]).replace("\0", "-");
+ public static void main(String[] args) throws InterruptedException {
+ String usage = """
+ Usage:
+