/*
* 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 managedblockchain-2018-09-24.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.ManagedBlockchain.Model
{
///
/// An invitation to an Amazon Web Services account to create a member and join the network.
///
///
///
/// Applies only to Hyperledger Fabric.
///
///
public partial class Invitation
{
private string _arn;
private DateTime? _creationDate;
private DateTime? _expirationDate;
private string _invitationId;
private NetworkSummary _networkSummary;
private InvitationStatus _status;
///
/// Gets and sets the property Arn.
///
/// The Amazon Resource Name (ARN) of the invitation. For more information about ARNs
/// and their format, see Amazon
/// Resource Names (ARNs) in the Amazon Web Services General Reference.
///
///
[AWSProperty(Min=1, Max=1011)]
public string Arn
{
get { return this._arn; }
set { this._arn = value; }
}
// Check to see if Arn property is set
internal bool IsSetArn()
{
return this._arn != null;
}
///
/// Gets and sets the property CreationDate.
///
/// The date and time that the invitation was created.
///
///
public DateTime CreationDate
{
get { return this._creationDate.GetValueOrDefault(); }
set { this._creationDate = value; }
}
// Check to see if CreationDate property is set
internal bool IsSetCreationDate()
{
return this._creationDate.HasValue;
}
///
/// Gets and sets the property ExpirationDate.
///
/// The date and time that the invitation expires. This is the CreationDate
/// plus the ProposalDurationInHours
that is specified in the ProposalThresholdPolicy
.
/// After this date and time, the invitee can no longer create a member and join the network
/// using this InvitationId
.
///
///
public DateTime ExpirationDate
{
get { return this._expirationDate.GetValueOrDefault(); }
set { this._expirationDate = value; }
}
// Check to see if ExpirationDate property is set
internal bool IsSetExpirationDate()
{
return this._expirationDate.HasValue;
}
///
/// Gets and sets the property InvitationId.
///
/// The unique identifier for the invitation.
///
///
[AWSProperty(Min=1, Max=32)]
public string InvitationId
{
get { return this._invitationId; }
set { this._invitationId = value; }
}
// Check to see if InvitationId property is set
internal bool IsSetInvitationId()
{
return this._invitationId != null;
}
///
/// Gets and sets the property NetworkSummary.
///
public NetworkSummary NetworkSummary
{
get { return this._networkSummary; }
set { this._networkSummary = value; }
}
// Check to see if NetworkSummary property is set
internal bool IsSetNetworkSummary()
{
return this._networkSummary != null;
}
///
/// Gets and sets the property Status.
///
/// The status of the invitation:
///
/// -
///
///
PENDING
- The invitee hasn't created a member to join the network, and
/// the invitation hasn't yet expired.
///
/// -
///
///
ACCEPTING
- The invitee has begun creating a member, and creation hasn't
/// yet completed.
///
/// -
///
///
ACCEPTED
- The invitee created a member and joined the network using
/// the InvitationID
.
///
/// -
///
///
REJECTED
- The invitee rejected the invitation.
///
/// -
///
///
EXPIRED
- The invitee neither created a member nor rejected the invitation
/// before the ExpirationDate
.
///
///
///
public InvitationStatus Status
{
get { return this._status; }
set { this._status = value; }
}
// Check to see if Status property is set
internal bool IsSetStatus()
{
return this._status != null;
}
}
}