AccessToken(Result: IAccessToken);
AccessToken(Result: Prognoz.Platform.Interop.Metabase.IAccessToken);
Result. переменная, в которую будет помещен результат.
Свойство AccessToken возвращает метку доступа обновления объектов репозитория.
Актуально при использовании мандатного метода контроля доступа. Условия для использования свойства:
свойство IMetabaseUpdateObjectNode.UpdatePart установлено в значение ReplaceSecurityDescriptor;
свойство IMetabaseUpdateObjectNode.AccessTokenOptions установлено в значение Manual.
Обновление будет происходить по старому механизму (будут копироваться из исходного объекта IMetabaseObjectDescriptor->SecurityDescriptor->AccessToken) если хоть одно из условий не выполняется.
Для выполнения примера предполагается наличие в репозитории объектов с идентификаторами «OBJ1» и «OBJ2». Для выполнения примера добавьте ссылки на системные сборки «Metabase».
Sub UserProc;
Var
Mb: IMetabase;
Obj: IMetabaseObjectDescriptor;
Upd: IMetabaseUpdate;
Nd: IMetabaseUpdateObjectNode;
RootFolder: IMetabaseUpdateFolderNode;
ObjDesc: IMetabaseObjectDescriptor;
SecDesc: ISecurityDescriptor;
Tok: IAccessToken;
Begin
Mb := MetabaseClass.Active;
ObjDesc:=MB.ItemById("OBJ1");
SecDesc:=ObjDesc.SecurityDescriptor;
Tok:=SecDesc.AccessToken;
Upd := Mb.CreateUpdate;
RootFolder := Upd.RootFolder;
Nd := RootFolder.Add(MetabaseUpdateNodeType.Object) As IMetabaseUpdateObjectNode;
Upd.AllowReplaceSD := True;
Nd.UpdatePart := MetabaseObjectUpdatePart.ReplaceSecurityDescriptor;
Nd.AccessTokenOptions := MetabaseUpdateAccessTokenOptions.Manual;
Obj := Mb.ItemById("OBJ2").Bind;
Nd.Object := Obj;
Nd.AccessToken.Assign(Tok);
Upd.SaveToFileNF("С:\Update.pefx");
Upd := Mb.CreateUpdate;
Upd.LoadFromFileNF("С:\Update.pefx");
Upd.Apply;
End Sub UserProc;
В процессе выполнения примера происходит установка созданного обновления. После выполнения примера метка доступа объекта «OBJ2» заменится на метку доступа объекта «OBJ1».
Для выполнения примера предполагается наличие в репозитории объектов с идентификаторами «OBJ1» и «OBJ2». Для выполнения примера добавьте ссылки на системные сборки «Metabase».
Sub Main(Params: StartParams);
Var
Mb: IMetabase;
Obj: IMetabaseObjectDescriptor;
Upd: IMetabaseUpdate;
Nd: IMetabaseUpdateObjectNode;
RootFolder: IMetabaseUpdateFolderNode;
ObjDesc: IMetabaseObjectDescriptor;
SecDesc: ISecurityDescriptor;
Tok: IAccessToken;
Begin
Mb := Params.Metabase;
ObjDesc:=MB.ItemById["OBJ1"];
SecDesc:=ObjDesc.SecurityDescriptor;
Tok:=SecDesc.AccessToken;
Upd := Mb.CreateUpdate();
RootFolder := Upd.RootFolder;
Nd := RootFolder.Add(MetabaseUpdateNodeType.untObject) As IMetabaseUpdateObjectNode;
Upd.AllowReplaceSD := True;
Nd.UpdatePart := MetabaseObjectUpdatePart.moupReplaceSecurityDescriptor;
Nd.AccessTokenOptions := MetabaseUpdateAccessTokenOptions.muatoManual;
Obj := Mb.ItemById["OBJ2"].Bind();
Nd.Object := Obj;
Nd.AccessToken.Assign(Tok);
Upd.SaveToFileNF("D:\"+ "Update.pefx");
Upd := Mb.CreateUpdate();
Upd.LoadFromFileNF("D:\"+ "Update.pefx",UpdateLoadMode.ulmReplace);
Upd.Apply(Null);
End Sub;
В процессе выполнения примера происходит установка созданного обновления. После выполнения примера метка доступа объекта «OBJ2» заменится на метку доступа объекта «OBJ1».
См. также: