/
PutAccountPreferencesCommand.ts
111 lines (101 loc) · 4.7 KB
/
PutAccountPreferencesCommand.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// smithy-typescript generated code
import { getSerdePlugin } from "@aws-sdk/middleware-serde";
import { HttpRequest as __HttpRequest, HttpResponse as __HttpResponse } from "@aws-sdk/protocol-http";
import { Command as $Command } from "@aws-sdk/smithy-client";
import {
FinalizeHandlerArguments,
Handler,
HandlerExecutionContext,
HttpHandlerOptions as __HttpHandlerOptions,
MetadataBearer as __MetadataBearer,
MiddlewareStack,
SerdeContext as __SerdeContext,
} from "@aws-sdk/types";
import { EFSClientResolvedConfig, ServiceInputTypes, ServiceOutputTypes } from "../EFSClient";
import {
PutAccountPreferencesRequest,
PutAccountPreferencesRequestFilterSensitiveLog,
PutAccountPreferencesResponse,
PutAccountPreferencesResponseFilterSensitiveLog,
} from "../models/models_0";
import {
deserializeAws_restJson1PutAccountPreferencesCommand,
serializeAws_restJson1PutAccountPreferencesCommand,
} from "../protocols/Aws_restJson1";
export interface PutAccountPreferencesCommandInput extends PutAccountPreferencesRequest {}
export interface PutAccountPreferencesCommandOutput extends PutAccountPreferencesResponse, __MetadataBearer {}
/**
* <p>Use this operation to set the account preference in the current Amazon Web Services Region
* to use long 17 character (63 bit) or short 8 character (32 bit) resource IDs for
* new EFS file system and mount target resources. All existing resource IDs are not affected
* by any changes you make. You can set the ID preference during the
* opt-in period as EFS transitions to long resource IDs. For more information,
* see <a href="https://docs.aws.amazon.com/efs/latest/ug/manage-efs-resource-ids.html">Managing Amazon EFS resource IDs</a>.</p>
* <note>
* <p>Starting in October, 2021, you will receive an error if you try to set the account preference
* to use the short 8 character format resource ID. Contact Amazon Web Services support if you
* receive an error and must use short IDs for file system and mount target resources.</p>
* </note>
* @example
* Use a bare-bones client and the command you need to make an API call.
* ```javascript
* import { EFSClient, PutAccountPreferencesCommand } from "@aws-sdk/client-efs"; // ES Modules import
* // const { EFSClient, PutAccountPreferencesCommand } = require("@aws-sdk/client-efs"); // CommonJS import
* const client = new EFSClient(config);
* const command = new PutAccountPreferencesCommand(input);
* const response = await client.send(command);
* ```
*
* @see {@link PutAccountPreferencesCommandInput} for command's `input` shape.
* @see {@link PutAccountPreferencesCommandOutput} for command's `response` shape.
* @see {@link EFSClientResolvedConfig | config} for EFSClient's `config` shape.
*
*/
export class PutAccountPreferencesCommand extends $Command<
PutAccountPreferencesCommandInput,
PutAccountPreferencesCommandOutput,
EFSClientResolvedConfig
> {
// Start section: command_properties
// End section: command_properties
constructor(readonly input: PutAccountPreferencesCommandInput) {
// Start section: command_constructor
super();
// End section: command_constructor
}
/**
* @internal
*/
resolveMiddleware(
clientStack: MiddlewareStack<ServiceInputTypes, ServiceOutputTypes>,
configuration: EFSClientResolvedConfig,
options?: __HttpHandlerOptions
): Handler<PutAccountPreferencesCommandInput, PutAccountPreferencesCommandOutput> {
this.middlewareStack.use(getSerdePlugin(configuration, this.serialize, this.deserialize));
const stack = clientStack.concat(this.middlewareStack);
const { logger } = configuration;
const clientName = "EFSClient";
const commandName = "PutAccountPreferencesCommand";
const handlerExecutionContext: HandlerExecutionContext = {
logger,
clientName,
commandName,
inputFilterSensitiveLog: PutAccountPreferencesRequestFilterSensitiveLog,
outputFilterSensitiveLog: PutAccountPreferencesResponseFilterSensitiveLog,
};
const { requestHandler } = configuration;
return stack.resolve(
(request: FinalizeHandlerArguments<any>) =>
requestHandler.handle(request.request as __HttpRequest, options || {}),
handlerExecutionContext
);
}
private serialize(input: PutAccountPreferencesCommandInput, context: __SerdeContext): Promise<__HttpRequest> {
return serializeAws_restJson1PutAccountPreferencesCommand(input, context);
}
private deserialize(output: __HttpResponse, context: __SerdeContext): Promise<PutAccountPreferencesCommandOutput> {
return deserializeAws_restJson1PutAccountPreferencesCommand(output, context);
}
// Start section: command_body_extra
// End section: command_body_extra
}