(.Net)Active Directroyの情報を参照でのサンプルソースの補足です。
ユーザーアカウント情報を持つ User クラスです。(C#)
public class User{
/// <summary>
/// objectGUID キー値
/// </summary>
public Guid dmObjectGUID{get;set;}
/// <summary>
/// objectSID
/// </summary>
public string dmObjectSID { get; set; }
/// <summary>
/// sAMAccountName ログインアカウント名
/// </summary>
public string dmSamAccountName { get; set; }
/// <summary>
/// userPrincipalName ログインアカウント名(AD環境 xx@aa.jp)
/// </summary>
public string dmUserPrincipalName { get; set; }
/// <summary>
/// createTimeStamp アカウント作成日時(なぜか空)
/// </summary>
public DateTime dmCreateTimeStamp { get; set; }
/// <summary>
/// modifyTimeStamp アカウント変更日時(なぜか空)
/// </summary>
public DateTime dmModifyTimeStamp { get; set; }
/// <summary>
/// WhenCreated アカウント作成日時
/// </summary>
public DateTime dmWhenCreated{ get; set; }
/// <summary>
/// WhenChanged アカウント変更日時
/// </summary>
public DateTime dmWhenChanged { get; set; }
/// <summary>
/// displayName 表示名
/// </summary>
public string dmDisplayName { get; set; }
/// <summary>
/// logonCount ログイン回数(ドメイン間複製無し)
/// </summary>
public long dmLogonCount { get; set; }
/// <summary>
/// lastLogon 最終ログイン日時(ドメイン間複製無)
/// </summary>
public DateTime dmLastLogon { get; set; }
/// <summary>
/// lastLoginTimeStamp 最終ログイン日時(14日毎ドメイン間複製あり)
/// </summary>
public DateTime dmLastLogonTimeStamp { get; set; }
/// <summary>
/// userAccountControl ユーザのアカウントに関する情報(無効情報もここにあり)
/// </summary>
public int dmUserAccountControl { get; set; }
/// <summary>
/// distinguishedName 識別名。DN表記
/// </summary>
public string dmDistinguishedName { get; set; }
private List<string> mDmMemberOf = new List<string>();
/// <summary>
/// memberOf ユーザが属しているグループ。DN表記
/// </summary>
public List<string> dmMemberOf { get { return mDmMemberOf; } set { mDmMemberOf=value; } }
/// <summary>
/// sn 姓
/// </summary>
public string dmSn { get; set; }
/// <summary>
/// givenName 名
/// </summary>
public string dmGivenName { get; set; }
/// <summary>
/// cn CN名
/// </summary>
public string dmCn { get; set; }
/// <summary>
/// description 説明
/// </summary>
public string dmDescription { get; set; }
/// <summary>
/// accountExpirationDate アカウント有効期限
/// </summary>
public DateTime dmAccountExpirationDate { get; set; }
/// <summary>
/// objectcategory オブジェクトのカテゴリ
/// </summary>
public string dmObjectCategory { get; set; }
/// <summary>
/// adspath オブジェクトへのパス
/// </summary>
public string dmAdsPath { get; set; }
/// <summary>
/// アカウント無効か
/// </summary>
public bool Disable { get; set; }
/// <summary>
/// ログオンスクリプト実行
/// </summary>
public bool Script{ get; set; }
/// <summary>
/// ホームフォルダが必要
/// </summary>
public bool HomeDirReauired { get; set; }
/// <summary>
/// ロックアウトしてる
/// </summary>
public bool LockOut { get; set; }
/// <summary>
/// パスワードが必要ない
/// </summary>
public bool PasswdNotReqd { get; set; }
/// <summary>
/// パスワードが変更できない
/// </summary>
public bool PasswdCantChange { get; set; }
/// <summary>
/// 暗号化されたパスワードを送信できる
/// </summary>
public bool EncPasswdAllowed { get; set; }
/// <summary>
/// 別のドメインにプライマリ アカウントを持つユーザーが使用するアカウントです。このアカウントが存在することにより、ユーザーはこのドメインにアクセスできますが、このドメインを 信頼するドメインへのアクセスはできません。これはローカル ユーザー アカウントとして参照される場合があります。
/// </summary>
public bool TempDuplicateAccount { get; set; }
/// <summary>
/// 通常のユーザー
/// </summary>
public bool NormalAccount { get; set; }
/// <summary>
/// 別のドメインを信頼しているシステム ドメインのアカウントを信頼することを許可します。
/// </summary>
public bool InterdomainTrustAccount { get; set; }
/// <summary>
/// Microsoft Windows NT 4.0 Workstation、Microsoft Windows NT 4.0 Server、Microsoft Windows 2000 Professional、または Windows 2000 Server を実行している動作するコンピュータのコンピュータ アカウントであり、このドメインのメンバです。
/// </summary>
public bool WorkstTrustAccount { get; set; }
/// <summary>
/// このドメインのメンバであるドメイン コントローラのコンピュータ アカウントです。
/// </summary>
public bool ServerTrustAccount { get; set; }
/// <summary>
/// パスワード無期限
/// </summary>
public bool DontExpirePasswd { get; set; }
/// <summary>
/// MNSログインアカウント
/// </summary>
public bool MnsLogon { get; set; }
/// <summary>
/// スマートカードログイン
/// </summary>
public bool SmartCardRequired { get; set; }
/// <summary>
/// このフラグを設定すると、サービスを実行するサービス アカウント (ユーザー アカウントまたはコンピュータ アカウント) が Kerberos の委任に対して信頼されます。このようなサービスでは、サービスを要求するクライアントを偽装することができます。サービスで Kerberos の委任を有効にするには、このフラグをサービス アカウントの userAccountControl プロパティに設定する必要があります。
/// </summary>
public bool TrustedForDelegation { get; set; }
/// <summary>
/// このフラグを設定すると、サービス アカウントが Kerberos の委任に対して信頼されると設定されていても、ユーザーのセキュリティ コンテキストはサービスに委任されません。
/// </summary>
public bool NotDelegated { get; set; }
/// <summary>
/// このプリンシパルを、DES (Data Encryption Standard) 暗号化のみをキーに使用できるように制限します
/// </summary>
public bool UseDesKeyOnly { get; set; }
/// <summary>
/// このアカウントは、ログオン時に Kerberos 事前認証を必要としません。
/// </summary>
public bool DontReqPreauth { get; set; }
/// <summary>
/// ユーザーのパスワードの有効期限が切れています。
/// </summary>
public bool PasswdExpired { get; set; }
/// <summary>
/// このアカウントは委任に対して有効です。これはセキュリティに代わる設定です。このオプションが設定されたアカウントは厳密に管理する必要があります。こ の設定を行うと、アカウントで実行されているサービスはクライアントとして識別され、ネットワーク上の他のリモート サーバーへそのユーザーとして認証されます
/// </summary>
public bool TrustedToAuthForDelegation { get; set; }
/// <summary>
/// PrimaryグループSID(プライマリグループはMemberOfで取れないため)
/// </summary>
public string PrimaryGroupSID { get; set; }
}