La API de Vault te permite administrar las exportaciones de Vault. Puedes hacer lo siguiente:
Crear exportaciones: Envía una solicitud a Vault que encuentre los mensajes o archivos que que coinciden con tu consulta y los exporta a Google Cloud.
Nota: No puedes tener más de 20 exportaciones en curso en toda tu organización. Para mejorar el rendimiento, divide las exportaciones grandes en conjuntos más pequeños. Por ejemplo, divide tu exportación por mes en lugar de exportar todo de una sola vez. Otro ejemplo es incluir menos entidades (por ejemplo, usuarios y entidades especiales, como grupos, espacios de chat, etc.) en cada exportación.
Ejemplos:
Enumerar exportaciones: Recupere el estado de todas las exportaciones asociadas. con un asunto.
Obtener exportaciones: Recupera información sobre una exportación.
Descarga las exportaciones: Descarga una exportación de Google Cloud.
Borrar exportaciones: Quita las exportaciones de un asunto cuando ya no son necesarios.
Antes de comenzar
Para configurar las bibliotecas y la autenticación necesarias, consulta la guía de inicio rápido para tu lenguaje de programación.
Para trabajar con los recursos de Vault, la cuenta debe tener el Vault requerido. y el acceso a las lo que importa. Para acceder a un asunto, la cuenta debe haber creado el asunto, tener la asunto que se haya compartido con ellos, o que tengas el privilegio de Ver todos los asuntos.
Crear una exportación de Gmail
En el siguiente ejemplo, se muestra cómo crear una exportación de Gmail. Esta solicitud exporta todos los mensajes de Gmail y la versión clásica de Hangouts que cumplan con los siguientes criterios:
- mensajes propiedad de las cuentas
email1
yemail2
. - excluye los borradores de mensajes.
- mensajes enviados a
ceo@solarmora.com
.
Nota: Estos ejemplos usan el sistema de exportación clásico de Gmail. Para exportar con el
nuevo sistema de exportación,
en MailExportOptions,
establece useNewExport
como verdadero.
Java
public Export createMailAccountHeldDataExports(Vault client, String matterId) {
AccountInfo emailsToSearch = new AccountInfo().setEmails(ImmutableList.of("email1", "email2"));
MailOptions mailQueryOptions = new MailOptions().setExportFormat("PST");
String queryTerms = "to:ceo@solarmora.com";
Query mailQuery =
new Query()
.setCorpus("MAIL")
.setDataScope("HELD_DATA")
.setSearchMethod("ACCOUNT")
.setAccountInfo(emailsToSearch)
.setTerms(queryTerms)
.setMailOptions(mailQueryOptions);
MailExportOptions mailExportOptions =
new MailExportOptions()
.setExportFormat("MBOX")
.showConfidentialModeContent(true);
Export wantedExport =
new Export()
.setMatterId(matterId)
.setName("My first mail accounts export")
.setQuery(mailQuery)
.setExportOptions(new ExportOptions().setMailOptions(mailExportOptions));
return client.matters().exports().create(matter, wantedExport).execute();
}
Python
def create_mail_account_held_data_export(service, matter_id):
emails_to_search = ['email1', 'email2']
mail_query_options = {'excludeDrafts': True}
query_terms = 'to:ceo@solarmora.com'
mail_query = {
'corpus': 'MAIL',
'dataScope': 'HELD_DATA',
'searchMethod': 'ACCOUNT',
'accountInfo': {
'emails': emails_to_search
},
'terms': query_terms,
'mailOptions': mail_query_options,
}
mail_export_options = {
'exportFormat': 'MBOX',
'showConfidentialModeContent': True
}
wanted_export = {
'name': 'My first mail accounts export',
'query': mail_query,
'exportOptions': {
'mailOptions': mail_export_options
}
}
return service.matters().exports().create(
matterId=matter_id, body=wanted_export).execute()
Crea una exportación de Drive
En el siguiente ejemplo, se muestra cómo crear una exportación de Drive. Esta solicitud exporta todos los archivos, incluidos los que se encuentran en unidades compartidas, que cumplan con los siguientes criterios:
- Pertenezca a la unidad organizativa especificada (obtenida con el SDK de Admin).
se crearon entre los valores especificados veces
Java
public Export createDriveOuAllDataExport(Vault client, String matterId) {
OrgUnitInfo ouToSearch = new OrgUnitInfo().setOrgUnitId("ou id retrieved from admin sdk");
DriveOptions driveQueryOptions = new DriveOptions().setIncludeSharedDrives(true);
Query driveQuery =
new Query()
.setCorpus("DRIVE")
.setDataScope("ALL_DATA")
.setSearchMethod("ORG_UNIT")
.setOrgUnitInfo(ouToSearch)
.setDriveOptions(driveQueryOptions)
.setStartTime("2017-03-16T00:00:00Z")
.setEndTime("2017-03-16T00:00:00Z")
.setTimeZone("Etc/GMT+2");
DriveExportOptions driveExportOptions = new DriveExportOptions().setIncludeAccessInfo(false);
Export wantedExport =
new Export()
.setName("My first drive ou export")
.setQuery(driveQuery)
.setExportOptions(new ExportOptions().setDriveOptions(driveExportOptions));
return client.matters().exports().create(matter, wantedExport).execute();
}
Python
def create_drive_ou_all_data_export(service, matter_id):
ou_to_search = 'ou id retrieved from admin sdk'
drive_query_options = {'includeSharedDrives': True}
drive_query = {
'corpus': 'DRIVE',
'dataScope': 'ALL_DATA',
'searchMethod': 'ORG_UNIT',
'orgUnitInfo': {
'org_unit_id': ou_to_search
},
'driveOptions': drive_query_options,
'startTime': '2017-03-16T00:00:00Z',
'endTime': '2017-09-23T00:00:00Z',
'timeZone': 'Etc/GMT+2'
}
drive_export_options = {'includeAccessInfo': False}
wanted_export = {
'name': 'My first drive ou export',
'query': drive_query,
'exportOptions': {
'driveOptions': drive_export_options
}
}
return service.matters().exports().create(
matterId=matter_id, body=wanted_export).execute()
Crea una exportación de Meet
En el siguiente ejemplo, se muestra cómo crear una exportación de Meet. Esta solicitud exporta archivos asociados con cuentas de la unidad organizativa especificada que tengan una nombre de archivo que siga el patrón de las grabaciones de Meet.
Python
def create_meet_export(service, matter_id, ou_to_search, export_name):
export = {
'name': export_name,
'query': {
'corpus': 'DRIVE',
'dataScope': 'ALL_DATA',
'searchMethod': 'ORG_UNIT',
'terms': 'title:"...-...-... \\(....-..-.. at ..:.. *\\)"',
'orgUnitInfo': {
'orgUnitId': 'id:'+ou_to_search
},
'driveOptions': {
'includeTeamDrives': True,
'includeSharedDrives': True
},
'timeZone': 'Etc/GMT',
'method': 'ORG_UNIT'
},
'exportOptions': {
'driveOptions': {},
'region': 'ANY'
},
}
return service.matters().exports().create(
matterId=matter_id, body=export).execute()
Cómo exportar a partir de una consulta guardada
En el siguiente ejemplo, se muestra cómo crear una exportación a partir de una consulta guardada.
Python
def create_mail_export_from_saved_query(service, matter_id, saved_query_id, export_name):
export = {
'name': export_name,
'exportOptions': {
'mailOptions': {
'exportFormat': 'PST',
'showConfidentialModeContent': True
},
'region': 'ANY'
}
}
export['query'] = service.matters().savedQueries().get(
savedQueryId=saved_query_id, matterId=matter_id).execute()['query']
return service.matters().exports().create(
matterId=matter_id, body=export).execute()
Mostrar lista de exportaciones
En el siguiente ejemplo, se muestra cómo recuperar una lista de exportaciones asociadas con un asunto.
Java
public class exports {
public ListExportsResponse listExports(Vault client, String matterId) {
return client.matters().exports().list(matterId).execute();
}
Python
def list_exports(service, matter_id):
return service.matters().exports().list(matterId=matter_id).execute()
Obtén información sobre una exportación
En el siguiente ejemplo, se muestra cómo obtener información sobre una exportación específica. Nota: Para descargar archivos y mensajes exportados, debes usar las APIs de Cloud (en la próxima ejemplo).
Java
public Export getExportById(Vault client, String matterId, String exportId) {
return client.matters().exports().get(matterId, exportId).execute();
}
Python
def get_export_by_id(service, matter_id, export_id):
return service.matters().exports().get(
matterId=matter_id, exportId=export_id).execute()
Descarga una exportación de Google Cloud
En el siguiente ejemplo, se muestra cómo descargar todas las exportaciones completadas de un asunto de Google Cloud. Esta solicitud usa las APIs de Cloud y Vault.
Nota: Para descargar una exportación, la cuenta necesita la siguiente información: Administra el privilegio de Exports y el asunto que se compartió con ellos.
Python
def download_exports(service, matter_id):
"""Google Cloud storage service is authenticated by running
`gcloud auth application-default login` and expects a billing enabled project
in ENV variable `GOOGLE_CLOUD_PROJECT` """
gcpClient = storage.Client()
matter_id = os.environ['MATTERID']
for export in vaultService.matters().exports().list(
matterId=matter_id).execute()['exports']:
if 'cloudStorageSink' in export:
directory = export['name']
if not os.path.exists(directory):
os.makedirs(directory)
print(export['id'])
for sinkFile in export['cloudStorageSink']['files']:
filename = '%s/%s' % (directory, sinkFile['objectName'].split('/')[-1])
objectURI = 'gs://%s/%s' % (sinkFile['bucketName'],
sinkFile['objectName'])
print('get %s to %s' % (objectURI, filename))
gcpClient.download_blob_to_file(objectURI, open(filename, 'wb+'))
Cómo borrar una exportación
En el siguiente ejemplo, se muestra cómo borrar una exportación.
Java
public void deleteExportById(Vault client, String matterId, String exportId) {
client.matters().exports().delete(matterId, exportId).execute();
Python
def delete_export_by_id(service, matter_id, export_id):
return service.matters().exports().delete(
matterId=matter_id, exportId=export_id).execute()
Para obtener información específica de la app sobre la búsqueda y la exportación, incluidos los límites de búsqueda, consulta Cómo comenzar a usar la búsqueda y la exportación de Vault.