Ниже приведён пример использования операции GetMbSec для получения информации о структуре атрибутного доступа. В запросе передаётся моникёр соединения с репозиторием. В ответе возвращается полученная информация.
{
"GetMbSec" :
{
"tMbSec" :
{
"id" : "PCGKENPODPGEGOAEBLFFGBMAHOGHMEGEBKOBBHAIGEIMEDDN!M"
},
"tArg" :
{
"pattern" :
{
"policy" :
{
"abacRules" :
{
"op" : "Get"
}
}
}
}
}
}
{
"GetMbSecResult" :
{
"id" :
{
"id" : "PCGKENPODPGEGOAEBLFFGBMAHOGHMEGEBKOBBHAIGEIMEDDN!M"
},
"meta" :
{
"policy" :
{
"abacRules" :
{
"alg" : "DenyOverride",
"policySets" :
{
"its" :
{
"Item" :
{
"n" : "Набор",
"id" : "PLCST1",
"description" : "",
"k" : "1",
"target" :
{
"n" : "OBJECT.CLASS",
"op" : "Equal",
"val" : "1295"
},
"active" : "1",
"alg" : "DenyOverride",
"policies" :
{
"its" :
{
"Item" :
[
{
"n" : "Чтение",
"id" : "PLC1",
"description" : "",
"k" : "2",
"target" :
{
"n" : "OPERATION",
"op" : "Equal",
"val" : "1048576"
},
"active" : "1",
"alg" : "PermitOverride",
"rules" :
{
"its" :
{
"Item" :
{
"n" : "Правило",
"id" : "RULE1",
"description" : "",
"k" : "3",
"target" :
{
"n" : "",
"op" : "Empty",
"val" : ""
},
"active" : "1",
"condition" : "ABAC.INTERSECC("NAME",SUBJECT.GROUPS,OBJECT.R_GROUPS) And ABAC.INTERSECC("NAME",SUBJECT.GROUPS,OBJECT.ORG_GROUPS)",
"effect" : "Permit"
}
}
}
},
{
"n" : "Запись",
"id" : "PLC10",
"description" : "",
"k" : "10",
"target" :
{
"n" : "OPERATION",
"op" : "Equal",
"val" : "2097152"
},
"active" : "1",
"alg" : "PermitOverride",
"rules" :
{
"its" :
{
"Item" :
{
"n" : "Правило",
"id" : "RULE11",
"description" : "",
"k" : "11",
"target" :
{
"n" : "",
"op" : "Empty",
"val" : ""
},
"active" : "1",
"condition" : "ABAC.INTERSECC("NAME",SUBJECT.GROUPS,OBJECT.W_GROUPS) And ABAC.INTERSECC("NAME",SUBJECT.GROUPS,OBJECT.ORG_GROUPS)",
"effect" : "Permit"
}
}
}
}
]
}
},
"policySets" :
{
"its" : ""
}
}
}
}
}
},
"bisearchEnable" : "Disable"
}
}
}
public static GetMbSecResult GetABACRules(string mb)
{
var somClient = new SomPortTypeClient(); // Прокси-объект для выполнения операций
// Параметры выполнения операции
var tGet = new GetMbSec()
{
tArg = new GetMbSecArg()
{
pattern = new MbSecMdPattern()
{
policy = new MbSecPolicyPattern()
{
abacRules = new MbSecAbacRulesPattern()
{
op = ListOperation.Get
}
}
}
},
tMbSec = new MbId() { id = mb }
};
// Получение атрибутов доступа у пользователя
var result = somClient.GetMbSec(tGet);
return result;
}
См. также: