• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1{
2  "version":"2.0",
3  "metadata":{
4    "apiVersion":"2023-08-22",
5    "endpointPrefix":"thinclient",
6    "jsonVersion":"1.1",
7    "protocol":"rest-json",
8    "serviceFullName":"Amazon WorkSpaces Thin Client",
9    "serviceId":"WorkSpaces Thin Client",
10    "signatureVersion":"v4",
11    "signingName":"thinclient",
12    "uid":"workspaces-thin-client-2023-08-22"
13  },
14  "operations":{
15    "CreateEnvironment":{
16      "name":"CreateEnvironment",
17      "http":{
18        "method":"POST",
19        "requestUri":"/environments",
20        "responseCode":201
21      },
22      "input":{"shape":"CreateEnvironmentRequest"},
23      "output":{"shape":"CreateEnvironmentResponse"},
24      "errors":[
25        {"shape":"ServiceQuotaExceededException"},
26        {"shape":"ValidationException"},
27        {"shape":"AccessDeniedException"},
28        {"shape":"ResourceNotFoundException"},
29        {"shape":"ThrottlingException"},
30        {"shape":"ConflictException"},
31        {"shape":"InternalServerException"}
32      ],
33      "documentation":"<p>Creates an environment for your thin client devices.</p>",
34      "endpoint":{"hostPrefix":"api."}
35    },
36    "DeleteDevice":{
37      "name":"DeleteDevice",
38      "http":{
39        "method":"DELETE",
40        "requestUri":"/devices/{id}",
41        "responseCode":204
42      },
43      "input":{"shape":"DeleteDeviceRequest"},
44      "output":{"shape":"DeleteDeviceResponse"},
45      "errors":[
46        {"shape":"ValidationException"},
47        {"shape":"AccessDeniedException"},
48        {"shape":"ResourceNotFoundException"},
49        {"shape":"ThrottlingException"},
50        {"shape":"ConflictException"},
51        {"shape":"InternalServerException"}
52      ],
53      "documentation":"<p>Deletes a thin client device.</p>",
54      "endpoint":{"hostPrefix":"api."},
55      "idempotent":true
56    },
57    "DeleteEnvironment":{
58      "name":"DeleteEnvironment",
59      "http":{
60        "method":"DELETE",
61        "requestUri":"/environments/{id}",
62        "responseCode":204
63      },
64      "input":{"shape":"DeleteEnvironmentRequest"},
65      "output":{"shape":"DeleteEnvironmentResponse"},
66      "errors":[
67        {"shape":"ValidationException"},
68        {"shape":"AccessDeniedException"},
69        {"shape":"ResourceNotFoundException"},
70        {"shape":"ThrottlingException"},
71        {"shape":"ConflictException"},
72        {"shape":"InternalServerException"}
73      ],
74      "documentation":"<p>Deletes an environment.</p>",
75      "endpoint":{"hostPrefix":"api."},
76      "idempotent":true
77    },
78    "DeregisterDevice":{
79      "name":"DeregisterDevice",
80      "http":{
81        "method":"POST",
82        "requestUri":"/deregister-device/{id}",
83        "responseCode":202
84      },
85      "input":{"shape":"DeregisterDeviceRequest"},
86      "output":{"shape":"DeregisterDeviceResponse"},
87      "errors":[
88        {"shape":"ValidationException"},
89        {"shape":"AccessDeniedException"},
90        {"shape":"ResourceNotFoundException"},
91        {"shape":"ThrottlingException"},
92        {"shape":"ConflictException"},
93        {"shape":"InternalServerException"}
94      ],
95      "documentation":"<p>Deregisters a thin client device.</p>",
96      "endpoint":{"hostPrefix":"api."},
97      "idempotent":true
98    },
99    "GetDevice":{
100      "name":"GetDevice",
101      "http":{
102        "method":"GET",
103        "requestUri":"/devices/{id}",
104        "responseCode":200
105      },
106      "input":{"shape":"GetDeviceRequest"},
107      "output":{"shape":"GetDeviceResponse"},
108      "errors":[
109        {"shape":"ValidationException"},
110        {"shape":"AccessDeniedException"},
111        {"shape":"ResourceNotFoundException"},
112        {"shape":"ThrottlingException"},
113        {"shape":"InternalServerException"}
114      ],
115      "documentation":"<p>Returns information for a thin client device.</p>",
116      "endpoint":{"hostPrefix":"api."}
117    },
118    "GetEnvironment":{
119      "name":"GetEnvironment",
120      "http":{
121        "method":"GET",
122        "requestUri":"/environments/{id}",
123        "responseCode":200
124      },
125      "input":{"shape":"GetEnvironmentRequest"},
126      "output":{"shape":"GetEnvironmentResponse"},
127      "errors":[
128        {"shape":"ValidationException"},
129        {"shape":"AccessDeniedException"},
130        {"shape":"ResourceNotFoundException"},
131        {"shape":"ThrottlingException"},
132        {"shape":"InternalServerException"}
133      ],
134      "documentation":"<p>Returns information for an environment.</p>",
135      "endpoint":{"hostPrefix":"api."}
136    },
137    "GetSoftwareSet":{
138      "name":"GetSoftwareSet",
139      "http":{
140        "method":"GET",
141        "requestUri":"/softwaresets/{id}",
142        "responseCode":200
143      },
144      "input":{"shape":"GetSoftwareSetRequest"},
145      "output":{"shape":"GetSoftwareSetResponse"},
146      "errors":[
147        {"shape":"ValidationException"},
148        {"shape":"AccessDeniedException"},
149        {"shape":"ResourceNotFoundException"},
150        {"shape":"ThrottlingException"},
151        {"shape":"InternalServerException"}
152      ],
153      "documentation":"<p>Returns information for a software set.</p>",
154      "endpoint":{"hostPrefix":"api."}
155    },
156    "ListDevices":{
157      "name":"ListDevices",
158      "http":{
159        "method":"GET",
160        "requestUri":"/devices",
161        "responseCode":200
162      },
163      "input":{"shape":"ListDevicesRequest"},
164      "output":{"shape":"ListDevicesResponse"},
165      "errors":[
166        {"shape":"ValidationException"},
167        {"shape":"AccessDeniedException"},
168        {"shape":"ThrottlingException"},
169        {"shape":"InternalServerException"}
170      ],
171      "documentation":"<p>Returns a list of thin client devices.</p>",
172      "endpoint":{"hostPrefix":"api."}
173    },
174    "ListEnvironments":{
175      "name":"ListEnvironments",
176      "http":{
177        "method":"GET",
178        "requestUri":"/environments",
179        "responseCode":200
180      },
181      "input":{"shape":"ListEnvironmentsRequest"},
182      "output":{"shape":"ListEnvironmentsResponse"},
183      "errors":[
184        {"shape":"ValidationException"},
185        {"shape":"AccessDeniedException"},
186        {"shape":"ThrottlingException"},
187        {"shape":"InternalServerException"}
188      ],
189      "documentation":"<p>Returns a list of environments.</p>",
190      "endpoint":{"hostPrefix":"api."}
191    },
192    "ListSoftwareSets":{
193      "name":"ListSoftwareSets",
194      "http":{
195        "method":"GET",
196        "requestUri":"/softwaresets",
197        "responseCode":200
198      },
199      "input":{"shape":"ListSoftwareSetsRequest"},
200      "output":{"shape":"ListSoftwareSetsResponse"},
201      "errors":[
202        {"shape":"ValidationException"},
203        {"shape":"AccessDeniedException"},
204        {"shape":"ThrottlingException"},
205        {"shape":"InternalServerException"}
206      ],
207      "documentation":"<p>Returns a list of software sets.</p>",
208      "endpoint":{"hostPrefix":"api."}
209    },
210    "ListTagsForResource":{
211      "name":"ListTagsForResource",
212      "http":{
213        "method":"GET",
214        "requestUri":"/tags/{resourceArn}",
215        "responseCode":200
216      },
217      "input":{"shape":"ListTagsForResourceRequest"},
218      "output":{"shape":"ListTagsForResourceResponse"},
219      "errors":[
220        {"shape":"ValidationException"},
221        {"shape":"ResourceNotFoundException"},
222        {"shape":"InternalServiceException"}
223      ],
224      "documentation":"<p>Returns a list of tags for a resource.</p>",
225      "endpoint":{"hostPrefix":"api."}
226    },
227    "TagResource":{
228      "name":"TagResource",
229      "http":{
230        "method":"POST",
231        "requestUri":"/tags/{resourceArn}",
232        "responseCode":200
233      },
234      "input":{"shape":"TagResourceRequest"},
235      "output":{"shape":"TagResourceResponse"},
236      "errors":[
237        {"shape":"ValidationException"},
238        {"shape":"ResourceNotFoundException"},
239        {"shape":"InternalServiceException"}
240      ],
241      "documentation":"<p>Assigns one or more tags (key-value pairs) to the specified resource.</p>",
242      "endpoint":{"hostPrefix":"api."}
243    },
244    "UntagResource":{
245      "name":"UntagResource",
246      "http":{
247        "method":"DELETE",
248        "requestUri":"/tags/{resourceArn}",
249        "responseCode":200
250      },
251      "input":{"shape":"UntagResourceRequest"},
252      "output":{"shape":"UntagResourceResponse"},
253      "errors":[
254        {"shape":"ValidationException"},
255        {"shape":"ResourceNotFoundException"},
256        {"shape":"InternalServiceException"}
257      ],
258      "documentation":"<p>Removes a tag or tags from a resource.</p>",
259      "endpoint":{"hostPrefix":"api."},
260      "idempotent":true
261    },
262    "UpdateDevice":{
263      "name":"UpdateDevice",
264      "http":{
265        "method":"PATCH",
266        "requestUri":"/devices/{id}",
267        "responseCode":200
268      },
269      "input":{"shape":"UpdateDeviceRequest"},
270      "output":{"shape":"UpdateDeviceResponse"},
271      "errors":[
272        {"shape":"ValidationException"},
273        {"shape":"AccessDeniedException"},
274        {"shape":"ResourceNotFoundException"},
275        {"shape":"ThrottlingException"},
276        {"shape":"InternalServerException"}
277      ],
278      "documentation":"<p>Updates a thin client device.</p>",
279      "endpoint":{"hostPrefix":"api."},
280      "idempotent":true
281    },
282    "UpdateEnvironment":{
283      "name":"UpdateEnvironment",
284      "http":{
285        "method":"PATCH",
286        "requestUri":"/environments/{id}",
287        "responseCode":200
288      },
289      "input":{"shape":"UpdateEnvironmentRequest"},
290      "output":{"shape":"UpdateEnvironmentResponse"},
291      "errors":[
292        {"shape":"ValidationException"},
293        {"shape":"AccessDeniedException"},
294        {"shape":"ResourceNotFoundException"},
295        {"shape":"ThrottlingException"},
296        {"shape":"InternalServerException"}
297      ],
298      "documentation":"<p>Updates an environment.</p>",
299      "endpoint":{"hostPrefix":"api."},
300      "idempotent":true
301    },
302    "UpdateSoftwareSet":{
303      "name":"UpdateSoftwareSet",
304      "http":{
305        "method":"PATCH",
306        "requestUri":"/softwaresets/{id}",
307        "responseCode":204
308      },
309      "input":{"shape":"UpdateSoftwareSetRequest"},
310      "output":{"shape":"UpdateSoftwareSetResponse"},
311      "errors":[
312        {"shape":"ValidationException"},
313        {"shape":"AccessDeniedException"},
314        {"shape":"ResourceNotFoundException"},
315        {"shape":"ThrottlingException"},
316        {"shape":"InternalServerException"}
317      ],
318      "documentation":"<p>Updates a software set.</p>",
319      "endpoint":{"hostPrefix":"api."},
320      "idempotent":true
321    }
322  },
323  "shapes":{
324    "AccessDeniedException":{
325      "type":"structure",
326      "members":{
327        "message":{"shape":"ExceptionMessage"}
328      },
329      "documentation":"<p>You do not have sufficient access to perform this action.</p>",
330      "error":{
331        "httpStatusCode":403,
332        "senderFault":true
333      },
334      "exception":true
335    },
336    "ActivationCode":{
337      "type":"string",
338      "pattern":"[a-z]{2}[a-z0-9]{6}"
339    },
340    "ApplyTimeOf":{
341      "type":"string",
342      "enum":[
343        "UTC",
344        "DEVICE"
345      ]
346    },
347    "Arn":{
348      "type":"string",
349      "max":2048,
350      "min":20,
351      "pattern":"arn:[\\w+=\\/,.@-]+:[a-zA-Z0-9\\-]+:[a-zA-Z0-9\\-]*:[0-9]{0,12}:[a-zA-Z0-9\\-\\/\\._]+"
352    },
353    "ClientToken":{
354      "type":"string",
355      "max":512,
356      "min":1
357    },
358    "ConflictException":{
359      "type":"structure",
360      "members":{
361        "message":{"shape":"ExceptionMessage"},
362        "resourceId":{
363          "shape":"ResourceId",
364          "documentation":"<p>The ID of the resource associated with the request.</p>"
365        },
366        "resourceType":{
367          "shape":"ResourceType",
368          "documentation":"<p>The type of the resource associated with the request.</p>"
369        }
370      },
371      "documentation":"<p>The requested operation would cause a conflict with the current state of a service resource associated with the request. Resolve the conflict before retrying this request.</p>",
372      "error":{
373        "httpStatusCode":409,
374        "senderFault":true
375      },
376      "exception":true
377    },
378    "CreateEnvironmentRequest":{
379      "type":"structure",
380      "required":["desktopArn"],
381      "members":{
382        "name":{
383          "shape":"EnvironmentName",
384          "documentation":"<p>The name for the environment.</p>"
385        },
386        "desktopArn":{
387          "shape":"Arn",
388          "documentation":"<p>The Amazon Resource Name (ARN) of the desktop to stream from Amazon WorkSpaces, WorkSpaces Web, or AppStream 2.0.</p>"
389        },
390        "desktopEndpoint":{
391          "shape":"DesktopEndpoint",
392          "documentation":"<p>The URL for the identity provider login (only for environments that use AppStream 2.0).</p>"
393        },
394        "softwareSetUpdateSchedule":{
395          "shape":"SoftwareSetUpdateSchedule",
396          "documentation":"<p>An option to define if software updates should be applied within a maintenance window.</p>"
397        },
398        "maintenanceWindow":{
399          "shape":"MaintenanceWindow",
400          "documentation":"<p>A specification for a time window to apply software updates.</p>"
401        },
402        "softwareSetUpdateMode":{
403          "shape":"SoftwareSetUpdateMode",
404          "documentation":"<p>An option to define which software updates to apply.</p>"
405        },
406        "desiredSoftwareSetId":{
407          "shape":"SoftwareSetId",
408          "documentation":"<p>The ID of the software set to apply.</p>"
409        },
410        "kmsKeyArn":{
411          "shape":"KmsKeyArn",
412          "documentation":"<p>The Amazon Resource Name (ARN) of the Key Management Service key to use to encrypt the environment.</p>"
413        },
414        "clientToken":{
415          "shape":"ClientToken",
416          "documentation":"<p>Specifies a unique, case-sensitive identifier that you provide to ensure the idempotency of the request. This lets you safely retry the request without accidentally performing the same operation a second time. Passing the same value to a later call to an operation requires that you also pass the same value for all other parameters. We recommend that you use a <a href=\"https://wikipedia.org/wiki/Universally_unique_identifier\">UUID type of value</a>.</p> <p>If you don't provide this value, then Amazon Web Services generates a random one for you.</p> <p>If you retry the operation with the same <code>ClientToken</code>, but with different parameters, the retry fails with an <code>IdempotentParameterMismatch</code> error.</p>",
417          "idempotencyToken":true
418        },
419        "tags":{
420          "shape":"TagsMap",
421          "documentation":"<p>A map of the key-value pairs of the tag or tags to assign to the resource.</p>"
422        }
423      }
424    },
425    "CreateEnvironmentResponse":{
426      "type":"structure",
427      "members":{
428        "environment":{
429          "shape":"EnvironmentSummary",
430          "documentation":"<p>Describes an environment.</p>"
431        }
432      }
433    },
434    "DayOfWeek":{
435      "type":"string",
436      "enum":[
437        "MONDAY",
438        "TUESDAY",
439        "WEDNESDAY",
440        "THURSDAY",
441        "FRIDAY",
442        "SATURDAY",
443        "SUNDAY"
444      ]
445    },
446    "DayOfWeekList":{
447      "type":"list",
448      "member":{"shape":"DayOfWeek"},
449      "max":7,
450      "min":1
451    },
452    "DeleteDeviceRequest":{
453      "type":"structure",
454      "required":["id"],
455      "members":{
456        "id":{
457          "shape":"DeviceId",
458          "documentation":"<p>The ID of the device to delete.</p>",
459          "location":"uri",
460          "locationName":"id"
461        },
462        "clientToken":{
463          "shape":"ClientToken",
464          "documentation":"<p>Specifies a unique, case-sensitive identifier that you provide to ensure the idempotency of the request. This lets you safely retry the request without accidentally performing the same operation a second time. Passing the same value to a later call to an operation requires that you also pass the same value for all other parameters. We recommend that you use a <a href=\"https://wikipedia.org/wiki/Universally_unique_identifier\">UUID type of value</a>.</p> <p>If you don't provide this value, then Amazon Web Services generates a random one for you.</p> <p>If you retry the operation with the same <code>ClientToken</code>, but with different parameters, the retry fails with an <code>IdempotentParameterMismatch</code> error.</p>",
465          "idempotencyToken":true,
466          "location":"querystring",
467          "locationName":"clientToken"
468        }
469      }
470    },
471    "DeleteDeviceResponse":{
472      "type":"structure",
473      "members":{
474      }
475    },
476    "DeleteEnvironmentRequest":{
477      "type":"structure",
478      "required":["id"],
479      "members":{
480        "id":{
481          "shape":"EnvironmentId",
482          "documentation":"<p>The ID of the environment to delete.</p>",
483          "location":"uri",
484          "locationName":"id"
485        },
486        "clientToken":{
487          "shape":"ClientToken",
488          "documentation":"<p>Specifies a unique, case-sensitive identifier that you provide to ensure the idempotency of the request. This lets you safely retry the request without accidentally performing the same operation a second time. Passing the same value to a later call to an operation requires that you also pass the same value for all other parameters. We recommend that you use a <a href=\"https://wikipedia.org/wiki/Universally_unique_identifier\">UUID type of value</a>.</p> <p>If you don't provide this value, then Amazon Web Services generates a random one for you.</p> <p>If you retry the operation with the same <code>ClientToken</code>, but with different parameters, the retry fails with an <code>IdempotentParameterMismatch</code> error.</p>",
489          "idempotencyToken":true,
490          "location":"querystring",
491          "locationName":"clientToken"
492        }
493      }
494    },
495    "DeleteEnvironmentResponse":{
496      "type":"structure",
497      "members":{
498      }
499    },
500    "DeregisterDeviceRequest":{
501      "type":"structure",
502      "required":["id"],
503      "members":{
504        "id":{
505          "shape":"DeviceId",
506          "documentation":"<p>The ID of the device to deregister.</p>",
507          "location":"uri",
508          "locationName":"id"
509        },
510        "targetDeviceStatus":{
511          "shape":"TargetDeviceStatus",
512          "documentation":"<p>The desired new status for the device.</p>"
513        },
514        "clientToken":{
515          "shape":"ClientToken",
516          "documentation":"<p>Specifies a unique, case-sensitive identifier that you provide to ensure the idempotency of the request. This lets you safely retry the request without accidentally performing the same operation a second time. Passing the same value to a later call to an operation requires that you also pass the same value for all other parameters. We recommend that you use a <a href=\"https://wikipedia.org/wiki/Universally_unique_identifier\">UUID type of value</a>.</p> <p>If you don't provide this value, then Amazon Web Services generates a random one for you.</p> <p>If you retry the operation with the same <code>ClientToken</code>, but with different parameters, the retry fails with an <code>IdempotentParameterMismatch</code> error.</p>",
517          "idempotencyToken":true
518        }
519      }
520    },
521    "DeregisterDeviceResponse":{
522      "type":"structure",
523      "members":{
524      }
525    },
526    "DesktopEndpoint":{
527      "type":"string",
528      "max":1024,
529      "min":1,
530      "pattern":"(https:\\/\\/)[a-z0-9]+([\\-\\.]{1}[a-z0-9]+)*\\.[a-z]{2,32}(:[0-9]{1,5})?(\\/.*)?",
531      "sensitive":true
532    },
533    "DesktopType":{
534      "type":"string",
535      "enum":[
536        "workspaces",
537        "appstream",
538        "workspaces-web"
539      ]
540    },
541    "Device":{
542      "type":"structure",
543      "members":{
544        "id":{
545          "shape":"DeviceId",
546          "documentation":"<p>The ID of the device.</p>"
547        },
548        "serialNumber":{
549          "shape":"String",
550          "documentation":"<p>The hardware serial number of the device.</p>"
551        },
552        "name":{
553          "shape":"DeviceName",
554          "documentation":"<p>The name of the device.</p>"
555        },
556        "model":{
557          "shape":"String",
558          "documentation":"<p>The model number of the device.</p>"
559        },
560        "environmentId":{
561          "shape":"EnvironmentId",
562          "documentation":"<p>The ID of the environment the device is associated with.</p>"
563        },
564        "status":{
565          "shape":"DeviceStatus",
566          "documentation":"<p>The status of the device.</p>"
567        },
568        "currentSoftwareSetId":{
569          "shape":"SoftwareSetId",
570          "documentation":"<p>The ID of the software set currently installed on the device.</p>"
571        },
572        "currentSoftwareSetVersion":{
573          "shape":"String",
574          "documentation":"<p>The version of the software set currently installed on the device.</p>"
575        },
576        "desiredSoftwareSetId":{
577          "shape":"SoftwareSetId",
578          "documentation":"<p>The ID of the software set which the device has been set to.</p>"
579        },
580        "pendingSoftwareSetId":{
581          "shape":"SoftwareSetId",
582          "documentation":"<p>The ID of the software set that is pending to be installed on the device.</p>"
583        },
584        "pendingSoftwareSetVersion":{
585          "shape":"String",
586          "documentation":"<p>The version of the software set that is pending to be installed on the device.</p>"
587        },
588        "softwareSetUpdateSchedule":{
589          "shape":"SoftwareSetUpdateSchedule",
590          "documentation":"<p>An option to define if software updates should be applied within a maintenance window.</p>"
591        },
592        "softwareSetComplianceStatus":{
593          "shape":"DeviceSoftwareSetComplianceStatus",
594          "documentation":"<p>Describes if the software currently installed on the device is a supported version.</p>"
595        },
596        "softwareSetUpdateStatus":{
597          "shape":"SoftwareSetUpdateStatus",
598          "documentation":"<p>Describes if the device has a supported version of software installed.</p>"
599        },
600        "lastConnectedAt":{
601          "shape":"Timestamp",
602          "documentation":"<p>The timestamp of the most recent session on the device.</p>"
603        },
604        "lastPostureAt":{
605          "shape":"Timestamp",
606          "documentation":"<p>The timestamp of the most recent check-in of the device.</p>"
607        },
608        "createdAt":{
609          "shape":"Timestamp",
610          "documentation":"<p>The timestamp of when the device was created.</p>"
611        },
612        "updatedAt":{
613          "shape":"Timestamp",
614          "documentation":"<p>The timestamp of when the device was updated.</p>"
615        },
616        "arn":{
617          "shape":"Arn",
618          "documentation":"<p>The Amazon Resource Name (ARN) of the device.</p>"
619        },
620        "kmsKeyArn":{
621          "shape":"KmsKeyArn",
622          "documentation":"<p>The Amazon Resource Name (ARN) of the Key Management Service key used to encrypt the device.</p>"
623        },
624        "tags":{
625          "shape":"EmbeddedTag",
626          "documentation":"<p>The tag keys and optional values for the resource.</p>"
627        }
628      },
629      "documentation":"<p>Describes a thin client device.</p>"
630    },
631    "DeviceId":{
632      "type":"string",
633      "pattern":"[a-zA-Z0-9]{24}"
634    },
635    "DeviceList":{
636      "type":"list",
637      "member":{"shape":"DeviceSummary"}
638    },
639    "DeviceName":{
640      "type":"string",
641      "pattern":"[0-9\\p{IsAlphabetic}+:,.@'\" -]{1,64}",
642      "sensitive":true
643    },
644    "DeviceSoftwareSetComplianceStatus":{
645      "type":"string",
646      "enum":[
647        "NONE",
648        "COMPLIANT",
649        "NOT_COMPLIANT"
650      ]
651    },
652    "DeviceStatus":{
653      "type":"string",
654      "enum":[
655        "REGISTERED",
656        "DEREGISTERING",
657        "DEREGISTERED",
658        "ARCHIVED"
659      ]
660    },
661    "DeviceSummary":{
662      "type":"structure",
663      "members":{
664        "id":{
665          "shape":"DeviceId",
666          "documentation":"<p>The ID of the device.</p>"
667        },
668        "serialNumber":{
669          "shape":"String",
670          "documentation":"<p>The hardware serial number of the device.</p>"
671        },
672        "name":{
673          "shape":"DeviceName",
674          "documentation":"<p>The name of the device.</p>"
675        },
676        "model":{
677          "shape":"String",
678          "documentation":"<p>The model number of the device.</p>"
679        },
680        "environmentId":{
681          "shape":"EnvironmentId",
682          "documentation":"<p>The ID of the environment the device is associated with.</p>"
683        },
684        "status":{
685          "shape":"DeviceStatus",
686          "documentation":"<p>The status of the device.</p>"
687        },
688        "currentSoftwareSetId":{
689          "shape":"SoftwareSetId",
690          "documentation":"<p>The ID of the software set currently installed on the device.</p>"
691        },
692        "desiredSoftwareSetId":{
693          "shape":"SoftwareSetId",
694          "documentation":"<p>The ID of the software set which the device has been set to.</p>"
695        },
696        "pendingSoftwareSetId":{
697          "shape":"SoftwareSetId",
698          "documentation":"<p>The ID of the software set that is pending to be installed on the device.</p>"
699        },
700        "softwareSetUpdateSchedule":{
701          "shape":"SoftwareSetUpdateSchedule",
702          "documentation":"<p>An option to define if software updates should be applied within a maintenance window.</p>"
703        },
704        "lastConnectedAt":{
705          "shape":"Timestamp",
706          "documentation":"<p>The timestamp of the most recent session on the device.</p>"
707        },
708        "lastPostureAt":{
709          "shape":"Timestamp",
710          "documentation":"<p>The timestamp of the most recent check-in of the device.</p>"
711        },
712        "createdAt":{
713          "shape":"Timestamp",
714          "documentation":"<p>The timestamp of when the device was created.</p>"
715        },
716        "updatedAt":{
717          "shape":"Timestamp",
718          "documentation":"<p>The timestamp of when the device was updated.</p>"
719        },
720        "arn":{
721          "shape":"Arn",
722          "documentation":"<p>The Amazon Resource Name (ARN) of the device.</p>"
723        },
724        "tags":{
725          "shape":"EmbeddedTag",
726          "documentation":"<p>The tag keys and optional values for the resource.</p>"
727        }
728      },
729      "documentation":"<p>Describes a thin client device.</p>"
730    },
731    "EmbeddedTag":{
732      "type":"structure",
733      "members":{
734        "resourceArn":{
735          "shape":"String",
736          "documentation":"<p>The Amazon Resource Name (ARN) of a resource to tag.</p>"
737        },
738        "internalId":{
739          "shape":"String",
740          "documentation":"<p>The internal ID of a resource to tag.</p>"
741        }
742      },
743      "documentation":"<p>The resource and internal ID of a resource to tag.</p>",
744      "sensitive":true
745    },
746    "Environment":{
747      "type":"structure",
748      "members":{
749        "id":{
750          "shape":"EnvironmentId",
751          "documentation":"<p>The ID of the environment.</p>"
752        },
753        "name":{
754          "shape":"EnvironmentName",
755          "documentation":"<p>The name of the environment.</p>"
756        },
757        "desktopArn":{
758          "shape":"Arn",
759          "documentation":"<p>The Amazon Resource Name (ARN) of the desktop to stream from Amazon WorkSpaces, WorkSpaces Web, or AppStream 2.0.</p>"
760        },
761        "desktopEndpoint":{
762          "shape":"DesktopEndpoint",
763          "documentation":"<p>The URL for the identity provider login (only for environments that use AppStream 2.0).</p>"
764        },
765        "desktopType":{
766          "shape":"DesktopType",
767          "documentation":"<p>The type of streaming desktop for the environment.</p>"
768        },
769        "activationCode":{
770          "shape":"ActivationCode",
771          "documentation":"<p>The activation code to register a device to the environment.</p>"
772        },
773        "registeredDevicesCount":{
774          "shape":"Integer",
775          "documentation":"<p>The number of devices registered to the environment.</p>"
776        },
777        "softwareSetUpdateSchedule":{
778          "shape":"SoftwareSetUpdateSchedule",
779          "documentation":"<p>An option to define if software updates should be applied within a maintenance window.</p>"
780        },
781        "maintenanceWindow":{
782          "shape":"MaintenanceWindow",
783          "documentation":"<p>A specification for a time window to apply software updates.</p>"
784        },
785        "softwareSetUpdateMode":{
786          "shape":"SoftwareSetUpdateMode",
787          "documentation":"<p>An option to define which software updates to apply.</p>"
788        },
789        "desiredSoftwareSetId":{
790          "shape":"SoftwareSetId",
791          "documentation":"<p>The ID of the software set to apply.</p>"
792        },
793        "pendingSoftwareSetId":{
794          "shape":"SoftwareSetId",
795          "documentation":"<p>The ID of the software set that is pending to be installed.</p>"
796        },
797        "pendingSoftwareSetVersion":{
798          "shape":"String",
799          "documentation":"<p>The version of the software set that is pending to be installed.</p>"
800        },
801        "softwareSetComplianceStatus":{
802          "shape":"EnvironmentSoftwareSetComplianceStatus",
803          "documentation":"<p>Describes if the software currently installed on all devices in the environment is a supported version.</p>"
804        },
805        "createdAt":{
806          "shape":"Timestamp",
807          "documentation":"<p>The timestamp of when the environment was created.</p>"
808        },
809        "updatedAt":{
810          "shape":"Timestamp",
811          "documentation":"<p>The timestamp of when the device was updated.</p>"
812        },
813        "arn":{
814          "shape":"Arn",
815          "documentation":"<p>The Amazon Resource Name (ARN) of the environment.</p>"
816        },
817        "kmsKeyArn":{
818          "shape":"KmsKeyArn",
819          "documentation":"<p>The Amazon Resource Name (ARN) of the Key Management Service key used to encrypt the environment.</p>"
820        },
821        "tags":{
822          "shape":"EmbeddedTag",
823          "documentation":"<p>The tag keys and optional values for the resource.</p>"
824        }
825      },
826      "documentation":"<p>Describes an environment.</p>"
827    },
828    "EnvironmentId":{
829      "type":"string",
830      "pattern":"[a-z0-9]{9}"
831    },
832    "EnvironmentList":{
833      "type":"list",
834      "member":{"shape":"EnvironmentSummary"}
835    },
836    "EnvironmentName":{
837      "type":"string",
838      "pattern":"[0-9\\p{IsAlphabetic}+:,.@'\" -][0-9\\p{IsAlphabetic}+=:,.@'\" -]{0,63}",
839      "sensitive":true
840    },
841    "EnvironmentSoftwareSetComplianceStatus":{
842      "type":"string",
843      "enum":[
844        "NO_REGISTERED_DEVICES",
845        "COMPLIANT",
846        "NOT_COMPLIANT"
847      ]
848    },
849    "EnvironmentSummary":{
850      "type":"structure",
851      "members":{
852        "id":{
853          "shape":"EnvironmentId",
854          "documentation":"<p>The ID of the environment.</p>"
855        },
856        "name":{
857          "shape":"EnvironmentName",
858          "documentation":"<p>The name of the environment.</p>"
859        },
860        "desktopArn":{
861          "shape":"Arn",
862          "documentation":"<p>The Amazon Resource Name (ARN) of the desktop to stream from Amazon WorkSpaces, WorkSpaces Web, or AppStream 2.0.</p>"
863        },
864        "desktopEndpoint":{
865          "shape":"DesktopEndpoint",
866          "documentation":"<p>The URL for the identity provider login (only for environments that use AppStream 2.0).</p>"
867        },
868        "desktopType":{
869          "shape":"DesktopType",
870          "documentation":"<p>The type of streaming desktop for the environment.</p>"
871        },
872        "activationCode":{
873          "shape":"ActivationCode",
874          "documentation":"<p>The activation code to register a device to the environment.</p>"
875        },
876        "softwareSetUpdateSchedule":{
877          "shape":"SoftwareSetUpdateSchedule",
878          "documentation":"<p>An option to define if software updates should be applied within a maintenance window.</p>"
879        },
880        "maintenanceWindow":{
881          "shape":"MaintenanceWindow",
882          "documentation":"<p>A specification for a time window to apply software updates.</p>"
883        },
884        "softwareSetUpdateMode":{
885          "shape":"SoftwareSetUpdateMode",
886          "documentation":"<p>An option to define which software updates to apply.</p>"
887        },
888        "desiredSoftwareSetId":{
889          "shape":"SoftwareSetId",
890          "documentation":"<p>The ID of the software set to apply.</p>"
891        },
892        "pendingSoftwareSetId":{
893          "shape":"SoftwareSetId",
894          "documentation":"<p>The ID of the software set that is pending to be installed.</p>"
895        },
896        "createdAt":{
897          "shape":"Timestamp",
898          "documentation":"<p>The timestamp of when the environment was created.</p>"
899        },
900        "updatedAt":{
901          "shape":"Timestamp",
902          "documentation":"<p>The timestamp of when the device was updated.</p>"
903        },
904        "arn":{
905          "shape":"Arn",
906          "documentation":"<p>The Amazon Resource Name (ARN) of the environment.</p>"
907        },
908        "tags":{
909          "shape":"EmbeddedTag",
910          "documentation":"<p>The tag keys and optional values for the resource.</p>"
911        }
912      },
913      "documentation":"<p>Describes an environment.</p>"
914    },
915    "ExceptionMessage":{"type":"string"},
916    "FieldName":{"type":"string"},
917    "GetDeviceRequest":{
918      "type":"structure",
919      "required":["id"],
920      "members":{
921        "id":{
922          "shape":"DeviceId",
923          "documentation":"<p>The ID of the device for which to return information.</p>",
924          "location":"uri",
925          "locationName":"id"
926        }
927      }
928    },
929    "GetDeviceResponse":{
930      "type":"structure",
931      "members":{
932        "device":{
933          "shape":"Device",
934          "documentation":"<p>Describes an device.</p>"
935        }
936      }
937    },
938    "GetEnvironmentRequest":{
939      "type":"structure",
940      "required":["id"],
941      "members":{
942        "id":{
943          "shape":"EnvironmentId",
944          "documentation":"<p>The ID of the environment for which to return information.</p>",
945          "location":"uri",
946          "locationName":"id"
947        }
948      }
949    },
950    "GetEnvironmentResponse":{
951      "type":"structure",
952      "members":{
953        "environment":{
954          "shape":"Environment",
955          "documentation":"<p>Describes an environment.</p>"
956        }
957      }
958    },
959    "GetSoftwareSetRequest":{
960      "type":"structure",
961      "required":["id"],
962      "members":{
963        "id":{
964          "shape":"SoftwareSetId",
965          "documentation":"<p>The ID of the software set for which to return information.</p>",
966          "location":"uri",
967          "locationName":"id"
968        }
969      }
970    },
971    "GetSoftwareSetResponse":{
972      "type":"structure",
973      "members":{
974        "softwareSet":{
975          "shape":"SoftwareSet",
976          "documentation":"<p>Describes a software set.</p>"
977        }
978      }
979    },
980    "Hour":{
981      "type":"integer",
982      "box":true,
983      "max":23,
984      "min":0
985    },
986    "Integer":{
987      "type":"integer",
988      "box":true
989    },
990    "InternalServerException":{
991      "type":"structure",
992      "members":{
993        "message":{"shape":"ExceptionMessage"},
994        "retryAfterSeconds":{
995          "shape":"RetryAfterSeconds",
996          "documentation":"<p>The number of seconds to wait before retrying the next request.</p>",
997          "location":"header",
998          "locationName":"Retry-After"
999        }
1000      },
1001      "documentation":"<p>The server encountered an internal error and is unable to complete the request.</p>",
1002      "error":{"httpStatusCode":500},
1003      "exception":true,
1004      "fault":true
1005    },
1006    "InternalServiceException":{
1007      "type":"structure",
1008      "members":{
1009        "message":{"shape":"ExceptionMessage"},
1010        "retryAfterSeconds":{
1011          "shape":"RetryAfterSeconds",
1012          "documentation":"<p>The number of seconds to wait before retrying the next request.</p>",
1013          "location":"header",
1014          "locationName":"Retry-After"
1015        }
1016      },
1017      "documentation":"<p>Request processing failed due to some unknown error, exception, or failure.</p>",
1018      "error":{"httpStatusCode":500},
1019      "exception":true,
1020      "fault":true
1021    },
1022    "KmsKeyArn":{
1023      "type":"string",
1024      "max":2048,
1025      "min":20,
1026      "pattern":"arn:[\\w+=\\/,.@-]+:kms:[a-zA-Z0-9\\-]*:[0-9]{0,12}:key\\/[a-zA-Z0-9-]+"
1027    },
1028    "ListDevicesRequest":{
1029      "type":"structure",
1030      "members":{
1031        "nextToken":{
1032          "shape":"PaginationToken",
1033          "documentation":"<p>If <code>nextToken</code> is returned, there are more results available. The value of <code>nextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. Using an expired pagination token will return an <i>HTTP 400 InvalidToken error</i>.</p>",
1034          "location":"querystring",
1035          "locationName":"nextToken"
1036        },
1037        "maxResults":{
1038          "shape":"MaxResults",
1039          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>nextToken</code> to obtain further pages of results.</p> <p>This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.</p>",
1040          "location":"querystring",
1041          "locationName":"maxResults"
1042        }
1043      }
1044    },
1045    "ListDevicesResponse":{
1046      "type":"structure",
1047      "members":{
1048        "devices":{
1049          "shape":"DeviceList",
1050          "documentation":"<p>Describes devices.</p>"
1051        },
1052        "nextToken":{
1053          "shape":"PaginationToken",
1054          "documentation":"<p>If <code>nextToken</code> is returned, there are more results available. The value of <code>nextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. Using an expired pagination token will return an <i>HTTP 400 InvalidToken error</i>.</p>"
1055        }
1056      }
1057    },
1058    "ListEnvironmentsRequest":{
1059      "type":"structure",
1060      "members":{
1061        "nextToken":{
1062          "shape":"PaginationToken",
1063          "documentation":"<p>If <code>nextToken</code> is returned, there are more results available. The value of <code>nextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. Using an expired pagination token will return an <i>HTTP 400 InvalidToken error</i>.</p>",
1064          "location":"querystring",
1065          "locationName":"nextToken"
1066        },
1067        "maxResults":{
1068          "shape":"MaxResults",
1069          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>nextToken</code> to obtain further pages of results.</p> <p>This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.</p>",
1070          "location":"querystring",
1071          "locationName":"maxResults"
1072        }
1073      }
1074    },
1075    "ListEnvironmentsResponse":{
1076      "type":"structure",
1077      "members":{
1078        "environments":{
1079          "shape":"EnvironmentList",
1080          "documentation":"<p>Describes environments.</p>"
1081        },
1082        "nextToken":{
1083          "shape":"PaginationToken",
1084          "documentation":"<p>If <code>nextToken</code> is returned, there are more results available. The value of <code>nextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. Using an expired pagination token will return an <i>HTTP 400 InvalidToken error</i>.</p>"
1085        }
1086      }
1087    },
1088    "ListSoftwareSetsRequest":{
1089      "type":"structure",
1090      "members":{
1091        "nextToken":{
1092          "shape":"PaginationToken",
1093          "documentation":"<p>If <code>nextToken</code> is returned, there are more results available. The value of <code>nextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. Using an expired pagination token will return an <i>HTTP 400 InvalidToken error</i>.</p>",
1094          "location":"querystring",
1095          "locationName":"nextToken"
1096        },
1097        "maxResults":{
1098          "shape":"MaxResults",
1099          "documentation":"<p>The maximum number of results that are returned per call. You can use <code>nextToken</code> to obtain further pages of results.</p> <p>This is only an upper limit. The actual number of results returned per call might be fewer than the specified maximum.</p>",
1100          "location":"querystring",
1101          "locationName":"maxResults"
1102        }
1103      }
1104    },
1105    "ListSoftwareSetsResponse":{
1106      "type":"structure",
1107      "members":{
1108        "softwareSets":{
1109          "shape":"SoftwareSetList",
1110          "documentation":"<p>Describes software sets.</p>"
1111        },
1112        "nextToken":{
1113          "shape":"PaginationToken",
1114          "documentation":"<p>If <code>nextToken</code> is returned, there are more results available. The value of <code>nextToken</code> is a unique pagination token for each page. Make the call again using the returned token to retrieve the next page. Keep all other arguments unchanged. Each pagination token expires after 24 hours. Using an expired pagination token will return an <i>HTTP 400 InvalidToken error</i>.</p>"
1115        }
1116      }
1117    },
1118    "ListTagsForResourceRequest":{
1119      "type":"structure",
1120      "required":["resourceArn"],
1121      "members":{
1122        "resourceArn":{
1123          "shape":"String",
1124          "documentation":"<p>The Amazon Resource Name (ARN) of the resource for which you want to retrieve tags.</p>",
1125          "location":"uri",
1126          "locationName":"resourceArn"
1127        }
1128      }
1129    },
1130    "ListTagsForResourceResponse":{
1131      "type":"structure",
1132      "members":{
1133        "tags":{
1134          "shape":"TagsMap",
1135          "documentation":"<p>A map of the key-value pairs for the tag or tags assigned to the specified resource.</p>"
1136        }
1137      }
1138    },
1139    "MaintenanceWindow":{
1140      "type":"structure",
1141      "members":{
1142        "type":{
1143          "shape":"MaintenanceWindowType",
1144          "documentation":"<p>An option to select the default or custom maintenance window.</p>"
1145        },
1146        "startTimeHour":{
1147          "shape":"Hour",
1148          "documentation":"<p>The hour for the maintenance window start (<code>00</code>-<code>23</code>).</p>"
1149        },
1150        "startTimeMinute":{
1151          "shape":"Minute",
1152          "documentation":"<p>The minutes past the hour for the maintenance window start (<code>00</code>-<code>59</code>).</p>"
1153        },
1154        "endTimeHour":{
1155          "shape":"Hour",
1156          "documentation":"<p>The hour for the maintenance window end (<code>00</code>-<code>23</code>).</p>"
1157        },
1158        "endTimeMinute":{
1159          "shape":"Minute",
1160          "documentation":"<p>The minutes for the maintenance window end (<code>00</code>-<code>59</code>).</p>"
1161        },
1162        "daysOfTheWeek":{
1163          "shape":"DayOfWeekList",
1164          "documentation":"<p>The days of the week during which the maintenance window is open.</p>"
1165        },
1166        "applyTimeOf":{
1167          "shape":"ApplyTimeOf",
1168          "documentation":"<p>The option to set the maintenance window during the device local time or Universal Coordinated Time (UTC).</p>"
1169        }
1170      },
1171      "documentation":"<p>Describes the maintenance window for a thin client device.</p>"
1172    },
1173    "MaintenanceWindowType":{
1174      "type":"string",
1175      "enum":[
1176        "SYSTEM",
1177        "CUSTOM"
1178      ]
1179    },
1180    "MaxResults":{
1181      "type":"integer",
1182      "box":true,
1183      "max":50,
1184      "min":1
1185    },
1186    "Minute":{
1187      "type":"integer",
1188      "box":true,
1189      "max":59,
1190      "min":0
1191    },
1192    "PaginationToken":{
1193      "type":"string",
1194      "max":2048,
1195      "min":0,
1196      "pattern":"\\S*"
1197    },
1198    "QuotaCode":{"type":"string"},
1199    "ResourceId":{"type":"string"},
1200    "ResourceNotFoundException":{
1201      "type":"structure",
1202      "members":{
1203        "message":{"shape":"ExceptionMessage"},
1204        "resourceId":{
1205          "shape":"ResourceId",
1206          "documentation":"<p>The ID of the resource associated with the request.</p>"
1207        },
1208        "resourceType":{
1209          "shape":"ResourceType",
1210          "documentation":"<p>The type of the resource associated with the request.</p>"
1211        }
1212      },
1213      "documentation":"<p>The resource specified in the request was not found.</p>",
1214      "error":{
1215        "httpStatusCode":404,
1216        "senderFault":true
1217      },
1218      "exception":true
1219    },
1220    "ResourceType":{"type":"string"},
1221    "RetryAfterSeconds":{
1222      "type":"integer",
1223      "box":true
1224    },
1225    "ServiceCode":{"type":"string"},
1226    "ServiceQuotaExceededException":{
1227      "type":"structure",
1228      "members":{
1229        "message":{"shape":"ExceptionMessage"},
1230        "resourceId":{
1231          "shape":"ResourceId",
1232          "documentation":"<p>The ID of the resource that exceeds the service quota.</p>"
1233        },
1234        "resourceType":{
1235          "shape":"ResourceType",
1236          "documentation":"<p>The type of the resource that exceeds the service quota.</p>"
1237        },
1238        "serviceCode":{
1239          "shape":"ServiceCode",
1240          "documentation":"<p>The code for the service in <a href=\"https://docs.aws.amazon.com/servicequotas/latest/userguide/intro.html\">Service Quotas</a>.</p>"
1241        },
1242        "quotaCode":{
1243          "shape":"QuotaCode",
1244          "documentation":"<p>The code for the quota in <a href=\"https://docs.aws.amazon.com/servicequotas/latest/userguide/intro.html\">Service Quotas</a>.</p>"
1245        }
1246      },
1247      "documentation":"<p>Your request exceeds a service quota.</p>",
1248      "error":{
1249        "httpStatusCode":402,
1250        "senderFault":true
1251      },
1252      "exception":true
1253    },
1254    "Software":{
1255      "type":"structure",
1256      "members":{
1257        "name":{
1258          "shape":"String",
1259          "documentation":"<p>The name of the software component.</p>"
1260        },
1261        "version":{
1262          "shape":"String",
1263          "documentation":"<p>The version of the software component.</p>"
1264        }
1265      },
1266      "documentation":"<p>Describes software.</p>"
1267    },
1268    "SoftwareList":{
1269      "type":"list",
1270      "member":{"shape":"Software"}
1271    },
1272    "SoftwareSet":{
1273      "type":"structure",
1274      "members":{
1275        "id":{
1276          "shape":"SoftwareSetId",
1277          "documentation":"<p>The ID of the software set.</p>"
1278        },
1279        "version":{
1280          "shape":"String",
1281          "documentation":"<p>The version of the software set.</p>"
1282        },
1283        "releasedAt":{
1284          "shape":"Timestamp",
1285          "documentation":"<p>The timestamp of when the software set was released.</p>"
1286        },
1287        "supportedUntil":{
1288          "shape":"Timestamp",
1289          "documentation":"<p>The timestamp of the end of support for the software set.</p>"
1290        },
1291        "validationStatus":{
1292          "shape":"SoftwareSetValidationStatus",
1293          "documentation":"<p>An option to define if the software set has been validated.</p>"
1294        },
1295        "software":{
1296          "shape":"SoftwareList",
1297          "documentation":"<p>A list of the software components in the software set.</p>"
1298        },
1299        "arn":{
1300          "shape":"Arn",
1301          "documentation":"<p>The Amazon Resource Name (ARN) of the software set.</p>"
1302        }
1303      },
1304      "documentation":"<p>Describes a software set.</p>"
1305    },
1306    "SoftwareSetId":{
1307      "type":"string",
1308      "pattern":"[0-9]{1,9}"
1309    },
1310    "SoftwareSetIdOrEmptyString":{
1311      "type":"string",
1312      "pattern":"[0-9]{0,9}"
1313    },
1314    "SoftwareSetList":{
1315      "type":"list",
1316      "member":{"shape":"SoftwareSetSummary"}
1317    },
1318    "SoftwareSetSummary":{
1319      "type":"structure",
1320      "members":{
1321        "id":{
1322          "shape":"SoftwareSetId",
1323          "documentation":"<p>The ID of the software set.</p>"
1324        },
1325        "version":{
1326          "shape":"String",
1327          "documentation":"<p>The version of the software set.</p>"
1328        },
1329        "releasedAt":{
1330          "shape":"Timestamp",
1331          "documentation":"<p>The timestamp of when the software set was released.</p>"
1332        },
1333        "supportedUntil":{
1334          "shape":"Timestamp",
1335          "documentation":"<p>The timestamp of the end of support for the software set.</p>"
1336        },
1337        "validationStatus":{
1338          "shape":"SoftwareSetValidationStatus",
1339          "documentation":"<p>An option to define if the software set has been validated.</p>"
1340        },
1341        "arn":{
1342          "shape":"Arn",
1343          "documentation":"<p>The Amazon Resource Name (ARN) of the software set.</p>"
1344        }
1345      },
1346      "documentation":"<p>Describes a software set.</p>"
1347    },
1348    "SoftwareSetUpdateMode":{
1349      "type":"string",
1350      "enum":[
1351        "USE_LATEST",
1352        "USE_DESIRED"
1353      ]
1354    },
1355    "SoftwareSetUpdateSchedule":{
1356      "type":"string",
1357      "enum":[
1358        "USE_MAINTENANCE_WINDOW",
1359        "APPLY_IMMEDIATELY"
1360      ]
1361    },
1362    "SoftwareSetUpdateStatus":{
1363      "type":"string",
1364      "enum":[
1365        "AVAILABLE",
1366        "IN_PROGRESS",
1367        "UP_TO_DATE"
1368      ]
1369    },
1370    "SoftwareSetValidationStatus":{
1371      "type":"string",
1372      "enum":[
1373        "VALIDATED",
1374        "NOT_VALIDATED"
1375      ]
1376    },
1377    "String":{"type":"string"},
1378    "TagKeys":{
1379      "type":"list",
1380      "member":{"shape":"String"},
1381      "sensitive":true
1382    },
1383    "TagResourceRequest":{
1384      "type":"structure",
1385      "required":[
1386        "resourceArn",
1387        "tags"
1388      ],
1389      "members":{
1390        "resourceArn":{
1391          "shape":"String",
1392          "documentation":"<p>The Amazon Resource Name (ARN) of the resource that you want to tag.</p>",
1393          "location":"uri",
1394          "locationName":"resourceArn"
1395        },
1396        "tags":{
1397          "shape":"TagsMap",
1398          "documentation":"<p>A map of the key-value pairs of the tag or tags to assign to the resource.</p>"
1399        }
1400      }
1401    },
1402    "TagResourceResponse":{
1403      "type":"structure",
1404      "members":{
1405      }
1406    },
1407    "TagsMap":{
1408      "type":"map",
1409      "key":{"shape":"String"},
1410      "value":{"shape":"String"},
1411      "sensitive":true
1412    },
1413    "TargetDeviceStatus":{
1414      "type":"string",
1415      "enum":[
1416        "DEREGISTERED",
1417        "ARCHIVED"
1418      ]
1419    },
1420    "ThrottlingException":{
1421      "type":"structure",
1422      "members":{
1423        "message":{"shape":"ExceptionMessage"},
1424        "serviceCode":{
1425          "shape":"ServiceCode",
1426          "documentation":"<p>The code for the service in <a href=\"https://docs.aws.amazon.com/servicequotas/latest/userguide/intro.html\">Service Quotas</a>.</p>"
1427        },
1428        "quotaCode":{
1429          "shape":"QuotaCode",
1430          "documentation":"<p>The code for the quota in <a href=\"https://docs.aws.amazon.com/servicequotas/latest/userguide/intro.html\">Service Quotas</a>.</p>"
1431        },
1432        "retryAfterSeconds":{
1433          "shape":"RetryAfterSeconds",
1434          "documentation":"<p>The number of seconds to wait before retrying the next request.</p>",
1435          "location":"header",
1436          "locationName":"Retry-After"
1437        }
1438      },
1439      "documentation":"<p>The request was denied due to request throttling.</p>",
1440      "error":{
1441        "httpStatusCode":429,
1442        "senderFault":true
1443      },
1444      "exception":true
1445    },
1446    "Timestamp":{"type":"timestamp"},
1447    "UntagResourceRequest":{
1448      "type":"structure",
1449      "required":[
1450        "resourceArn",
1451        "tagKeys"
1452      ],
1453      "members":{
1454        "resourceArn":{
1455          "shape":"String",
1456          "documentation":"<p>The Amazon Resource Name (ARN) of the resource that you want to untag.</p>",
1457          "location":"uri",
1458          "locationName":"resourceArn"
1459        },
1460        "tagKeys":{
1461          "shape":"TagKeys",
1462          "documentation":"<p>The keys of the key-value pairs for the tag or tags you want to remove from the specified resource.</p>",
1463          "location":"querystring",
1464          "locationName":"tagKeys"
1465        }
1466      }
1467    },
1468    "UntagResourceResponse":{
1469      "type":"structure",
1470      "members":{
1471      }
1472    },
1473    "UpdateDeviceRequest":{
1474      "type":"structure",
1475      "required":["id"],
1476      "members":{
1477        "id":{
1478          "shape":"DeviceId",
1479          "documentation":"<p>The ID of the device to update.</p>",
1480          "location":"uri",
1481          "locationName":"id"
1482        },
1483        "name":{
1484          "shape":"DeviceName",
1485          "documentation":"<p>The name of the device to update.</p>"
1486        },
1487        "desiredSoftwareSetId":{
1488          "shape":"SoftwareSetId",
1489          "documentation":"<p>The ID of the software set to apply.</p>"
1490        },
1491        "softwareSetUpdateSchedule":{
1492          "shape":"SoftwareSetUpdateSchedule",
1493          "documentation":"<p>An option to define if software updates should be applied within a maintenance window.</p>"
1494        },
1495        "kmsKeyArn":{
1496          "shape":"KmsKeyArn",
1497          "documentation":"<p>The Amazon Resource Name (ARN) of the Key Management Service key to use for the update.</p>"
1498        }
1499      }
1500    },
1501    "UpdateDeviceResponse":{
1502      "type":"structure",
1503      "members":{
1504        "device":{
1505          "shape":"DeviceSummary",
1506          "documentation":"<p>Describes a device.</p>"
1507        }
1508      }
1509    },
1510    "UpdateEnvironmentRequest":{
1511      "type":"structure",
1512      "required":["id"],
1513      "members":{
1514        "id":{
1515          "shape":"EnvironmentId",
1516          "documentation":"<p>The ID of the environment to update.</p>",
1517          "location":"uri",
1518          "locationName":"id"
1519        },
1520        "name":{
1521          "shape":"EnvironmentName",
1522          "documentation":"<p>The name of the environment to update.</p>"
1523        },
1524        "desktopArn":{
1525          "shape":"Arn",
1526          "documentation":"<p>The Amazon Resource Name (ARN) of the desktop to stream from Amazon WorkSpaces, WorkSpaces Web, or AppStream 2.0.</p>"
1527        },
1528        "desktopEndpoint":{
1529          "shape":"DesktopEndpoint",
1530          "documentation":"<p>The URL for the identity provider login (only for environments that use AppStream 2.0).</p>"
1531        },
1532        "softwareSetUpdateSchedule":{
1533          "shape":"SoftwareSetUpdateSchedule",
1534          "documentation":"<p>An option to define if software updates should be applied within a maintenance window.</p>"
1535        },
1536        "maintenanceWindow":{
1537          "shape":"MaintenanceWindow",
1538          "documentation":"<p>A specification for a time window to apply software updates.</p>"
1539        },
1540        "softwareSetUpdateMode":{
1541          "shape":"SoftwareSetUpdateMode",
1542          "documentation":"<p>An option to define which software updates to apply.</p>"
1543        },
1544        "desiredSoftwareSetId":{
1545          "shape":"SoftwareSetIdOrEmptyString",
1546          "documentation":"<p>The ID of the software set to apply.</p>"
1547        }
1548      }
1549    },
1550    "UpdateEnvironmentResponse":{
1551      "type":"structure",
1552      "members":{
1553        "environment":{
1554          "shape":"EnvironmentSummary",
1555          "documentation":"<p>Describes an environment.</p>"
1556        }
1557      }
1558    },
1559    "UpdateSoftwareSetRequest":{
1560      "type":"structure",
1561      "required":[
1562        "id",
1563        "validationStatus"
1564      ],
1565      "members":{
1566        "id":{
1567          "shape":"SoftwareSetId",
1568          "documentation":"<p>The ID of the software set to update.</p>",
1569          "location":"uri",
1570          "locationName":"id"
1571        },
1572        "validationStatus":{
1573          "shape":"SoftwareSetValidationStatus",
1574          "documentation":"<p>An option to define if the software set has been validated.</p>"
1575        }
1576      }
1577    },
1578    "UpdateSoftwareSetResponse":{
1579      "type":"structure",
1580      "members":{
1581      }
1582    },
1583    "ValidationException":{
1584      "type":"structure",
1585      "members":{
1586        "message":{"shape":"ExceptionMessage"},
1587        "reason":{
1588          "shape":"ValidationExceptionReason",
1589          "documentation":"<p>The reason for the exception.</p>"
1590        },
1591        "fieldList":{
1592          "shape":"ValidationExceptionFieldList",
1593          "documentation":"<p>A list of fields that didn't validate.</p>"
1594        }
1595      },
1596      "documentation":"<p>The input fails to satisfy the specified constraints.</p>",
1597      "error":{
1598        "httpStatusCode":400,
1599        "senderFault":true
1600      },
1601      "exception":true
1602    },
1603    "ValidationExceptionField":{
1604      "type":"structure",
1605      "required":[
1606        "name",
1607        "message"
1608      ],
1609      "members":{
1610        "name":{
1611          "shape":"FieldName",
1612          "documentation":"<p>The name of the exception.</p>"
1613        },
1614        "message":{
1615          "shape":"ExceptionMessage",
1616          "documentation":"<p>A message that describes the reason for the exception.</p>"
1617        }
1618      },
1619      "documentation":"<p>Describes a validation exception.</p>"
1620    },
1621    "ValidationExceptionFieldList":{
1622      "type":"list",
1623      "member":{"shape":"ValidationExceptionField"}
1624    },
1625    "ValidationExceptionReason":{
1626      "type":"string",
1627      "enum":[
1628        "unknownOperation",
1629        "cannotParse",
1630        "fieldValidationFailed",
1631        "other"
1632      ]
1633    }
1634  },
1635  "documentation":"<p>Amazon WorkSpaces Thin Client is a affordable device built to work with Amazon Web Services End User Computing (EUC) virtual desktops to provide users with a complete cloud desktop solution. WorkSpaces Thin Client is a compact device designed to connect up to two monitors and USB devices like a keyboard, mouse, headset, and webcam. To maximize endpoint security, WorkSpaces Thin Client devices do not allow local data storage or installation of unapproved applications. The WorkSpaces Thin Client device ships preloaded with device management software.</p> <p>You can use these APIs to complete WorkSpaces Thin Client tasks, such as creating environments or viewing devices. For more information about WorkSpaces Thin Client, including the required permissions to use the service, see the <a href=\"https://docs.aws.amazon.com/workspaces-thin-client/latest/ag/\">Amazon WorkSpaces Thin Client Administrator Guide</a>. For more information about using the Command Line Interface (CLI) to manage your WorkSpaces Thin Client resources, see the <a href=\"https://docs.aws.amazon.com/cli/latest/reference/workspaces-thin-client/index.html\">WorkSpaces Thin Client section of the CLI Reference</a>.</p>"
1636}
1637