Egnyte Secure and Govern Public API (1.0.0)

Download OpenAPI specification:Download

Egnyte Secure and Govern Public API exposes issues for the purpose of listing, polling for new issues and watching for changes in issue pool.

Definitions:

Environment
One of the two egnyteprotect.com subdomains to use with the API: usc1-api.egnyteprotect.com or euw1-api.egnyteprotect.com
Tenant
A company/organization account in Egnyte Secure and Govern.
Issue
A violation of data protection policies listed in Secure and Govern

Authentication

CodeGrantAuth

Code Grant from OAuth2 is used for obtaining tokens to the API for applications using the Public API to provide functionality for Secure and Govern users.

Request a client_id from https://developers.egnyte.com - register and select "Issue a new key for Egnyte Secure and Govern" to get it.

Example calls

# get code - open in the browser
https://usc1-api.egnyteprotect.com/oauth2/code?client_id=CLIENT_ID&redirect_uri=https://your-app.com/oauthredirect&response_type=code&scope=issues:read

# exchange code for token - POST request
curl -v -d 'client_id=CLIENT_ID&client_secret=SECRET&grant_type=authorization_code&redirect_uri=https://your-app.com/oauthredirect&code=CODE' https://usc1-api.egnyteprotect.com/oauth2/token

# refresh token - POST request
curl -v -d 'client_id=CLIENT_ID&client_secret=SECRET&grant_type=refresh_token&redirect_uri=https://your-app.com/oauthredirect&refresh_token=REF_TOKEN' https://usc1-api.egnyteprotect.com/oauth2/token
            
            
Security Scheme Type: OAuth2
Flow type: authorizationCode
Token URL: https://<env>.egnyteprotect.com/oauth2/token
Refresh URL: https://<env>.egnyteprotect.com/oauth2/token
Scopes:
  • issues:read -

    Read issues and react to issue status changes

  • classification:write -

    Register content classification sources

  • sar:read -

    Check SAR status and list files from SAR matches

  • sar:write -

    Create SAR and delete files from SAR matches

  • sc:read -

    Read classification results

  • sc:matches -

    Read the actual sensitive content text in classified files

  • legalhold:read -

    Read Legal holds details and retained files

  • legalhold:write -

    Create and update Legal holds

  • auditevents:read -

    Read audit events

Subject Access Request

Create a Subject Access Request

Creates a SAR. IDs in "identifiers" come from the endpoint for listing identifiers

Authorizations:
CodeGrantAuth
Request Body schema: application/json
required
object
requestType
required
string
Enum: "NOTIFICATION" "RIGHT_TO_BE_FORGOTTEN"
serviceTime
number

Responses

Request samples

Content type
application/json
{ }

Response samples

Content type
application/json
{
  • "id": "c9ac0519-284a-4bee-9574-30ae7891e5dc"
}

List all Subject Access Requests

List the details of all Subject Access Requsts created in the tenant.

Authorizations:
CodeGrantAuth
query Parameters
cursor
string

cursor value from the previous response body - for continuity. Each response is returning a cursor - a string pointing to the place on the list of Subject Access Requests for tenant, and each request passes the last known cursor value to get next SARs page. null in the response means that pagination is over

Responses

Response samples

Content type
application/json
No sample

Get SAR

Returns SAR details, including status and stage of processing the SAR.

Authorizations:
CodeGrantAuth
path Parameters
sarId
required
string <uuid>

Id of the SAR

Responses

Response samples

Content type
application/json
Example
{
  • "id": "096e400e-56db-4128-bdea-05ebcea9ab7e",
  • "subject": {
    },
  • "requestType": "NOTIFICATION",
  • "stage": "COLLECTING_DATA",
  • "daysLeft": 29,
  • "created": 1576580243855,
  • "serviceTime": 30,
  • "servicedDays": 0,
  • "serviceDate": 1576580243855,
  • "processed": false,
  • "completed": false,
  • "actions": {}
}

List paths from fulfilled SAR

Returns paths to files from SAR matches

Authorizations:
CodeGrantAuth
path Parameters
sarId
required
string <uuid>

Id of the SAR

query Parameters
count
integer [ 1 .. 100 ]
Default: 100

Number of items to return at most

cursor
string

cursor value from the previous response body - for continuity. Each response is returning a cursor - a string pointing to the place on the list of files from SAR matches, and each request passes the last known cursor value to get items which occurred after that. null in the response means that pagination is over

Responses

Response samples

Content type
application/json
{
  • "files": [
    ],
  • "cursor": "string"
}

Delete SAR files

Authorizations:
CodeGrantAuth
path Parameters
sarId
required
string <uuid>

Id of the SAR

Responses

Response samples

Content type
application/json
{
  • "code": "string",
  • "message": "string",
  • "details": "string"
}

Submit download request

Request SAR files to be prepared for downloading. Status of the download preparation can be checked by using action's url from the response.

Authorizations:
CodeGrantAuth
path Parameters
sarId
required
string <uuid>

Id of the SAR

query Parameters
flat
boolean

If it is true, a folder structure of the source won't be preserved for files in the returned zip file. Only files will be returned, without information about its location on the source. The default is false.

Responses

Response samples

Content type
application/json
No sample

Check a download preparation status

Check if the download with provided downloadId is ready and SAR files can be served. If it is, use actions from the downloads list to download ZIP archives with files content.

Authorizations:
CodeGrantAuth
path Parameters
sarId
required
string <uuid>

Id of the SAR

downloadId
required
string <uuid>

Id of the download

Responses

Response samples

Content type
application/json
No sample

Get a content of a SAR file

Get a binary content of a file returned as ZIP archive

Authorizations:
CodeGrantAuth
path Parameters
sarId
required
string <uuid>

Id of the SAR

downloadId
required
string <uuid>

Id of the download

archiveId
required
string

Id of an archiveId

Responses

Response samples

Content type
application/json
{
  • "code": "string",
  • "message": "string",
  • "details": "string"
}

Classification Source

Register a source for classification

Creates a classification source in Secure and Govern sourceId in response can be used to unregister, it also shows up as sourceId in results of Content Classification and Issues

Authorizations:
CodeGrantAuth
Request Body schema: application/json
transport
required
string
Value: "https"

Transport choice. https is the default, more will be added.

discoveryURL
required
string

URL of the Classification FS discovery endpoint for the particular source.

sourceDisplayName
required
string

Visible name of the registered source.

location
string

Visible name of the location of the source, can be left empty or used as a hint to the user as to where to look for the source (a network address or a specific section of the source system).

troubleshootingURL
required
string

A URL to display to the user if the classification source stops responding. Can be a direct link to configuration of the source or a link to a troubleshooting guide.

authHeader
string

The content for authorization header of requests made to Classification FS.

emailContact
string

E-mail address to contact when source is down for.

sourceType
string

Display name of source.

iconUrl
string

Source icon url.

Responses

Request samples

Content type
application/json
{
  • "transport": "https",
  • "discoveryURL": "string",
  • "sourceDisplayName": "string",
  • "location": "string",
  • "troubleshootingURL": "string",
  • "authHeader": "string",
  • "emailContact": "string",
  • "sourceType": "string",
  • "iconUrl": "string"
}

Response samples

Content type
application/json
{
  • "sourceId": "string"
}

Unregister classification source

Unregister a classification source from Secure and Govern

Authorizations:
CodeGrantAuth
path Parameters
sourceId
required
string

Responses

Response samples

Content type
application/json
{
  • "code": "string",
  • "message": "string",
  • "details": "string"
}

Request a test run on a classification source

Runs a simulation of a Classification Source scan pass on the given source URL and invokes report endpoint with issues it finds.
Does not return a success/failure result - it's intended as a tool for helping the developer during work and manual acceptance testing, not as a CI/CD tool.

