C#amo完成角色

时间:2015-04-15 09:33:35

标签: c# ssas roles

我正在开发一个SSAS项目,其中我需要在C#中获得表格多维数据集的完整用户列表。 目前我的工作方式是我可以获得角色,但数据不完整。当我调用Server.Database.Roles(简化为可读性)属性并通过它枚举时,我只获得ID,Name和CreatedTimeStamp。我所缺少的,至关重要的是会员,CellPermissions(DAX过滤器)以及这些成员的权限。 我目前在Server.Database.Cube中寻找的权限(读/写/管理员),但CubePermissions是空的......

在SSMS中,当我编写我的一个testroles时,该角色包含:

<ID>Role</ID>
        <Name>TestRole</Name>
        <Description>role for testing</Description>
        <Members>
            <Member>
                <Name>THORVALDDATA\rj</Name>
                <Sid>OMITTED</Sid>
            </Member>
            <Member>
                <Name>THORVALDDATA\dp</Name>
                <Sid>OMITTED</Sid>
            </Member>
            <Member>
                <Name>THORVALDDATA\jtl</Name>
                <Sid>OMITTED</Sid>
            </Member>
        </Members>

但如前所述,当我在代码中枚举它时,我不会得到成员和描述。

你们这些聪明的人能帮助我弄清楚这里出了什么问题吗?

我的所有代码:

        RoleCollection roleCollection = _analysisServer.Databases[dbID].Roles;

        Database database = _analysisServer.Databases[dbID];

        Dictionary<string, CubeRole> roles = new Dictionary<string, CubeRole>();
        foreach (Role role in roleCollection)
        {
            CubeRole cRole = new CubeRole();
            cRole.ID = role.ID;
            cRole.Name = role.Name;

            cRole.Members = role.Members;
            CubeCollection cubeCollection = _analysisServer.Databases[dbID].Cubes;

            foreach (Cube cube in cubeCollection)
            {
                foreach (CubePermission cubePermission in cube.CubePermissions)
                {
                    cRole.Filters = cubePermission.CellPermissions;
                    cRole.Permission.Add(cubePermission);
                }
            }
            roles.Add(cRole.Name, cRole);
        }
        return roles;

1 个答案:

答案 0 :(得分:0)

使用表格,您可以在服务器级别拥有管理员。在数据库级别,您只有3个内置权限:1)完全控制2)Process Database&amp; 3)阅读。您在数据库中创建的每个角色都可以选择这些权限。表格中没有立方体,所以你只有2个级别,服务器和数据库。 MSDN是理解权限的良好起点。表格https://msdn.microsoft.com/en-us/library/hh213165.aspx

中的角色

您可以遍历数据库的角色,以拉出每个角色中的角色成员以及与每个角色关联的权限:

   //loop through database permissions
   foreach (AMO.DatabasePermission dbp in Analysisdb.DatabasePermissions)
          {
           Console.Write(dbp.Role.Name); //role name
           Console.Write(dbp.Read); // Is read role?
           Console.Write(dbp.Process); // Is process role?
           Console.Write(dbp.Administer); // Is Full control role?
          //loop through database permissions role members
          foreach (AMO.RoleMember rolemember in dbp.Role.Members)
              { 
              Console.Write(rolemember.Name); 
               }
          }

可以通过循环每个角色的每个维度来拉出每个维度的DAX表达式。下面的示例将获取codeplex AdventureWorks示例模型中Users角色的Currency维度的DAX表达式:

     using (AMO.DimensionPermission dimensionPermission = AnalysisDb.Dimensions.GetByName("Currency").DimensionPermissions[0]);
Console.Write(dimensionPermission.AllowedRowsExpression);

有关表格AMO的更多信息,请参阅http://tabularamo2012.codeplex.com/SourceControl/latest#AMO2TabularV2/AMO2Tabular.RlsFunctions.cs