Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Imperva skyfence integration #86

Merged
merged 9 commits into from Nov 14, 2016
188 changes: 188 additions & 0 deletions Integrations/integration-Imperva_Skyfence.yml
@@ -0,0 +1,188 @@
commonfields:
id: Imperva Skyfence
version: -1
name: Imperva Skyfence
display: Imperva Skyfence
category: End point
image: 
description: The Imperva Skyfence Cloud Gateway is a Cloud Access Security Broker
(CASB) that provides visibility and control over sanctioned and unsanctioned cloud
apps to enable their safe and productive use.
detaileddescription: |-
All API requests must be authenticated. The authentication model is OAuth 2.0.
Client applications must initially perform a token request to receive an authentication token,
and subsequently use the obtained token in all following requests.
The token request must itself be authenticated by a customer ID and password, here called Client ID and Client Secret. You need to manually obtain these credentials in the Skyfence web interface, at Settings > API.
Note: After the Client Secret has been displayed once, it no longer appears in the Skyfence web interface.
configuration:
- display: Server URL (192.168.56.101)
name: url
defaultvalue: ""
type: 0
required: true
- display: Client ID
name: clientId
defaultvalue: ""
type: 4
required: true
- display: Client Secret
name: clientSecret
defaultvalue: ""
type: 4
required: true
- display: Insecure (over HTTP)
name: insecure
defaultvalue: "true"
type: 8
required: false
script:
script: |-
if (typeof params.insecure === 'string' || !params.insecure) {
params.insecure = params.insecure === 'true' ? true : false;
}

var fixUrl = function(url) {
fixedUrl = '';
if (url.indexOf("http") !== 0) {
if (params.insecure) {
fixedUrl = 'http://' + url;
} else {
fixedUrl = 'https://' + url;
}
}

return fixedUrl;
};

var parseResponse = function(resp) {
var res = null;
if (resp.StatusCode >= 200 && resp.StatusCode < 300) {
try {
res = JSON.parse(resp.Body);
} catch (e) {
res = resp.Body;
}
} else {
err = resp.Status;
if (resp.Body) {
err += '\n' + resp.Body;
}
throw err;
}


if (res && res.length && res.length > 1 ) {
// response body is array, then put it into object
// we don't want to return array
return { result: res };
} else if (res && res.length === 0) {
return {};
} else {
return res;
}
};

var url = fixUrl(params.url);

var login = function(params) {
var fullUrl = fixUrl(params.url) + '/cm/api/v1.0/oauth2/token';
var body = {
grant_type: 'client_credentials',
client_id: params.clientId,
client_secret: params.clientSecret
};

var res = httpMultipart(
fullUrl,
'',
{
Method: 'POST'
},
body,
params.insecure
);

return parseResponse(res);
};

var listEndpoints = function(url, token) {
var fullUrl = fixUrl(url) + '/cm/api/v1.0/endpoint';
var res = http(
fullUrl,
{
Method: 'GET',
Headers: {'Authorization': ['Bearer ' + token]}
},
params.insecure
);

return parseResponse(res);
};

var setEndpointStatus = function(url, token, endpointId, action) {
// validate action
// action can be "enroll" or "revoke"
if (action !== 'enroll' && action !== 'revoke') {
throw 'action must be "enroll" or "revoke"!';
}

var fullUrl = fixUrl(url) + '/cm/api/v1.0/endpoint/' + endpointId;
var res = http(
fullUrl,
{
Method: 'POST',
Headers: {
'Authorization': ['Bearer ' + token],
'Content-Type': ['application/json']
},
Body: JSON.stringify({
action: action
})
},
params.insecure
);

parseResponse(res);
return 'Success';
};

switch(command) {
case 'test-module':
login(params);
return true;
case 'imp-sf-list-endpoints':
var loginRes = login(params);
return listEndpoints(params.url, loginRes.access_token);
case 'imp-sf-set-endpoint-status':
var loginRes = login(params);
return setEndpointStatus(params.url, loginRes.access_token, args.endpointId, args.action);
default:
return true;
}
type: javascript
commands:
- name: imp-sf-list-endpoints
arguments: []
description: The endpoints list request enables a client application to receive
a list of all managed and unmanaged endpoints, with their basic details. This
list can then be externally filtered or searched by the application to identify
individual endpoints that might require action. For any such endpoint, the application
can obtain fuller details (see Endpoint Details Request below) and if relevant
change its enrollment status (see Set Endpoint Status Request on page 11).
- name: imp-sf-set-endpoint-status
arguments:
- name: endpointId
required: true
default: true
description: 'The id of the endpoint. '
- name: action
required: true
description: '"enroll" / "revoke"'
description: ' The endpoint status request enables a client application to enroll
an endpoint or revoke its enrollment. This is usually relevant for endpoints
with pending status but can be done for endpoints with any current status. The
endpoint needs to be specified by its ID, which can have been received from
an endpoints list request (see Endpoints List Request on page 10), from a new
endpoint notification (see New Endpoint Notifications on page 6), or from any
other implemented manual or automated input.'
execution: true