Authorizations:
CodeGrantAuth
Request Body schema: application/json
transport
required
string
Value: "https"

Transport choice. https is the default, more will be added.

discoveryURL
required
string

URL of the Classification FS discovery endpoint for the particular source

authHeader
string

The content for authorization header of requests made to Classification FS

Responses

Request samples

Content type
application/json
{
  • "transport": "https",
  • "discoveryURL": "string",
  • "authHeader": "string"
}

Response samples

Content type
application/json
{
  • "code": "string",
  • "message": "string",
  • "details": "string"
}

Sensitive Content

Get policies

Returns policies from current tenant's setup.
Content listing will only refer to policies by tags. Details and display names can be resolved from this endpoint.
Policies don't change often so it's reasonable to cache the response to this.

Authorizations:
CodeGrantAuth

Responses

Response samples

Content type
application/json
No sample

Get sources

Lists all sources installed for the tenant. IDs are useful for exploring sensitive content in selected ones.

Authorizations:
CodeGrantAuth

Responses

Response samples

Content type
application/json
No sample

Locations

List locations with Sensitive Content found. Returns a list of paths to locations containing files identified as sensitive.

Authorizations:
CodeGrantAuth
path Parameters
sourceId
required
string

ID of the source

query Parameters
cursor
string

The cursor returned in previous request

count
number [ 1 .. 100 ]

The number of items to return in one response

Responses

Response samples

Content type
application/json
No sample

Get location

Get location details along with the list of IDs of sensitive files found.

Authorizations:
CodeGrantAuth
path Parameters
sourceId
required
string

ID of the source

locationId
required
string <uuid>

ID of the location to read

Responses

Response samples

Content type
application/json
No sample

List location

List files in a location.

Authorizations:
CodeGrantAuth
path Parameters
sourceId
required
string

ID of the source

locationId
required
string <uuid>

ID of the location to list

query Parameters
cursor
string

The cursor returned in previous request

count
number [ 1 .. 100 ]

The number of items to return in one response

Responses

Response samples

Content type
application/json
No sample

Get file

Get sensitive file details.

Authorizations:
CodeGrantAuth
path Parameters
sourceId
required
string

ID of the source

fileId
required
string <uuid>

ID of the file to read

query Parameters
classificationStatus
boolean

Option to get status of classification

Responses

Response samples

Content type
application/json
No sample

Get matches

Get sensitive file details including the list of matched content occurrences. > Note a specific scope is required for this endpoint access

Authorizations:
CodeGrantAuth
path Parameters
sourceId
required
string

ID of the source

fileId
required
string <uuid>

ID of the file to read

query Parameters
includeTextContext
number [ 10 .. 250 ]

Number of characters before and after the match to include in the context. Context is only returned if this parameter is set. Otherwise context field is missing from response.

Responses

Response samples

Content type
application/json
No sample

Get classification status

Get status of file's classification

Authorizations:
CodeGrantAuth
path Parameters
sourceId
required
string

ID of the source

query Parameters
versionId
required
string <uuid>

ID of the version of the file to read

Responses

Response samples

Content type
application/json
No sample

Issues

Get list of issues

Returns Secure and Govern issues, starting from oldest, uses a cursor to iterate without duplicates.

Issue
A violation of data protection policies listed in Secure and Govern
Cursor
A value pointing to a location in the list of issues. Cursor refers to the last item you already received. The API will return items newer than the cursor.

Authorizations:
CodeGrantAuth
query Parameters
count
integer [ 1 .. 100 ]
Default: 100

Number of items to return at most

cursor
integer <int64> >= 0

Most recent known id, return items with IDs after this one.

format
string
Default: "short"
Enum: "short" "full"

Either short or full to include less or more issue details.

Responses

Response samples

Content type
application/json
{
  • "cursor": 46,
  • "issues": [
    ]
}

Get cursor

