AlloyDB

Create an integration to manage access to an AlloyDB instance

AlloyDB is a fully managed PostgreSQL-compatible database service on Google Cloud. It offers high performance, scalability, and reliability for demanding enterprise workloads.

Through this integration, Apono helps you securely manage access to your AlloyDB instance.


Prerequisites

Item
Description

Apono Connector

Minimum Required Version: 1.6.4

Allow Connector IP Access

Allows the Apono connector to communicate with the AlloyDB instance

You must allow the connector IP range in the AlloyDB primary instance's IP allow list.

API Services

API services that must enabled:

  • AlloyDB API

  • Compute Engine API

  • Service Networking API

AlloyDB Information

Identifiers for AlloyDB resources:

  • Primary Instance ID

  • Cluster ID


Assign roles to the Apono connector

Use the following tabs to assign roles to the Apono connector for either your Google Project or Google Organization.

Follow these steps to assign roles to the Apono connector:

  1. In your shell environment, log in to Google Cloud and enable the API.

gcloud auth login
gcloud services enable cloudresourcemanager.googleapis.com
gcloud services enable iam.googleapis.com
  1. Set the environment variables.

export GCP_PROJECT_ID=<GOOGLE_PROJECT_ID>
export SERVICE_ACCOUNT_NAME=<SERVICE_ACCOUNT_NAME>
  1. Assign roles to the connector.

gcloud projects add-iam-policy-binding $GCP_PROJECT_ID \
    --member="serviceAccount:$SERVICE_ACCOUNT_NAME@$GCP_PROJECT_ID.iam.gserviceaccount.com" \
    --role="roles/alloydb.admin" \
    --project $GCP_PROJECT_ID

gcloud projects add-iam-policy-binding $GCP_PROJECT_ID \
    --member="serviceAccount:$SERVICE_ACCOUNT_NAME@$GCP_PROJECT_ID.iam.gserviceaccount.com" \
    --role="roles/serviceusage.serviceUsageConsumer" \
    --project $GCP_PROJECT_ID

Create an AlloyDB user

You must create a user in your AlloyDB instance for the Apono connector and grant that user permissions.

Use the following steps to create a user for the Apono connector and grant it permissions:

  1. Create a new user and grant permissions with either Built-in Authentication or IAM Authentication.

Run the following commands from your PostgreSQL client.

CREATE USER CONNECTOR_USERNAME WITH PASSWORD 'password';
GRANT alloydbsuperuser TO CONNECTOR_USERNAME;
  1. (Built-in Authentication only) Create a secret with the credentials from step 1.

When using IAM authentication, the service account and its permissions are managed through Google Cloud IAM roles and policies.

A secret does not need to be created.


Integrate AlloyDB

You can also use the steps below to integrate with Apono using Terraform.

In step 11, instead of clicking Confirm, follow the Are you integrating with Apono using Terraform? guidance.

Follow these steps to complete the integration:

  1. On the Catalog tab, click AlloyDB. The Connect Integration page appears.

  2. Under Discovery, select one or multiple resource types for Apono to discover in the instance.

  3. Click Next. The Apono connector section expands.

  4. From the dropdown menu, select a connector. Choosing a connector links Apono to all the services available on the account where the connector is located.

If the desired connector is not listed, click + Add new connector and follow the instructions for creating a connector for GCP.

  1. Click Next. The Integration Config page appears.

  2. Define the Integration Config settings.

Setting
Description

Integration Name

Unique, alphanumeric, user-friendly name used to identify this integration when constructing an access flow

Auth Type

Option

Description

User / Password

Apono-created local user credentials

IAM Authentication

Cloud IAM authentication

Project ID

ID of the project associated with the AlloyDB instance

Location

Location of the AlloyDB instance

Primary Instance ID

ID for the primary instance within the AlloyDB cluster

Cluster ID

ID for the AlloyDB cluster

Port

Port value for the database

By default, Apono sets this value to 5432.

Instance ID User Override (optional)

Overrides the instance ID for the user

Database Name

Name of the database to integrate

By default, Apono sets this value to postgre.

SSL Mode

(Optional) Mode of Secure Sockets Layer (SSL) encryption used to secure the connection with the SQL database server

Option

Description

require

An SSL-encrypted connection must be used.

allow

An SSL-encrypted or unencrypted connection is used. If an SSL encrypted connection is unavailable, the unencrypted connection is used.

disable

An unencrypted connection is used.

prefer

An SSL encrypted connection is attempted. If the encrypted connection is unavailable, the unencrypted connection is used.

verify-ca

An SSL-encrypted connection must be used and a server certification verification against the provided CA certificates must pass.

verify-full

An SSL-encrypted connection must be used and a server certification verification against the provided CA certificates must pass.

Additionally, the server hostname is checked against the certificate's names.

  1. Click Next. The Secret Store section expands.

  2. Click Next. The Get more with Apono section expands.

  3. Define the Get more with Apono settings.

Setting
Description

Credential Rotation

Custom Access Details

(Optional) Instructions explaining how to access this integration's resources

Upon accessing an integration, a message with these instructions will be displayed to end users in the User Portal. The message may include up to 400 characters.

To view the message as it appears to end users, click Preview.

Integration Owner

Follow these steps to define one or several integration owners:

  1. From the Attribute dropdown menu, select User or Group under the relevant identity provider (IdP) platform.

  2. From the Value dropdown menu, select one or multiple users or groups.

NOTE: When Resource Owner is defined, an Integration Owner must be defined.

Resource Owner

(Optional) Group or role responsible for managing access approvals or rejections for the resource

  1. Enter a Key name. This value is the name of the tag created in your cloud environment.

  2. From the Attribute dropdown menu, select an attribute under the IdP platform to which the key name is associated. Apono will use the value associated with the key (tag) to identify the resource owner. When you update the membership of the group or role in your IdP platform, this change is also reflected in Apono.

NOTE: When this setting is defined, an Integration Owner must also be defined.

  1. Click Confirm.

💡Are you integrating with Apono using Terraform?

If you want to integrate with Apono using Terraform, follow these steps instead of clicking Confirm:

  1. At the top of the screen, click View as Code. A modal appears with the completed Terraform configuration code.

  2. Click to copy the code.

  3. Make any additional edits.

  4. Deploy the code in your Terraform.

Refer to Integration Config Metadata for more details about the schema definition.

Now that you have completed this integration, you can create access flows that grant permission to your AlloyDB instance.

Last updated