/* * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * * Licensed under the Apache License, Version 2.0 (the "License"). * You may not use this file except in compliance with the License. * A copy of the License is located at * * http://aws.amazon.com/apache2.0 * * or in the "license" file accompanying this file. This file is distributed * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either * express or implied. See the License for the specific language governing * permissions and limitations under the License. */ /* * Do not modify this file. This file is generated from the organizations-2016-11-28.normal.json service model. */ using System; using System.Collections.Generic; using System.Xml.Serialization; using System.Text; using System.IO; using System.Net; using Amazon.Runtime; using Amazon.Runtime.Internal; namespace Amazon.Organizations.Model { /// /// Container for the parameters to the InviteAccountToOrganization operation. /// Sends an invitation to another account to join your organization as a member account. /// Organizations sends email on your behalf to the email address that is associated with /// the other account's owner. The invitation is implemented as a Handshake whose /// details are in the response. /// /// /// /// If the request includes tags, then the requester must have the organizations:TagResource /// permission. /// /// /// /// This operation can be called only from the organization's management account. /// /// public partial class InviteAccountToOrganizationRequest : AmazonOrganizationsRequest { private string _notes; private List _tags = new List(); private HandshakeParty _target; /// /// Gets and sets the property Notes. /// /// Additional information that you want to include in the generated email to the recipient /// account owner. /// /// [AWSProperty(Sensitive=true, Max=1024)] public string Notes { get { return this._notes; } set { this._notes = value; } } // Check to see if Notes property is set internal bool IsSetNotes() { return this._notes != null; } /// /// Gets and sets the property Tags. /// /// A list of tags that you want to attach to the account when it becomes a member of /// the organization. For each tag in the list, you must specify both a tag key and a /// value. You can set the value to an empty string, but you can't set it to null. /// For more information about tagging, see Tagging /// Organizations resources in the Organizations User Guide. /// /// /// /// Any tags in the request are checked for compliance with any applicable tag policies /// when the request is made. The request is rejected if the tags in the request don't /// match the requirements of the policy at that time. Tag policy compliance is not /// checked again when the invitation is accepted and the tags are actually attached /// to the account. That means that if the tag policy changes between the invitation and /// the acceptance, then that tags could potentially be non-compliant. /// /// /// /// If any one of the tags is not valid or if you exceed the allowed number of tags for /// an account, then the entire request fails and invitations are not sent. /// /// /// public List Tags { get { return this._tags; } set { this._tags = value; } } // Check to see if Tags property is set internal bool IsSetTags() { return this._tags != null && this._tags.Count > 0; } /// /// Gets and sets the property Target. /// /// The identifier (ID) of the Amazon Web Services account that you want to invite to /// join your organization. This is a JSON object that contains the following elements: /// /// /// /// { "Type": "ACCOUNT", "Id": "< account id number >" } /// /// /// /// /// If you use the CLI, you can submit this as a single string, similar to the following /// example: /// /// /// /// --target Id=123456789012,Type=ACCOUNT /// /// /// /// If you specify "Type": "ACCOUNT", you must provide the Amazon Web Services /// account ID number as the Id. If you specify "Type": "EMAIL", /// you must specify the email address that is associated with the account. /// /// /// /// --target Id=diego@example.com,Type=EMAIL /// /// [AWSProperty(Required=true)] public HandshakeParty Target { get { return this._target; } set { this._target = value; } } // Check to see if Target property is set internal bool IsSetTarget() { return this._target != null; } } }