Skip to content

Accelerynt-Security/AS-Sign-Out-Google-User

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 

Repository files navigation

AS-Sign-Out-Google-User

Author: Accelerynt

For any technical questions, please contact info@accelerynt.com

Deploy to Azure Deploy to Azure Gov

This playbook is intended to be run from a Microsoft Sentinel Incident. It will look up the Google Users associated with the Incident Account Entities and sign them out of all Google web and device sessions. This action also resets user sign-in cookies and forces them to reauthenticate. A comment noting the affected Google Users will be added to the Incident.

SignOutGoogleUser_Demo_1

Note Please note that this method may not work with all user types. In some cases, actions executed by service accounts could be restricted, particularly when attempting to operate on super admin accounts or accounts with higher privileges.

Requirements

The following items are required under the template settings during deployment:

Setup

Create a Google Service Account:

A Google Service Account with User Management Admin role and user.security scope is needed in order to perform the users.signOut action. A Google Cloud project is required to use Google Workspace requirements.txts and is where the Service Account will be housed. If you do not have an existing project, you can create one here: https://console.cloud.google.com/projectcreate

To create a Google Service Account, navigate to the Google Cloud console sign into an account that has administrator access, or have your administrator grant you the necessary roles to create Service Accounts, then navigate to the following page and select the appropriate project:

https://console.cloud.google.com/iam-admin/serviceaccounts/create

Enter a name for your Google Service Account, such as "Microsoft-Sentinel", then click "Done".

SignOutGoogleUser_Create_Google_Service_Account_1

Take note of the client ID and the email address that are generated for your Service Account upon creation, which can be found at https://console.cloud.google.com/iam-admin/serviceaccounts by selecting the project housing your Service Account.

Next you will need to add your newly created Service Account to the User Management Admin role. Navigate to https://admin.google.com/ac/roles and click "Assign Admin" for the "User Management Admin" role.

SignOutGoogleUser_Create_Google_Service_Account_2

Click "Assign Service Accounts".

SignOutGoogleUser_Create_Google_Service_Account_3

Enter the email generated for your Service Account and click "ASSIGN ROLE".

SignOutGoogleUser_Create_Google_Service_Account_4

Next, you will need to add the necessary scopes to the Service Account. Go to the admin console API controls: https://admin.google.com/ac/owl, and click "MANAGE DOMAIN WIDE DELEGATION".

SignOutGoogleUser_Create_Google_Service_Account_5

Click "Add new", then enter the client ID generated for your Service Account and paste "https://www.googleapis.com/auth/admin.directory.user.security" in the OAuth scopes field. Click "AUTHORIZE".

SignOutGoogleUser_Create_Google_Service_Account_6

Before this Service Account can successfully use the Google API, you will also need to enable admin SDK for your project. Navigate to https://console.cloud.google.com/apis/api/admin.googleapis.com/metrics and click "ENABLE".

SignOutGoogleUser_Create_Google_Service_Account_7

Create a Private Key:

Returning to your Google Service Account at https://console.cloud.google.com/iam-admin/serviceaccounts, select your Google Project and Service Account, then navigate to the "Keys" tab. Click "ADD KEY" and select the "Create new key" option.

SignOutGoogleUser_Create_a_Private_Key_1

Select the "JSON" option, then click "CREATE".

SignOutGoogleUser_Create_a_Private_Key_2

The JSON file containing your private key will download to your computer. Copy the JSON body in the file and save it for the next step.

Create an Azure Key Vault Secret:

Navigate to the Azure Key Vaults page: https://portal.azure.com/#view/HubsExtension/BrowseResource/resourceType/Microsoft.KeyVault%2Fvaults

Navigate to an existing Key Vault or create a new one. From the Key Vault overview page, click the "Secrets" menu option, found under the "Settings" section. Click "Generate/Import".

SignOutGoogleUser_Key_Vault_Create_Secret_1

Choose a name for the secret, such as "Google-App-Private-Key--Sign-Out-User", and enter the Google private key JSON copied from the previous step in the "Value" field. All other settings can be left as is. Click "Create".

SignOutGoogleUser_Key_Vault_Create_Secret_2

Once your secret has been added to the vault, navigate to the "Access policies" menu option on the Key Vault page menu. Leave this page open, as you will need to return to it once the playbook has been deployed. See Granting Access to Azure Key Vault.

SignOutGoogleUser_Key_Vault_Create_Secret_3

Configure Visual Studio Code:

This playbook utilizes an Azure Function to create a JSON Web Token (JWT), which is a required step in authenticating to Google as a Service Account. The Azure Function is included in this repository and will need to be deployed to your Azure tenant before it can be used. This Azure Function relies on the Python libraries "azure-functions", "PyJWT", and "cryptography". These libraries are not included in Python by default, which is why they must be installed in an IDE housing the CreateGoogleJWT project and then deployed to Azure.

