From 88f5a18145aa91dc94ef89bfe5fd4607badfb6bd Mon Sep 17 00:00:00 2001 From: shaniacht1 Date: Wed, 1 Nov 2017 20:30:26 +0200 Subject: [PATCH] Create integration-AzureAD --- Integrations/integration-AzureAD | 157 +++++++++++++++++++++++++++++++ 1 file changed, 157 insertions(+) create mode 100644 Integrations/integration-AzureAD diff --git a/Integrations/integration-AzureAD b/Integrations/integration-AzureAD new file mode 100644 index 000000000000..aaccd58f40b5 --- /dev/null +++ b/Integrations/integration-AzureAD @@ -0,0 +1,157 @@ +commonfields: + id: Azure Active Directory + version: -1 +name: Azure Active Directory +display: Azure Active Directory +category: Data Enrichment +image:  +description: Azure Active Directory (Azure AD) is Microsoft's multi-tenant, cloud + based directory and identity management service +detaileddescription: |+ + 1. Go to https://apps.dev.microsoft.com/ and create register an application. + 1.1 Copy the application ID + 1.2 Generate an Application Secret and copy it + 1.3 Choose a redirect URL and copy it + 1.4 Set up the following delegated permissions: IdentityRiskEvent.Read.All and User.Read.All + 1.5 Set up the following application permissions: IdentityRiskEvent.Read.All + 2. Complete the following URL with the values from the previous section and follow it: https://login.microsoftonline.com/{Directory Tenant or ‘Common’}/adminconsent?client_id={Application ID}&redirect_uri={Redirect URL} + 3. Click 'Accept' + 4. Fill in the parameters for the integration instance: + 4.1 Login URL: https://login.microsoftonline.com + 4.2 Tenant Domain: The directory tenant that you want to request permission from. This can be in GUID or friendly name format. + 4.3 Application ID: The Application ID (from section 1) + 4.4 Application Secret: the application secret (from section 1) + +configuration: +- display: Fetch incidents + name: isFetch + defaultvalue: "" + type: 8 + required: false +- display: Incident type + name: incidentType + defaultvalue: "" + type: 13 + required: false +- display: Login URL (e.g. https://login.microsoftonline.com) + name: login_url + defaultvalue: https://login.microsoftonline.com + type: 0 + required: true +- display: Tenant Domain + name: domain + defaultvalue: "" + type: 0 + required: true +- display: Application ID + name: client_id + defaultvalue: "" + type: 0 + required: false +- display: Application Secret + name: secret + defaultvalue: "" + type: 4 + required: false +script: + script: | + var sendRequest = function(url, method, headers, body) { + var res = http( + url, + { + Method: method, + Headers: { + 'Content-Type': ['application/x-www-form-urlencoded'], + 'Authorization' : token? [token_type + ' ' + token] : undefined + }, //TODO add headers + Body : body? encodeToURLQuery(body).substr(1) : undefined + }, + params.insecure, + params.proxy + ); + if (res.StatusCode < 200 || res.StatusCode >= 300) { + throw 'Request Failed.\nStatus code: ' + res.StatusCode + '.\nBody: ' + JSON.stringify(res) + '.'; + } + return res.Body; + }; + + var client_id = params.client_id; + var client_secret = params.secret; + var login_url = params.login_url.replace(/[\/]+$/, ''); + var tenant_domain = params.domain.replace(/[\/]+$/, ''); + + var token; + var token_type; + + var getToken = function(){ + request_url = login_url + '/'+tenant_domain + '/oauth2/v2.0/token'; + bodyvals = { + 'client_id': client_id, + 'client_secret': client_secret, + 'grant_type': 'client_credentials', + 'scope': 'https://graph.microsoft.com/.default' + }; + res = sendRequest(request_url, 'POST', {}, bodyvals); + try { + result = JSON.parse(res); + } catch (err) { + throw 'Request Failed. \n'+ res; + } + token = result['access_token']; + token_type = result['token_type']; + if(!token || !token_type){ + throw 'Request failed: missing token\n'+ res; + } + }; + + var fetchLoginEvents = function() { + var lastRun = getLastRun(); + var date = new Date(); + var now = {value : date.toISOString()}; + if (!lastRun || !lastRun.value) { + date.setDate(date.getDate() - 1); + lastRun = {value: date.toISOString()}; + } + request_string = 'https://graph.microsoft.com/beta/identityRiskEvents?filter=createdDateTime%20gt%20'+lastRun.value; + res = sendRequest(request_string, 'GET'); + events = JSON.parse(res).value; + + incidents = []; + events.forEach(function(event){ + incidents.push({name: 'Risky Signin', rawJSON: JSON.stringify(event).replace(/\\"/g, '"')}); + }); + setLastRun(now); + return JSON.stringify(incidents); + }; + + var getRiskEvent = function(id){ + request_string = 'https://graph.microsoft.com/beta/identityRiskEvents/'+id; + res = JSON.parse(sendRequest(request_string, 'GET')); + return { + Type: entryTypes.note, + HumanReadable: tableToMarkdown('Azure AD Risk Event', res), + HumanReadableFormat: formats.markdown, + Contents: res, + ContentsFormat: formats.json + }; + }; + + getToken(); + switch (command) { + case 'test-module': + return 'ok'; + case 'fetch-incidents': + return fetchLoginEvents(); + case 'azure-get-risk-event': + return getRiskEvent(args.id); + } + type: javascript + commands: + - name: azure-get-risk-event + arguments: + - name: id + required: true + default: true + description: Event id + description: Retrieve the properties and relationships of an identity risk event + isfetch: true