on 06-25-2024 10:00 AM - edited Friday
This page explains how to set up your Microsoft Azure (including Microsoft Cloud resources), Amazon Web Services (AWS) and Google Cloud Platform (GCP) environments for Lansweeper's Cloud Discovery.
Before scanning your cloud provider, you’ll first need to set up your infrastructure to allow Cloud Discovery to access your environment. Depending on your cloud provider, these steps may differ, but setting up authentication to your cloud environment is crucial.
On this page, we'll go over the steps needed to set up your Microsoft Azure, Microsoft Intune, or Microsoft 365, Amazon Web Services (AWS), and Google Cloud Platform (GCP) environments.
Integrating Microsoft Azure, Microsoft Intune, or Microsoft 365 with Auth0 for Workload Identity Federation involves several steps, ensuring a secure and seamless authentication process without traditional credentials. This setup allows our scanning application to authenticate with Azure services using tokens from Auth0, leveraging federated identities.
You’ll first need to register a new application in the Azure portal. You can find detailed instructions in Quickstart: Register an app in the Microsoft identity platform.
After registering the app, copy the Application (client) ID and the Directory (tenant) ID and save them for later.
Next, you’ll need to grant the correct permissions to the newly created app registration. You can find detailed instructions on adding permissions in Quickstart: Configure an app to access a web API.
From the list of permissions, add the following permissions based on the data you want to retrieve. Ensure you grant admin consent for each permission added.
For Microsoft Azure, make sure that the App Registration itself has Reader access to the subscriptions you want to scan.
Data | Permission Type | Permission name |
---|---|---|
Microsoft 365/Entra ID (Organization and Users) |
Application | Organization.Read.All Directory.Read.All |
Microsoft Intune | Application | DeviceManagementManagedDevices.Read.All |
Federated credentials are what enable workload identity federation for software workloads. You can find detailed information about Federated credentials in Create a trust relationship between an app and an external identity provider.
To configure Federated credentials for Lansweeper Discovery:
https://dev-734bjlip.eu.auth0.com/
.D9vGk9gXUNtrwWdifIe0BWC865gu8oHd@clients
.https://cloud-scanning-api
(no trailing space or “/” character).To allow your app registration to read resources under a specific subscription, you must assign the necessary role to your new application. Repeat this process for every subscription you wish to scan. You can find detailed instructions on assigning roles in Assign Azure roles using the Azure portal.
The Reader role should be an appropriate role for Lansweeper Discovery.
The final step in setting up Azure for Lansweeper Discovery is creating an Azure key vault. You can find detailed instructions on creating a key vault in Quickstart - Create an Azure Key Vault with the Azure portal.
After creating a default key vault, you need to configure the permissions:
After configuring the Azure key vault, copy the Vault URI and save it for later.
You can now create a Cloud Discovery action to schedule your cloud asset scanning.
Integrating AWS with Auth0 for Workload Identity Federation involves several steps, ensuring a secure and seamless authentication process without traditional credentials. This setup allows our scanning application to authenticate with AWS services using tokens from Auth0, leveraging federated identities.
You’ll first need to create an OpenID Connect (OIDC) provider. You can find detailed instructions in Create an OpenID Connect (OIDC) identity provider in IAM.
To configure the OIDC provider for Lansweeper Discovery:
https://dev-734bjlip.eu.auth0.com/
.D9vGk9gXUNtrwWdifIe0BWC865gu8oHd
.In order to scan multiple AWS accounts, you'll need to configure different account types.
We can define two account types:
You’ll first need to create and configure a custom policy. You can find detailed instructions on IAM policies in Creating IAM policies.
This policy will allow your Lansweeper Site to list the AWS accounts, as well as assume the Target roles to read the resources in the AWS accounts.
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"organizations:ListAccounts",
"organizations:ListAccountsForParent",
"sts:GetCallerIdentity",
"iam:GetRole",
"organizations:DescribeOrganization",
"sts:TagSession",
"sts:AssumeRole"
],
"Resource": "*",
"Condition": {
"StringEquals": {
"aws:PrincipalTag/siteId": ["<your site ID>"]
}
}
}
]
}
"StringEquals": {
"aws:PrincipalTag/siteId": ["site ID #1", "site ID #2"]
}
Next, you'll need to create a role and trust entity. You can find detailed instructions in Creating a role using custom trust policies (console).
This role will allow your Lansweeper Site to assume the permissions listed in the above policy, through the Auth0 authentication mechanism.
To configure this role for Lansweeper Discovery:
https://dev-734bjlip.eu.auth0.com/
.D9vGk9gXUNtrwWdifIe0BWC865gu8oHd
.You should end up with the following JSON:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Federated": "arn:aws:iam::<account number>:oidc-provider/dev-734bjlip.eu.auth0.com/"
},
"Action": [
"sts:AssumeRoleWithWebIdentity",
"sts:TagSession"
],
"Condition": {
"StringEquals": {
"dev-734bjlip.eu.auth0.com/:aud": "D9vGk9gXUNtrwWdifIe0BWC865gu8oHd"
}
}
}
]
}
After updating the role, copy the Role ARN and save it for later.
You’ll need to create and configure a custom Reading policy. You can find detailed instructions on IAM policies in Creating IAM policies.
This policy needs to be created in all accounts whose resources will be listed by your Lansweeper Site.
In the Policy editor, add the following JSON:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"<see full list of permissions at the end>"
],
"Resource": "*"
}
]
}
Finally, you'll need to create another role and trust entity. You can find detailed instructions in Creating a role using custom trust policies (console).
This role will allow your Lansweeper Site to read your cloud resources, and needs to be created in each account you want to scan.
arn:aws:sts::<main account number>:assumed-role/LSMainAccountRole/web-identity
.main account number
should be replaced with the ID of the AWS account you created the Main role for.LSMainAccountRole
should be replaced with the name of the Main role, e.g. LSMainAccountRole.sts:TagSession
.The role trust relationship should look like:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"AWS": [
"arn:aws:sts::<main account number>:assumed-role/LSMainAccountRole/web-identity"
]
},
"Action": [
"sts:AsssumeRole",
"sts:TagSession"
]
}
]
}
You can now create a Cloud Discovery action to schedule your cloud asset scanning.
To create an AWS discovery action, you will need:
arn:aws:iam::<main account number>:role/LSMainAccountRole
.LSReadingRole
.See below for the full list of actions performed by our scanning application.
"organizations:ListAccounts",
"organizations:ListAccountsForParent",
"organizations:DescribeOrganization",
"sts:GetCallerIdentity",
"iam:GetRole",
"resource-groups:Get*",
"resource-groups:List*",
"resource-groups:Search*",
"ssm:Describe*",
"ssm:Get*",
"ssm:List*",
"codepipeline:Get*",
"codepipeline:List*",
"elasticbeanstalk:Describe*",
"elasticbeanstalk:List*",
"appfabric:Get*",
"appfabric:List*",
"dms:Describe*",
"dms:List*",
"ds:Describe*",
"ds:Get*",
"ds:List*",
"route53-recovery-readiness:Get*",
"route53-recovery-readiness:List*",
"iam:Get*",
"iam:List*",
"autoscaling:Describe*",
"autoscaling:Get*",
"securityhub:Describe*",
"securityhub:Get*",
"securityhub:List*",
"network-firewall:Describe*",
"network-firewall:List*",
"sqs:Get*",
"sqs:List*",
"launchwizard:Describe*",
"launchwizard:Get*",
"launchwizard:List*",
"compute-optimizer:Describe*",
"compute-optimizer:Get*",
"dlm:Get*",
"savingsplans:Describe*",
"savingsplans:List*",
"sagemaker-groundtruth-synthetic:Get*",
"sagemaker-groundtruth-synthetic:List*",
"emr-serverless:Get*",
"emr-serverless:List*",
"route53domains:Get*",
"route53domains:List*",
"ses:Describe*",
"ses:Get*",
"ses:List*",
"codeartifact:Describe*",
"codeartifact:Get*",
"codeartifact:List*",
"networkmanager:Describe*",
"networkmanager:Get*",
"networkmanager:List*",
"athena:Get*",
"athena:List*",
"iot:Describe*",
"iot:Get*",
"iot:List*",
"appsync:Get*",
"appsync:List*",
"ce:Describe*",
"ce:Get*",
"ce:List*",
"cloudtrail:Describe*",
"cloudtrail:Get*",
"cloudtrail:List*",
"kinesis:Describe*",
"kinesis:Get*",
"kinesis:List*",
"iotwireless:Get*",
"iotwireless:List*",
"sdb:Get*",
"sdb:List*",
"application-autoscaling:Describe*",
"application-autoscaling:List*",
"glacier:Describe*",
"glacier:Get*",
"glacier:List*",
"lambda:Get*",
"lambda:List*",
"s3:Describe*",
"s3:Get*",
"s3:List*",
"trustedadvisor:Describe*",
"apprunner:Describe*",
"apprunner:List*",
"iotevents:Describe*",
"iotevents:List*",
"sagemaker:Describe*",
"sagemaker:Get*",
"sagemaker:List*",
"sagemaker:Search*",
"clouddirectory:Get*",
"clouddirectory:List*",
"iotroborunner:Get*",
"iotroborunner:List*",
"account:Get*",
"account:List*",
"rds:Describe*",
"rds:List*",
"serverlessrepo:Get*",
"serverlessrepo:List*",
"serverlessrepo:Search*",
"lakeformation:Describe*",
"lakeformation:Get*",
"lakeformation:List*",
"lakeformation:Search*",
"appstream:Describe*",
"appstream:List*",
"glue:Get*",
"glue:List*",
"glue:Search*",
"elastic-inference:Describe*",
"elastic-inference:List*",
"logs:Describe*",
"logs:Get*",
"logs:List*",
"iotanalytics:Describe*",
"iotanalytics:Get*",
"iotanalytics:List*",
"ecr:Describe*",
"ecr:Get*",
"ecr:List*",
"kafka:Describe*",
"kafka:Get*",
"kafka:List*",
"scheduler:Get*",
"scheduler:List*",
"codedeploy:Get*",
"codedeploy:List*",
"servicediscovery:Get*",
"servicediscovery:List*",
"kms:Describe*",
"kms:Get*",
"kms:List*",
"ecr-public:Describe*",
"ecr-public:Get*",
"ecr-public:List*",
"workspaces-web:Get*",
"workspaces-web:List*",
"elasticfilesystem:Describe*",
"elasticfilesystem:List*",
"route53-recovery-control-config:Describe*",
"route53-recovery-control-config:Get*",
"route53-recovery-control-config:List*",
"batch:Describe*",
"batch:List*",
"events:Describe*",
"events:List*",
"waf-regional:Get*",
"waf-regional:List*",
"workspaces:Describe*",
"redshift:Describe*",
"redshift:Get*",
"organizations:Describe*",
"organizations:List*",
"emr-containers:Describe*",
"emr-containers:List*",
"kafkaconnect:Describe*",
"kafkaconnect:List*",
"datapipeline:Describe*",
"datapipeline:Get*",
"datapipeline:List*",
"dynamodb:Describe*",
"dynamodb:Get*",
"dynamodb:List*",
"sts:Get*",
"lightsail:Get*",
"s3-object-lambda:Get*",
"s3-object-lambda:List*",
"cloudfront-keyvaluestore:Describe*",
"cloudfront-keyvaluestore:Get*",
"cloudfront-keyvaluestore:List*",
"firehose:Describe*",
"firehose:List*",
"codebuild:Describe*",
"codebuild:List*",
"notifications:Get*",
"notifications:List*",
"cloudfront:Describe*",
"cloudfront:Get*",
"cloudfront:List*",
"cloudformation:Describe*",
"cloudformation:Get*",
"cloudformation:List*",
"autoscaling-plans:Describe*",
"autoscaling-plans:Get*",
"backup:Describe*",
"backup:Get*",
"backup:List*",
"kinesisvideo:Describe*",
"kinesisvideo:Get*",
"kinesisvideo:List*",
"eks:Describe*",
"eks:List*",
"pipes:Describe*",
"pipes:List*",
"ec2messages:Get*",
"mq:Describe*",
"mq:List*",
"identitystore-auth:List*",
"tag:Describe*",
"tag:Get*",
"config:Describe*",
"config:Get*",
"config:List*",
"es:Describe*",
"es:Get*",
"lookoutvision:List*",
"sns:Get*",
"sns:List*",
"cloudsearch:Describe*",
"cloudsearch:List*",
"secretsmanager:Describe*",
"secretsmanager:Get*",
"secretsmanager:List*",
"notifications-contacts:Get*",
"notifications-contacts:List*",
"elasticloadbalancing:Describe*",
"cloudwatch:Describe*",
"cloudwatch:Get*",
"cloudwatch:List*",
"elasticmapreduce:Describe*",
"elasticmapreduce:Get*",
"elasticmapreduce:List*",
"waf:Get*",
"waf:List*",
"elasticache:Describe*",
"elasticache:List*",
"route53-recovery-cluster:Get*",
"route53-recovery-cluster:List*",
"swf:Describe*",
"swf:Get*",
"swf:List*",
"ec2:Describe*",
"ec2:Get*",
"ec2:List*",
"ec2:Search*",
"transfer:Describe*",
"transfer:List*",
"iot1click:Describe*",
"iot1click:Get*",
"iot1click:List*",
"wafv2:Describe*",
"wafv2:Get*",
"wafv2:List*",
"ecs:Describe*",
"ecs:List*",
"kinesisanalytics:Describe*",
"kinesisanalytics:Get*",
"kinesisanalytics:List*",
"route53:Get*",
"route53:List*",
"route53resolver:Get*",
"route53resolver:List*"
Integrating GCP with Auth0 for Workload Identity Federation involves several steps, ensuring a secure and seamless authentication process without traditional credentials. This setup allows our scanning application to authenticate with GCP services using tokens from Auth0, leveraging federated identities.
You’ll first need to create a Workload Identity Pool. You can find detailed instructions on creating Workload Identity Pools in Manage workload identity pools and providers.
To configure the Workload Identity Pool for Lansweeper Discovery:
https://dev-734bjlip.eu.auth0.com/
.https://cloud-scanning-api
.attribute.site_id == '<your site ID>'
attribute.side_id == '<site ID #1>' || attribute.site_id == '<site ID #2>'
After creating the Workload Identity Pool, copy the pool ID and save it for later.
Next, you’ll need to create a service account that grants permissions to the application. You can find detailed instructions in Create service accounts.
The Viewer role should be an appropriate role for Lansweeper Discovery. After creating the service account, copy the account email address and save it for later.
Your service account needs access to your organization and folders. You can find detailed instructions on granting the appropriate roles in Manage access to projects, folders, and organizations.
The service account will need the Folder Viewer and Organization Viewer roles.
The Workload Identity Pool needs to be configured to allow impersonation of the service account by the federated identity. You can find detailed instructions in Manage workload identity pools and providers.
In the Attribute name field, select subject and enter D9vGk9gXUNtrwWdifIe0BWC865gu8oHd@clients
.
If you want to scan multiple GCP projects, you will have to grant the Viewer role to the service account you created for every project you want to scan. You can find detailed instructions on granting the appropriate roles in Manage access to projects, folders, and organizations.
You can now create a Cloud Discovery action to schedule your cloud asset scanning.
Experience Lansweeper with your own data. Sign up now for a 14-day free trial.
Try NowExperience Lansweeper with your own data. Sign up now for a 14-day free trial.
Try Now