Note Simply recreating the file structure from this repository in Azure will not actually install the libraries required for the Azure Function; the function must be deployed from an IDE, so that the dependent library packages are recreated and properly installed. Any IDE can be used for this, but this documentation will outline the process using Visual Studio Code (VS Code).

If you have not already, download and install VS Code from the official website: https://code.visualstudio.com/download

Once VS Code has been installed, open it, and navigate to the Extensions view by clicking on the Extensions icon on the left menu blade.

SignOutGoogleUser_Configure_VSCode_1

In the Extensions view, search for the following extensions and install them:

  • Azure Account: This extension provides a single Azure login and subscription filtering experience for all other Azure extensions. It makes Azure's Cloud Shell service available in VS Code's integrated terminal.
  • Azure Functions: This extension helps in creating, testing, and deploying Azure Functions directly from VS Code. This includes the creation of new Function Apps within your Azure account.

SignOutGoogleUser_Configure_VSCode_2

After the extensions have been installed, sign in to your Azure Account. Click on the Azure icon that now appears in the Activity Bar. Under the "Resources" section, click "Sign in to Azure...".

SignOutGoogleUser_Configure_VSCode_3

You will be prompted to sign in to your account via web browser. Follow the prompts and use your Azure credentials to log in.

SignOutGoogleUser_Configure_VSCode_4

Once you have successfully authenticated, your Azure email will be displayed in the bottom left corner of the VS Code window.

Next, you will need to create an Azure Function project using the code included in this Google repo. Create a folder on your computer for the Azure Function to be housed and label it "CreateGoogleJWT". Next, in VS Code, hover your mouse over the "Workspace" section in the Azure pane on the left. Click the "Create Function" icon. Select the "CreateGoogleJWT" folder you just created from the open dialogue window.

SignOutGoogleUser_Configure_VSCode_5

From the command palette in the top-center area of the window, select "Python" as the programming language, then select "Python 3.10.11" or later for your Python interpreter.

SignOutGoogleUser_Configure_VSCode_6

Select "HTTP trigger" for the project's function and enter "CreateGoogleJWT" for the function name.

SignOutGoogleUser_Configure_VSCode_7

Select "Function" for the Authorization level, then after selecting the window to open your project in and granting trust, you will be able to view the "CreateGoogleJWT" project in the explorer pane of the left side of the window. The "init.py" file should be opened by default.

SignOutGoogleUser_Configure_VSCode_8

Note If you decide to use a different name for the function, you will need to do a -Find + Replace All- for "CreateGoogleJWT" in the azuredeploy.json file before deployment.

Replace the contents of "init.py" in VS Code with the contents of "CreateGoogleJWT.js" located in the CreateGoogleJWT-Function folder of this repository.

SignOutGoogleUser_Configure_VSCode_9

Finally, the Python packages used in init.py need to be installed. Download and install the latest versions of Python and pip from the official website: https://www.python.org/downloads/

Next, in VS Code, click "Terminal" from the top menu and select "New Terminal".

SignOutGoogleUser_Configure_VSCode_10

In the terminal window, run the command "python.exe -m pip install --upgrade pip" to verify that the latest versions were properly installed.

Next, run the commands "pip3 install azure-functions", "pip3 install cryptography" and "pip3 install pyjwt". The packages will be automatically added to the dependencies in the "requirements.txt" file once they have been successfully installed.

SignOutGoogleUser_Configure_VSCode_11

Check the "requirements.txt" file to ensure all three dependencies have been added. You may have to add them manually, which is fine, as long as the install commands have already been run. Be sure to save the file if you are updating it manually.

SignOutGoogleUser_Configure_VSCode_12

After installing the required packages, the Azure Function can be deployed.

Deploy the Azure Function App:

In order to deploy an Azure Function, there must be an existing Azure Function App supporting the language used in the Azure function. If there is an existing Function App that supports Python in your Azure subscription, you can skip the first part of this step. Otherwise, you need to create a new Function App in your Azure subscription before deploying your Function.

Click on the Azure icon in the left side Activity Bar in VS Code. Select the resource you will deploy this playbook to, and then right click on "Azure Function" and select "Create Function App in Azure...".

SignOutGoogleUser_Deploy_Azure_Function_1

VS Code will guide you through the process. You will need to provide a globally unique name for your Function App, select a runtime stack, and choose an operating system. When asked for the runtime stack, select the latest available version for Python.

SignOutGoogleUser_Deploy_Azure_Function_2

The Azure Function can now be deployed to the Azure Function App from VS Code.

