Ejemplo n.º 1
0
        private bool ADSetADClaimTransformLinkBeginCSRoutine()
        {
            ADClaimTransformPolicy item     = this._cmdletParameters["Policy"] as ADClaimTransformPolicy;
            ADTrustRole?           nullable = (ADTrustRole?)(this._cmdletParameters["TrustRole"] as ADTrustRole?);
            string value = null;

            if (item != null)
            {
                if (!item.IsSearchResult)
                {
                    ADClaimTransformPolicyFactory <ADClaimTransformPolicy> aDClaimTransformPolicyFactory = new ADClaimTransformPolicyFactory <ADClaimTransformPolicy>();
                    CmdletSessionInfo cmdletSessionInfo = base.GetCmdletSessionInfo();
                    aDClaimTransformPolicyFactory.SetCmdletSessionInfo(cmdletSessionInfo);
                    string   str = ADPathModule.MakePath(cmdletSessionInfo.ADRootDSE.ConfigurationNamingContext, "CN=Claims Transformation Policies,CN=Claims Configuration,CN=Services,", ADPathFormat.X500);
                    ADObject directoryObjectFromIdentity = aDClaimTransformPolicyFactory.GetDirectoryObjectFromIdentity(item, str);
                    value = directoryObjectFromIdentity["distinguishedName"].Value as string;
                }
                else
                {
                    value = item["distinguishedName"].Value as string;
                }
            }
            ADTrustRole aDTrustRole = nullable.Value;

            switch (aDTrustRole)
            {
            case ADTrustRole.Trusted:
                {
                    this._cmdletParameters["TrustedPolicy"] = value;
                    break;
                }

            case ADTrustRole.Trusting:
            {
                this._cmdletParameters["TrustingPolicy"] = value;
                break;
            }
            }
            this._cmdletParameters.RemoveParameter("Policy");
            return(true);
        }
        private bool ADSClearADClaimTransformLinkCSRoutine()
        {
            string   value;
            ADObject extendedObjectFromIdentity;
            ADClaimTransformPolicy item     = this._cmdletParameters["Policy"] as ADClaimTransformPolicy;
            ADTrustRole?           nullable = (ADTrustRole?)(this._cmdletParameters["TrustRole"] as ADTrustRole?);

            this._cmdletParameters.RemoveParameter("TrustedPolicy");
            this._cmdletParameters.RemoveParameter("TrustingPolicy");
            if (item != null || nullable.HasValue)
            {
                if (item != null)
                {
                    CmdletSessionInfo cmdletSessionInfo = base.GetCmdletSessionInfo();
                    if (!item.IsSearchResult)
                    {
                        ADClaimTransformPolicyFactory <ADClaimTransformPolicy> aDClaimTransformPolicyFactory = new ADClaimTransformPolicyFactory <ADClaimTransformPolicy>();
                        aDClaimTransformPolicyFactory.SetCmdletSessionInfo(cmdletSessionInfo);
                        string   str = ADPathModule.MakePath(cmdletSessionInfo.ADRootDSE.ConfigurationNamingContext, "CN=Claims Transformation Policies,CN=Claims Configuration,CN=Services,", ADPathFormat.X500);
                        ADObject directoryObjectFromIdentity = aDClaimTransformPolicyFactory.GetDirectoryObjectFromIdentity(item, str);
                        value = directoryObjectFromIdentity["distinguishedName"].Value as string;
                    }
                    else
                    {
                        value = item["distinguishedName"].Value as string;
                    }
                    ADTrust aDTrust = this._cmdletParameters["Identity"] as ADTrust;
                    if (!aDTrust.IsSearchResult)
                    {
                        ADTrustFactory <ADTrust> aDTrustFactory = new ADTrustFactory <ADTrust>();
                        aDTrustFactory.SetCmdletSessionInfo(cmdletSessionInfo);
                        string wellKnownGuidDN = Utils.GetWellKnownGuidDN(this.GetSessionInfo(), base.GetDefaultPartitionPath(), WellKnownGuids.SystemsContainerGuid);
                        extendedObjectFromIdentity = aDTrustFactory.GetExtendedObjectFromIdentity(aDTrust, wellKnownGuidDN);
                    }
                    else
                    {
                        extendedObjectFromIdentity = aDTrust;
                    }
                    if (nullable.HasValue)
                    {
                        if (nullable.Value != ADTrustRole.Trusted)
                        {
                            if (ADTrustRole.Trusting == nullable.Value && string.Compare(extendedObjectFromIdentity["TrustingPolicy"].Value as string, value, StringComparison.OrdinalIgnoreCase) == 0)
                            {
                                this._cmdletParameters["TrustingPolicy"] = null;
                            }
                        }
                        else
                        {
                            if (string.Compare(extendedObjectFromIdentity["TrustedPolicy"].Value as string, value, StringComparison.OrdinalIgnoreCase) == 0)
                            {
                                this._cmdletParameters["TrustedPolicy"] = null;
                            }
                        }
                    }
                    else
                    {
                        if (string.Compare(extendedObjectFromIdentity["TrustingPolicy"].Value as string, value, StringComparison.OrdinalIgnoreCase) == 0)
                        {
                            this._cmdletParameters["TrustingPolicy"] = null;
                        }
                        if (string.Compare(extendedObjectFromIdentity["TrustedPolicy"].Value as string, value, StringComparison.OrdinalIgnoreCase) == 0)
                        {
                            this._cmdletParameters["TrustedPolicy"] = null;
                        }
                    }
                }
                else
                {
                    ADTrustRole aDTrustRole = nullable.Value;
                    switch (aDTrustRole)
                    {
                    case ADTrustRole.Trusted:
                    {
                        this._cmdletParameters["TrustedPolicy"] = null;
                        break;
                    }

                    case ADTrustRole.Trusting:
                    {
                        this._cmdletParameters["TrustingPolicy"] = null;
                        break;
                    }
                    }
                }
                return(true);
            }
            else
            {
                throw new ArgumentException(StringResources.ADTrustNoDirectionAndPolicyError);
            }
        }