File SDK - Elaborare file con estensione msg di posta elettronica (C#)
File SDK supporta le operazioni di etichettatura per i file con estensione msg in modo identico a qualsiasi altro tipo di file, ad eccezione del fatto che l'SDK necessita dell'applicazione per abilitare il flag di funzionalità MSG. In questa sezione verrà illustrato come impostare questo flag.
Come illustrato in precedenza, la creazione di istanze di IFileEngine
richiede un oggetto impostazione, FileEngineSettings
. FileEngine Impostazioni può essere usato per passare i parametri per le impostazioni personalizzate che l'applicazione deve impostare per una determinata istanza. CustomSettings
la proprietà di FileEngineSettings
viene utilizzata per impostare il flag per enable_msg_file_type
per abilitare l'elaborazione dei file con estensione msg.
Prerequisiti
Se non è già stato fatto, assicurarsi di completare i prerequisiti seguenti prima di continuare:
- Completare la guida introduttiva: Inizializzazione dell'applicazione File SDK (C#), che crea prima una soluzione visual Studio iniziale. Questa guida introduttiva "How to - process email message .msg files (C#)" si basa su quella precedente.
- Esaminare i concetti relativi a MIP SDK per i file di posta elettronica.
- Facoltativamente: esaminare i motori di file nei concetti di MIP SDK .
- Facoltativamente: esaminare i gestori di file nei concetti di MIP SDK .
Impostare enable_msg_file_type e usare File SDK per l'etichettatura del file con estensione msg
Nella continuazione della guida introduttiva all'inizializzazione dell'applicazione API file modificare il codice di costruzione del motore di file per impostare enable_msg_file_type flag
e quindi usare il motore di file per etichettare un file con estensione msg.
Aprire la soluzione di Visual Studio creata nella precedente "Guida introduttiva: Inizializzazione dell'applicazione File SDK (C#)".
Usando Esplora soluzioni, aprire il file con estensione cs nel progetto che contiene l'implementazione del
Main()
metodo . Per impostazione predefinita, il nome del progetto che lo contiene è stato specificato durante la creazione del progetto.Rimuovere l'implementazione della
Main()
funzione dalla guida introduttiva precedente. All'interno delMain()
corpo inserire il codice seguente. Nel flag di bloccoenable_msg_file_type
di codice seguente viene impostato durante la creazione del motore di file, un file con estensione msg può quindi essere elaborato daIFileHandler
oggetti creati usando il motore di file.static void Main(string[] args) { // Initialize Wrapper for File SDK operations. MIP.Initialize(MipComponent.File); // Create ApplicationInfo, setting the clientID from Azure AD App Registration as the ApplicationId. ApplicationInfo appInfo = new ApplicationInfo() { ApplicationId = clientId, ApplicationName = appName, ApplicationVersion = "1.0.0" }; // Instantiate the AuthDelegateImpl object, passing in AppInfo. AuthDelegateImplementation authDelegate = new AuthDelegateImplementation(appInfo); MipContext mipContext = MIP.CreateMipContext(appInfo,"mip_data",LogLevel.Trace,null,null); // Initialize and instantiate the File Profile. // Create the FileProfileSettings object. // Initialize file profile settings to create/use local state. var profileSettings = new FileProfileSettings(mipContext, CacheStorageType.OnDiskEncrypted, new ConsentDelegateImplementation()); // Load the Profile async and wait for the result. var fileProfile = Task.Run(async () => await MIP.LoadFileProfileAsync(profileSettings)).Result; // Create a FileEngineSettings object, then use that to add an engine to the profile. var customSettings = new List<KeyValuePair<string, string>>(); customSettings.Add(new KeyValuePair<string, string>("enable_msg_file_type", "true")); // Create a FileEngineSettings object, then use that to add an engine to the profile. var engineSettings = new FileEngineSettings("user1@tenant.com", authDelegate, "", "en-US"); engineSettings.Identity = new Identity("user1@tenant.com"); //set custom settings for the engine engineSettings.CustomSettings = customSettings; //Add fileEngine to profile var fileEngine = Task.Run(async () => await fileProfile.AddEngineAsync(engineSettings)).Result; //Set file paths string inputFilePath = "<input-file-path>"; //.msg file to be labeled string actualFilePath = inputFilePath; string outputFilePath = "<output-file-path>"; //labeled .msg file string actualOutputFilePath = outputFilePath; //Create a file handler for original file var fileHandler = Task.Run(async () => await fileEngine.CreateFileHandlerAsync(inputFilePath, actualFilePath, true)).Result; // List labels available to the user and use one of them to label the MSG file. foreach (var label in fileEngine.SensitivityLabels) { Console.WriteLine(string.Format("{0} - {1}", label.Name, label.Id)); if (label.Children.Count > 0) { foreach (Label child in label.Children) { Console.WriteLine(string.Format("\t{0} - {1}", child.Name, child.Id)); } } } string labelId = "<label-id>"; //label retrieved using file engine LabelingOptions labelingOptions = new LabelingOptions() { AssignmentMethod = options.AssignmentMethod }; fileHandler.SetLabel(labelId, labelingOptions, new ProtectionSettings()); // Commit changes, save as outputFilePath var result = Task.Run(async () => await fileHandler.CommitAsync(outputFilePath)).Result; // Create a new handler to read the labeled file metadata var handlerModified = Task.Run(async () => await fileEngine.CreateFileHandlerAsync(outputFilePath, actualOutputFilePath, true)).Result; Console.WriteLine(string.Format("Original file: {0}", inputFilePath)); Console.WriteLine(string.Format("Labeled file: {0}", outputFilePath)); Console.WriteLine(string.Format("Label applied to file: {0}", handlerModified.Label.Name)); Console.WriteLine("Press a key to continue."); Console.ReadKey(); // Application Shutdown fileHandler = null; handlerModified = null; fileEngine = null; fileProfile = null; mipContext = null; }
Per altri dettagli sulle operazioni sui file, vedere i concetti relativi al gestore file.
Sostituire i valori segnaposto nel codice sorgente usando i valori seguenti:
Segnaposto Valore <input-file-path> Percorso completo di un file di messaggio di input di test, ad esempio: c:\\Test\\message.msg
.<output-file-path> Percorso completo del file di output, che sarà una copia etichettata del file di input, ad esempio : c:\\Test\\message_labeled.msg
.<label-id> LabelId recuperato tramite il motore di file, ad esempio : 667466bf-a01b-4b0a-8bbf-a79a3d96f720
.
Compilare e testare l'applicazione
Usare F6 (Compila soluzione) per compilare l'applicazione client. Se non sono presenti errori di compilazione, usare F5 (Avvia debug) per eseguire l'applicazione.
Original file: C:\Test.msg
Labeled file: C:\Test_Labeled.msg
Label applied to file: Confidential
Press a key to continue.