Click the Function App icon in the workspace section of the Azure extension, then select "Deploy to Function App...".

SignOutGoogleUser_Deploy_Azure_Function_3

Follow the prompts to choose your subscription and the Function App to which you want to deploy to. Take note of the name of the Function App, as it will be needed for deployment.

Once the deployment is complete, the Function can be accessed from your Azure tenant by the playbook. You can view your Function by navigating to https://portal.azure.com/#view/HubsExtension/BrowseResource/resourceType/Microsoft.Web%2Fsites/kind/functionapp and selecting the Function App your Function was deployed to.

SignOutGoogleUser_Deploy_Azure_Function_4

Deployment

To configure and deploy this playbook:

Open your browser and ensure you are logged into your Microsoft Sentinel workspace. In a separate tab, open the link to our playbook on the Accelerynt Security GitHub Repository:

https://github.com/Accelerynt-Security/AS-Sign-Out-Google-User

Deploy to Azure Deploy to Azure Gov

Click the "Deploy to Azure" button at the bottom and it will bring you to the custom deployment template.

In the Project Details section:

  • Select the "Subscription" and "Resource Group" from the dropdown boxes you would like the playbook deployed to.

In the Instance Details section:

Towards the bottom, click on "Review + create".

SignOutGoogleUser_Deploy_1

Once the resources have validated, click on "Create".

SignOutGoogleUser_Deploy_2

The resources should take around a minute to deploy. Once the deployment is complete, you can expand the "Deployment details" section to view them. Click the one corresponding to the Logic App.

SignOutGoogleUser_Deploy_3

Granting Access to Azure Key Vault

Before the Logic App can run successfully, the Key Vault connection created during deployment must be granted access to the Key Vault Secret storing your Google private key.

From the Key Vault "Access policies" page, click "Create".

SignOutGoogleUser_Key_Vault_Access_1

Select the "Get" checkbox in the "Secret permissions" section. Then click "Next".

SignOutGoogleUser_Key_Vault_Access_2

From the "Principal" page, paste "AS-Sign-Out-Google-User", or the alternative playbook name you used, into the search box and click the option that appears. Click "Next".

SignOutGoogleUser_Key_Vault_Access_3

Click "Next" in the application section. Then from the "Review + create" page, click "Create".

SignOutGoogleUser_Key_Vault_Access_4

Microsoft Sentinel Contributor Role

After deployment, you will need to give the system assigned managed identity the "Microsoft Sentinel Contributor" role. This will enable the Logic App to add comments to Incidents. Navigate to the Log Analytics Workspaces page and select the same workspace the playbook is located in:

https://portal.azure.com/#view/HubsExtension/BrowseResource/resourceType/Microsoft.OperationalInsights%2Fworkspaces

Select the "Access control (IAM)" option from the menu blade, then click "Add role assignment".

SignOutGoogleUser_Add_Contributor_Role_1

Select the "Microsoft Sentinel Contributor" role, then click "Next".

SignOutGoogleUser_Add_Contributor_Role_2

Select the "Managed identity" option, then click "Select Members". Under the subscription the Logic App is located, set the value of "Managed identity" to "Logic app". Next, enter "AS-Sign-Out-Google-User", or the alternative playbook name used during deployment, in the field labeled "Select". Select the playbook, then click "Select".

SignOutGoogleUser_Add_Contributor_Role_3

Continue on to the "Review + assign" tab and click "Review + assign".

SignOutGoogleUser_Add_Contributor_Role_4

Updating Python Packages for Azure Functions

As part of maintaining a robust and secure application, it's essential to regularly update the Python packages that your Azure Function relies on. There are several reasons for this:

  • Security Fixes: Developers frequently release updates to their packages to address discovered vulnerabilities. Keeping your packages up-to-date ensures you benefit from these fixes and reduces your application's risk exposure.

  • Bug Fixes and Improved Functionality: Updates often contain bug fixes or enhancements to functionality, stability, and performance. Regularly updating packages can provide your application with these benefits.

  • Compatibility: If you're updating your Python runtime or other packages, you need to keep all packages updated to ensure compatibility and prevent breaking changes.

As a general guideline, you should review and test for updates at least once per month. More frequent checks can be performed if your function has higher security requirements or is particularly sensitive to bugs in the underlying packages. Automated tools exist to help manage these updates.

You can update the dependent libraries for your Azure Function in VS Code by executing the commands "pip3 install --upgrade azure-functions", "pip3 install --upgrade cryptography" and "pip3 install --upgrade pyjwt" within your "CreateGoogleJWT" project directory in the integrated terminal. Redeploy the Function to Azure afterwards.

About

Sign out Google users from Microsoft Sentinel incidents

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages