Skip to main content

GCP provider for Pragmatiks

Project description

GCP Provider

GCP provider for Pragmatiks - manage Google Cloud resources declaratively.

Available Resources

Secret (gcp/secret)

Manages secrets in GCP Secret Manager using user-provided service account credentials.

from gcp_provider import Secret, SecretConfig

# Define a secret
secret = Secret(
    name="my-api-key",
    config=SecretConfig(
        project_id="my-gcp-project",
        secret_id="api-key",
        data="super-secret-value",
        credentials={"type": "service_account", ...},  # or JSON string
    ),
)

Config:

  • project_id - GCP project ID where the secret will be created
  • secret_id - Identifier for the secret (must be unique per project)
  • data - Secret payload data to store
  • credentials - GCP service account credentials (JSON object or string)

Outputs:

  • resource_name - Full GCP resource name (projects/{project}/secrets/{id})
  • version_name - Full version resource name including version number
  • version_id - The version number as a string

Installation

pip install pragmatiks-gcp-provider

Development

Testing

# Install dependencies
uv sync --dev

# Run tests
uv run pytest tests/

Writing Tests

Use ProviderHarness to test lifecycle methods:

from pragma_sdk.provider import ProviderHarness
from gcp_provider import Secret, SecretConfig

async def test_create_secret():
    harness = ProviderHarness()
    result = await harness.invoke_create(
        Secret,
        name="test-secret",
        config=SecretConfig(
            project_id="test-project",
            secret_id="my-secret",
            data="secret-value",
            credentials=mock_credentials,
        ),
    )
    assert result.success
    assert result.outputs.resource_name is not None

Deployment

Push your provider to Pragmatiks platform:

pragma provider push

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pragmatiks_gcp_provider-0.59.0.tar.gz (6.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pragmatiks_gcp_provider-0.59.0-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file pragmatiks_gcp_provider-0.59.0.tar.gz.

File metadata

  • Download URL: pragmatiks_gcp_provider-0.59.0.tar.gz
  • Upload date:
  • Size: 6.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pragmatiks_gcp_provider-0.59.0.tar.gz
Algorithm Hash digest
SHA256 c66f09b9397970b0353e4bcad61d701794a8a675d93e7ac1a3930e120752594e
MD5 fd7ff26e19e85f0ea85214b55b19a715
BLAKE2b-256 fb05ba344220867071ebc8c5f37b26f10ace36298bf835d3607733f5e06e6004

See more details on using hashes here.

Provenance

The following attestation bundles were made for pragmatiks_gcp_provider-0.59.0.tar.gz:

Publisher: publish.yaml on pragmatiks/pragma-providers

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pragmatiks_gcp_provider-0.59.0-py3-none-any.whl.

File metadata

File hashes

Hashes for pragmatiks_gcp_provider-0.59.0-py3-none-any.whl
Algorithm Hash digest
SHA256 051b2ade071df4b16db5655087601cb16601b4980e7fdd4e5f4ea36b9b710c1c
MD5 a0f008f1d8f55116d5013f5c3d90705d
BLAKE2b-256 e48f2d3dd8cffa514a3f4e2a1d0a154a7e67745d6748ebb9e4d2c4e0116ec3a7

See more details on using hashes here.

Provenance

The following attestation bundles were made for pragmatiks_gcp_provider-0.59.0-py3-none-any.whl:

Publisher: publish.yaml on pragmatiks/pragma-providers

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page