/*
* 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 clouddirectory-2017-01-11.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.CloudDirectory.Model
{
///
/// Container for the parameters to the CreateObject operation.
/// Creates an object in a Directory. Additionally attaches the object to a parent,
/// if a parent reference and LinkName
is specified. An object is simply
/// a collection of Facet attributes. You can also use this API call to create
/// a policy object, if the facet from which you create the object is a policy facet.
///
public partial class CreateObjectRequest : AmazonCloudDirectoryRequest
{
private string _directoryArn;
private string _linkName;
private List _objectAttributeList = new List();
private ObjectReference _parentReference;
private List _schemaFacets = new List();
///
/// Gets and sets the property DirectoryArn.
///
/// The Amazon Resource Name (ARN) that is associated with the Directory in which
/// the object will be created. For more information, see arns.
///
///
[AWSProperty(Required=true)]
public string DirectoryArn
{
get { return this._directoryArn; }
set { this._directoryArn = value; }
}
// Check to see if DirectoryArn property is set
internal bool IsSetDirectoryArn()
{
return this._directoryArn != null;
}
///
/// Gets and sets the property LinkName.
///
/// The name of link that is used to attach this object to a parent.
///
///
[AWSProperty(Min=1, Max=64)]
public string LinkName
{
get { return this._linkName; }
set { this._linkName = value; }
}
// Check to see if LinkName property is set
internal bool IsSetLinkName()
{
return this._linkName != null;
}
///
/// Gets and sets the property ObjectAttributeList.
///
/// The attribute map whose attribute ARN contains the key and attribute value as the
/// map value.
///
///
public List ObjectAttributeList
{
get { return this._objectAttributeList; }
set { this._objectAttributeList = value; }
}
// Check to see if ObjectAttributeList property is set
internal bool IsSetObjectAttributeList()
{
return this._objectAttributeList != null && this._objectAttributeList.Count > 0;
}
///
/// Gets and sets the property ParentReference.
///
/// If specified, the parent reference to which this object will be attached.
///
///
public ObjectReference ParentReference
{
get { return this._parentReference; }
set { this._parentReference = value; }
}
// Check to see if ParentReference property is set
internal bool IsSetParentReference()
{
return this._parentReference != null;
}
///
/// Gets and sets the property SchemaFacets.
///
/// A list of schema facets to be associated with the object. Do not provide minor version
/// components. See SchemaFacet for details.
///
///
[AWSProperty(Required=true)]
public List SchemaFacets
{
get { return this._schemaFacets; }
set { this._schemaFacets = value; }
}
// Check to see if SchemaFacets property is set
internal bool IsSetSchemaFacets()
{
return this._schemaFacets != null && this._schemaFacets.Count > 0;
}
}
}