-
Notifications
You must be signed in to change notification settings - Fork 1.7k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
fdc6ecd
commit 88f5a18
Showing
1 changed file
with
157 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -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 |