Udostępnij za pośrednictwem


Oblicz akcję

Jak opisano wcześniej, podstawowe funkcje zestawu SDK zasad to:

  • lista dostępnych etykiet
  • zwraca zestaw akcji, które należy wykonać, na podstawie bieżącego i żądanego stanu

Ostatnim krokiem procesu jest podanie identyfikatora etykiety i opcjonalnie metadanych dotyczących istniejącej etykiety do ComputeActions() funkcji.

Przykładowy kod tego artykułu można znaleźć w witrynie GitHub.

Oblicz akcji dla nowej etykiety

mip::Actions Obliczenia dla nowej etykiety można osiągnąć przy użyciu zdefiniowanego w parametrzeExecutionStateImpl ExecutionState.

// Replace with valid label ID.
string newLabelId = "d7b93a40-4df3-47e4-b2fd-7862fc6b095c"; 
sample::policy::ExecutionStateOptions options;

// Resolve desired label id to mip::Label and set in ExecutionStateOptions.
options.newLabel = mEngine->GetLabelById(newLabelId);

// Initialize ExecutionStateImpl with options, create handler, call ComputeActions.
std::unique_ptr<ExecutionStateImpl> state(new ExecutionStateImpl(options));
auto handler = mEngine->CreatePolicyHandler(false); // Don't generate audit event.
auto actions = handler->ComputeActions(*state);

Pisanie tylko zwróconych mip::MetadataActions elementów w ramach wyświetlania actions :

Add: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Enabled : true
Add: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_SetDate : 2018-10-23T20:39:06-0800
Add: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Method : Standard
Add: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Name : Contoso FTEs (C)
Add: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_SiteId : 94f6984e-8d31-4794-bdeb-3ac89ad2b660
Add: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_ActionId : 2266fbe8-a0d9-44e8-bad8-00008f2a0915
Add: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_ContentBits : 3

Funkcja PolicyHandler oblicza akcje i zwraca wartość typu std::vectormip::Action. Deweloper aplikacji musi zastosować te metadane do pliku lub danych.

Uwaga / Notatka

Powyższy przykład wyświetla tylko dane wyjściowe mip::MetadataAction. Aby zapoznać się z przykładem wyświetlania dodatkowych typów akcji, przejrzyj przykładowe pakiety dostępne w Policy SDK download.

Akcje obliczeniowe z istniejącą etykietą

Podczas korzystania z pakietu SDK zasad, to aplikacja odpowiada za odczytywanie metadanych z treści. Te metadane są udostępniane interfejsowi API w ramach elementu mip::ExecutionState. ComputeActions() może obsługiwać bardziej złożone operacje niż stosowanie nowej etykiety do dokumentu bez etykiet. W poniższym przykładzie pokazano obniżenie poziomu etykiety z etykiety bardziej wrażliwej na mniej wrażliwą etykietę. Ten proces jest symulowany przez odczytywanie rozdzielanego przecinkami ciągu metadanych i dostarczanie do interfejsu API za pośrednictwem metody mip::ExecutionState.

Uwaga / Notatka

W przykładzie użyto funkcji narzędzia o nazwie SplitString(). Przykład można znaleźć tutaj

// Replace with valid label ID.
string newLabelId = "d7b93a40-4df3-47e4-b2fd-7862fc6b095c";

// Comma and Pipe Delimited Metadata.
string metadata = "MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Enabled|true,MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_SetDate|2018-10-23T21:53:31-0800,MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Method|Standard,MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Name|Contoso FTEs (C),MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_SiteId|94f6984e-8d31-4794-bdeb-3ac89ad2b660,MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_ActionId|b56491d9-155f-40ff-866f-0000acd85c31,MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_ContentBits|7";

// Create ExecutionStateOptions and resolve newLabelId to mip::Label
sample::policy::ExecutionStateOptions options;
options.newLabel = mEngine->GetLabelById(newLabelId);

// Split metadata string by commas, store in vector.
vector<string> metadataPairs = sample::utils::SplitString(metadata, ','); 

// Iterate through each string, splitting by the pipe.
// Add each key/value pair to ExecutionStateOptions metadata.
for (const string& metadataPair : metadataPairs) {
    vector<string> keyValue = sample::utils::SplitString(metadataPair, '|');
    options.metadata[keyValue[0]] = keyValue[1];
}

// Initialize ExecutionStateImpl with options, create handler, call ComputeActions
std::unique_ptr<ExecutionStateImpl> state(new ExecutionStateImpl(options));
auto handler = mEngine->CreatePolicyHandler(false); // Don't generate audit event.
auto actions = handler->ComputeActions(*state);

Powyższy przykład może spowodować kilka akcji. Te akcje zależą od etykiet dostarczonych jako danych wejściowych i konfiguracji etykiety. Co najmniej wynik będzie jednym mip::MetadataAction, który zawiera dane do usunięcia za pośrednictwem GetMetadataToRemove() i dane do dodania za pośrednictwem GetMetadataToAdd().

Add: MSIP_Label_d48d0e60-c766-40d6-96d3-53b2857fe775_Enabled : true
Add: MSIP_Label_d48d0e60-c766-40d6-96d3-53b2857fe775_SetDate : 2018-10-23T23:59:41-0800
Add: MSIP_Label_d48d0e60-c766-40d6-96d3-53b2857fe775_Method : Standard
Add: MSIP_Label_d48d0e60-c766-40d6-96d3-53b2857fe775_Name : General
Add: MSIP_Label_d48d0e60-c766-40d6-96d3-53b2857fe775_SiteId : 94f6984e-8d31-4794-bdeb-3ac89ad2b660
Add: MSIP_Label_d48d0e60-c766-40d6-96d3-53b2857fe775_ActionId : 447a996b-28ea-482c-b0b5-000075bd4bb3
Add: MSIP_Label_d48d0e60-c766-40d6-96d3-53b2857fe775_ContentBits : 7
Remove: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Name
Remove: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Enabled
Remove: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_SiteId
Remove: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_SetDate
Remove: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_Method
Remove: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_ContentBits
Remove: MSIP_Label_d7b93a40-4df3-47e4-b2fd-7862fc6b095c_ActionId

Dalsze kroki