Skip to content

Latest commit

 

History

History
65 lines (52 loc) · 2.82 KB

cloudquery-implementation.md

File metadata and controls

65 lines (52 loc) · 2.82 KB

CloudQuery

Following the ADR(/proposal), and since PRs #202 and #212, this repository can be viewed as a set of CloudQuery configuration.

Implementation

We are using CloudQuery to collect data from:

  • AWS
  • GitHub
  • Snyk
  • Fastly
  • Galaxies of the Guardian
  • Image packages

As it is relatively easy collect data with CloudQuery, we have, largely, opted to collect all the data. By collecting this extra data, we enable others to answer their questions. For example:

  • Which of our EC2 apps still have port 22 open?
  • Which of our S3 buckets are publicly available?
  • I'm having trouble with a particular AWS service, who else is using it?
  • How many break-glass users do we have?

We have implemented CloudQuery to run on AWS ECS, writing data to Postgres. This is all defined using GuCDK.

We have more interest in some data sources than others. For example, we'd like to know more about AWS Lambdas across the estate than AWS Elastic Beanstalk deployments. For this reason, we have a number of ECS tasks, each running on their own schedule.

Postgres

Each ECS task authenticates with Postgres using IAM Authentication.

The root (sudo) user is not used. Instead, we manually created a user:

-- Create user for CloudQuery, and grant RDS IAM authentication.
-- See https://repost.aws/knowledge-center/rds-postgresql-connect-using-iam
CREATE USER cloudquery;
GRANT rds_iam TO cloudquery;

Grafana

We're using Grafana to create dashboards, joining data across the above sources. We have connected Grafana with read-only access to the Postgres database.

Unfortunately, Grafana does not support IAM authentication. We have manually created a user for Grafana with static credentials:

-- Create users for Grafana CODE and PROD, with readonly access.
-- See https://grafana.com/docs/grafana/latest/datasources/postgres/#database-user-permissions-important

-- Unfortunately Grafana does not support RDS IAM authentication.
-- See https://github.com/grafana/grafana/discussions/48170
CREATE USER grafanareadercode WITH PASSWORD 'REDACTED';
GRANT USAGE ON SCHEMA public TO grafanareadercode;

CREATE USER grafanareaderprod WITH PASSWORD 'REDACTED';
GRANT USAGE ON SCHEMA public TO grafanareaderprod;

-- Provide Grafana with access to any new tables and views as soon as they're created.
SET ROLE cloudquery;
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT ON TABLES TO grafanareadercode;
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT SELECT ON TABLES TO grafanareaderprod;