Get latest cursor or a cursor for provided timestamp. Returns cursor (issue id) for timestamp specified as startTime param. When querying issue listing for the cursor provided, you'll receive all issues created on the timestamp or later.
If the timestamp is older than the oldest issue, the API returns a cursor pointing to a value before all issues
If the timestamp is newer than the newest issue or not provided at all, a cursor is returned that, when used, will only return future issues. (useful for polling for new issues)

Authorizations:
CodeGrantAuth
query Parameters
startTime
integer >= 1500000000000

Timestamp in miliseconds for which to get the cursor

Responses

Response samples

Content type
application/json
{
  • "cursor": 2343
}

Get list of issues updates

Returns Issues in their current state, but ordered by their modification time. Polling this endpoint starting at the current timestamp will result in getting a list of issues as they're being updated or added. Polling with no timestamp to start with will list all issues in their current state and continue returning issues as they're being added or changed over time. Responses from this endpoint may contain more elements than the declared count if the last item in the returned set was not the last with the same timestamp value.

Authorizations:
CodeGrantAuth
query Parameters
count
integer [ 1 .. 100 ]
Default: 100

Approximate number of items to return. API doesn't not guarantee the exact match.

modifiedAfter
integer <int64> >= 0

Most recent known timestamp, return items which were updated after that timestamp.

format
string
Default: "short"
Enum: "short" "full"

Either short or full to include less or more issue details.

Responses

Response samples

Content type
application/json
{
  • "modifiedAfter": 0,
  • "issues": [
    ]
}

Get issue details

Returns detailed information about selected issue. It allows to track its status over time.

Authorizations:
CodeGrantAuth
path Parameters
id
required
integer <int64> >= 0

ID of the issue to return

Responses

Response samples

Content type
application/json
{
  • "id": 0,
  • "sourceId": "string",
  • "status": "string",
  • "type": "string",
  • "source": "string",
  • "sourceLabel": "string",
  • "sourceType": "string",
  • "severity": 1,
  • "updated": 0,
  • "detected": 0,
  • "item": {
    },
  • "policies": [
    ],
  • "webViewLink": "string",
  • "assignee": {
    },
  • "violationDetails": {
    }
}

Issue Remediation

Resolve or Dismiss open issues

Authorizations:
CodeGrantAuth
path Parameters
id
required
integer <int64> >= 0

ID of the issue to update

Request Body schema: application/json
issueStatus
required
string
Enum: "RESOLVED" "IGNORED"

RESOLVED - To Resolve issue,
IGNORE - To Dismiss issue

fixingMethod
string
Enum: "MARK_AS_RESOLVED" "DISABLE_USER_ACCOUNT" "RESET_PASSWORD"

Optional parameter to specify fixing method. "MARK_AS_RESOLVED" and "DISABLE_USER_ACCOUNT" are valid for Probable Ransomware, Unusual Access & Suspicious Login whereas "RESET_PASSWORD" is valid for Suspicious Login issue type only

Responses

Request samples

Content type
application/json
{
  • "issueStatus": "IGNORED",
  • "fixingMethod": "MARK_AS_RESOLVED"
}

Response samples

Content type
application/json
""

Legal Hold

Create Legal Hold

A Legal Hold retains content related to a legal matter, securing all files defined in the hold scope that were created, accessed or deleted within a specified date range. These files will be retained until the Legal Hold is closed or cancelled.
Criteria for hold scope are defined in this request, but can be modified and extended later

Authorizations:
CodeGrantAuth
Request Body schema: application/json
name
required
string non-empty

Human-readable name of the Legal Hold.

description
string

Description of the particular Legal Hold.

legalMatter
required
string non-empty

Legal matter concerning this particular Legal Hold.

startDate
integer <int64> >= 0

Unix timestamp.

endDate
integer <int64> >= 0

Unix timestamp.

holdScopeOperator
required
string
Enum: "or" "and"

Logical operator defining if ANY or ALL hold scope's criteria should apply to the file for it to be retained.

required
object

Hold scope's criteria.

Responses

Request samples

Content type
application/json
{
  • "name": "Copyright Infringement Claim",
  • "description": "Claims of Copyright Infringement by Competitor",
  • "legalMatter": "Copyright Infringement",
  • "startDate": 1566370800000,
  • "endDate": 1575435600000,
  • "holdScopeOperator": "or",
  • "holdScope": {
    },
  • "targetDomain": ""
}

Response samples

Content type
application/json
{
  • "legalHoldId": "df497868-9f1b-4ef2-963c-436d9156a91e"
}

Get list of Legal Holds

Returns Legal Holds. The list can be filtered by status.

Authorizations:
CodeGrantAuth
query Parameters
status
string
Enum: "open" "closed"

Legal Holds status used for filtering. If not provided, all Legal Holds will be returned.

Responses

Response samples

Content type
application/json
[
  • {
    },
  • {
    }
]

Get Legal Hold details

Returns details of the Legal Hold. This includes the fields defined when creating it and also current status.

Authorizations:
CodeGrantAuth
path Parameters
legalHoldId
required
string <uuid>

ID of the Legal Hold

Responses

Response samples

Content type
application/json
{
  • "name": "Copyright Infringement Claim",
  • "description": "Claims of Copyright Infringement by Competitor",
  • "legalMatter": "Copyright Infringement",
  • "startDate": 1566370800000,
  • "endDate": 1575435600000,
  • "holdScopeOperator": "or",
  • "holdScope": {
    },
  • "status": "open",
  • "createdBy": "Bob Green",
  • "createdDate": 1576535600000,
  • "lastModified": 1576535600000,
  • "userFacingId": "LH00001",
  • "targetDomain": ""
}

Update Legal Hold settings

Only settings that were provided in the request will be updated. The rest won't be changed. Regarding hold scope's criteria this endpoint will overwrite only those that were passed.
It means that if there are only 'folders' defined in the request under 'holdScope', the list of custodians won't be updated.
To clear the list of folders or custodians in the hold scope, empty array '[]' should be passed.

Authorizations:
CodeGrantAuth
path Parameters
legalHoldId
required
string <uuid>

ID of the Legal Hold

Request Body schema: application/json
name
string non-empty

Human-readable name of the Legal Hold.

description
string

Description of the particular Legal Hold.

legalMatter
string non-empty

Legal matter concerning this particular Legal Hold.

startDate
integer <int64> >= 0

Unix timestamp.

endDate
integer <int64> >= 0

Unix timestamp.

holdScopeOperator
string
Enum: "or" "and"

Logical operator defining if ANY or ALL hold scope's criteria should apply to the file for it to be retained.

object

Hold scope's criteria.

Responses

Request samples

Content type
application/json
{
  • "name": "Copyright Infringement Claim",
  • "description": "Claims of Copyright Infringement by Competitor",
  • "legalMatter": "Copyright Infringement",
  • "startDate": 1566370800000,
  • "endDate": 1575435600000,
  • "holdScopeOperator": "or",
  • "holdScope": {
    },
  • "targetDomain": ""
}

Response samples

Content type
application/json
""

Delete Legal Hold

Deletes Legal Hold definition from the system. This action is not recoverable and nothing is retained. The corect way to end working with a Legal Hold is to close it - see the /close endpoint.

Authorizations:
CodeGrantAuth
path Parameters
legalHoldId
required
string <uuid>

ID of the Legal Hold

Responses

Response samples

Content type
application/json
""

Close Legal Hold

Files retained for this Legal Hold will no longer be preserved.
Closing Legal Hold doesn't remove it entirely from the system. It's still possible to check some of the Legal Hold details.

Authorizations:
CodeGrantAuth
path Parameters
legalHoldId
required
string <uuid>

ID of the Legal Hold

Responses

Response samples

Content type
application/json
""

Modify hold scope

Hold scope's criteria, folders and custodians, can be modified by adding or deleting items which expand or shrink the hold scope.

Authorizations:
CodeGrantAuth
path Parameters
legalHoldId
required
string <uuid>

ID of the Legal Hold

Request Body schema: application/json
object

Definition of items to be added to the hold scope. If the content of the particular folder ids list shouldn't be changed, empty array should be passed.

object

Definition of items to be deleted from the hold scope. If the content of the particular folder ids list shouldn't be changed, empty array should be passed.

Responses

Request samples

Content type
application/json
{
  • "add": {
    },
  • "delete": {
    }
}

Response samples

Content type
application/json
""

Get retained files

Returns retained files matching Legal Hold settings. Resulting items are paginated using a cursor. Pagination may return pages with less items than expected based on permissions to view them. As long as a cursor is not null, there's more data to fetch

Authorizations:
CodeGrantAuth
path Parameters
legalHoldId
required
string <uuid>

ID of the Legal Hold

query Parameters
cursor
string

The cursor returned in the previous request.

count
integer [ 1 .. 100 ]
Default: 100

Number of items to return in one response.

Responses

Response samples

Content type
application/json
{
  • "cursor": null,
  • "files": [
    ]
}

Audit Events

Get User Actions audit events

Returns User Actions audit events, starting from oldest, uses a cursor to iterate without duplicates.

Authorizations:
CodeGrantAuth
query Parameters
count
integer [ 1 .. 1000 ]
Default: 100

Number of items to return at most

cursor
string

Iteration pointer for a following (not the initial) request. A cursor is returned in response to the initial request and then every following request generates a new cursor to be used in the next request.

startDate
string <date-time>

Start of date range for audit events to retrieve (if "cursor" and "startDate" is provided, "cursor" has highest priority). ISO 8601 format: "YYYY-MM-DD'T'HH:MM:SSZ"

Responses

Response samples

Content type
application/json
No sample

Get Content Lifecycle audit events

Returns Content Lifecycle audit events, starting from oldest, uses a cursor to iterate without duplicates.

Authorizations:
CodeGrantAuth
query Parameters
count
integer [ 1 .. 1000 ]
Default: 100

Number of items to return at most

cursor
string

Iteration pointer for a following (not the initial) request. A cursor is returned in response to the initial request and then every following request generates a new cursor to be used in the next request.

startDate
string <date-time>

Start of date range for audit events to retrieve (if "cursor" and "startDate" is provided, "cursor" has highest priority). ISO 8601 format: "YYYY-MM-DD'T'HH:MM:SSZ"

Responses

Response samples

Content type
application/json
No sample

Dev Tools

Get basic information about the user

Returns information about the user making request: data from Secure and Govern plus clientId of application used.

Authorizations:
CodeGrantAuth

Responses

Response samples

Content type
application/json
{
  • "clientId": "hweb8adyh3gumiypa45qdgkm",
  • "user": "d870600d-dd67-448f-b482-7c4618862008",
  • "tenant": "fc7e9d03-b838-40b3-ae6b-80f761f418d7",
  • "scopes": [
    ]
}

Request a test run on a classification source

Runs a simulation of a Classification Source scan pass on the given source URL and invokes report endpoint with issues it finds.
Does not return a success/failure result - it's intended as a tool for helping the developer during work and manual acceptance testing, not as a CI/CD tool.

Authorizations:
CodeGrantAuth
Request Body schema: application/json
transport
required
string
Value: "https"

Transport choice. https is the default, more will be added.

discoveryURL
required
string

URL of the Classification FS discovery endpoint for the particular source

authHeader
string

The content for authorization header of requests made to Classification FS

Responses

Request samples

Content type
application/json
{
  • "transport": "https",
  • "discoveryURL": "string",
  • "authHeader": "string"
}

Response samples

Content type
application/json
{
  • "code": "string",
  • "message": "string",
  • "details": "string"
}