Exchange 2010 Powershell + C #: как выполнить запрос WHERE - PullRequest
1 голос
/ 21 сентября 2011

Я использую exchange powershell в C # следующим образом:

public PowershellResult GetSendAsPermissions(string TargetIdentity)
    {
        string CommandName = "get-adpermission";

        Command cmd1 = new Command(CommandName);
        cmd1.Parameters.Add("Identity", TargetIdentity);
        if (powershell.DomainController.Length > 0)
        {
            cmd1.Parameters.Add("DomainController", powershell.DomainController);
        }

        List<Command> commands = new List<Command>();
        commands.Add(cmd1);
        string errorMessages = string.Empty;
        Collection<PSObject> commandResults = powershell.ExecutePowershellCommand(commands, out errorMessages);


        PowershellResult psr = null;

        if (errorMessages.Length == 0)
        {
            psr = new PowershellResult(true, "Successfully managed SendAs permission.", 0);
        }
        else
        {
            psr = new PowershellResult(false, string.Format("Error managing SendAs permission: {0}", errorMessages), 0);
        }
        return psr;
    }

public Collection<PSObject> ExecutePowershellCommand(List<Command> commands, out string errorMessages)
    {
        errorMessages = "";
        this.ps.Commands.Clear();
        ps.Streams.Error.Clear();
        if (commands != null)
        {
            foreach (Command cmd in commands)
            {
                this.ps.Commands.AddCommand(cmd);
            }
            Collection<PSObject> ret = null;
            try
            {
                ret = this.ps.Invoke();
                if (this.ps.Streams.Error.Count > 0)
                {
                    StringBuilder stb = new StringBuilder();
                    foreach (ErrorRecord err in this.ps.Streams.Error)
                    {
                        if (err.Exception.Message != null)
                        {
                            stb.AppendLine(err.Exception.Message);
                        }
                    }
                    errorMessages = stb.ToString();
                }
            }
            catch (Exception ex)
            {
                StringBuilder stb = new StringBuilder();
                if (ex.Message != null)
                {
                    stb.Append(ex.Message);
                }
                if (ex.InnerException != null)
                {
                    if (ex.InnerException.Message != null)
                    {
                        stb.Append(string.Format(" {0}", ex.InnerException));
                    }
                }
                errorMessages = stb.ToString().Trim();
            }

            return ret;
        }
        else
        {
            return null;
        }
    }

Теперь я хочу добавить предложение "where" к команде get-adpermission, например:

Get-ADPermission | where {($_.ExtendedRights -like “*Send-As*”) -and ($_.IsInherited -eq $false) -and -not ($_.User -like “NT AUTHORITY\SELF”)} 

Я абсолютно не знаю, куда поместить предложение where или как определить эти аргументы в фигурных скобках.У кого-нибудь есть идея?

1 Ответ

1 голос
/ 21 сентября 2011

Я вижу

 Collection<PSObject> commandResults = powershell.ExecutePowershellCommand(commands, out errorMessages);

, но с commandResults ничего не делается - они не передаются обратно вызывающей стороне.

То, что вам нужно, выглядит примерно так

 var filteredResults = commandResults.Where(cr =>    
       (((string)cr.Properties["ExtendedRights"].Value).Contains("Send-As")) && 
       (((bool)cr.Properties["IsInherited"].Value) == false) &&
       (((string)cr.Properties["User"].Value) == "NT AUTHORITY\\SELF"))

Это (надеюсь) даст вам отфильтрованный список comandResults, содержащий только те элементы, которые вам нужны.Вы захотите как-то передать это вызывающему абоненту или сделать что-то еще с ними.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...