Skip to main content

Manage Lagoon hosting platform resources as infrastructure-as-code.

Project description

Pulumi Lagoon Provider — Python SDK

PyPI version License

A Pulumi provider for managing Lagoon resources as infrastructure-as-code.

Installation

pip install pulumi-lagoon

Configuration

pulumi config set lagoon:apiUrl https://api.lagoon.example.com/graphql
pulumi config set --secret lagoon:token YOUR_TOKEN

Or via environment variables:

export LAGOON_API_URL=https://api.lagoon.example.com/graphql
export LAGOON_TOKEN=YOUR_TOKEN

Supported Resources

Resource Description
Project Lagoon projects (applications/sites)
Environment Environments (branch/PR deployments)
Variable Project and environment variables
DeployTarget Kubernetes cluster deploy targets
DeployTargetConfig Branch-pattern routing to deploy targets
NotificationSlack Slack deployment notifications
NotificationRocketChat RocketChat deployment notifications
NotificationEmail Email deployment notifications
NotificationMicrosoftTeams Microsoft Teams deployment notifications
ProjectNotification Link notifications to projects
Task Advanced task definitions (command and image types)
Group Groups for organizing projects and users
Route API-managed routes (requires Lagoon v2.29.0+)
ProjectAutogeneratedRouteConfig Autogenerated route settings at project level
EnvironmentAutogeneratedRouteConfig Autogenerated route settings at environment level

Usage

import pulumi
from pulumi_lagoon import Project, Environment, Variable, Group  # top-level re-exports
# The submodule path also works: from pulumi_lagoon.lagoon import ...

project = Project("my-site",
    name="my-drupal-site",
    git_url="git@github.com:org/repo.git",
    deploytarget_id=1,
    production_environment="main",
    branches="^(main|develop|stage)$",
)

prod_env = Environment("production",
    name="main",
    project_id=project.lagoon_id,
    deploy_type="branch",
    deploy_base_ref="main",
    environment_type="production",
)

db_config = Variable("db-host",
    name="DATABASE_HOST",
    value="mysql.production.example.com",
    project_id=project.lagoon_id,
    environment_id=prod_env.lagoon_id,
    scope="runtime",
)

team = Group("my-team",
    name="my-team",
)

pulumi.export("project_id", project.lagoon_id)

Importing Existing Resources

pulumi import lagoon:lagoon:Project my-site 123
pulumi import lagoon:lagoon:Environment prod-env 123:main
pulumi import lagoon:lagoon:Variable api-key 123::API_KEY
pulumi import lagoon:lagoon:Group my-team my-team

Multi-Language Support

This provider also has SDKs for TypeScript/JavaScript, Go, and .NET/C#.

Documentation

License

Apache License 2.0

Project details


Download files

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

Source Distribution

pulumi_lagoon-0.4.1.tar.gz (32.3 kB view details)

Uploaded Source

Built Distribution

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

pulumi_lagoon-0.4.1-py3-none-any.whl (59.3 kB view details)

Uploaded Python 3

File details

Details for the file pulumi_lagoon-0.4.1.tar.gz.

File metadata

  • Download URL: pulumi_lagoon-0.4.1.tar.gz
  • Upload date:
  • Size: 32.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pulumi_lagoon-0.4.1.tar.gz
Algorithm Hash digest
SHA256 a571e81634cee39afbfb0850a73aba581f2be856d4e2b5710dc9016c0a8ea449
MD5 e46d4050af2c3f3dbf7eb72294283ef3
BLAKE2b-256 2fa50880a3742957b969dec36fd0bbf9024a8e1b876f247f4f9d32bedb204682

See more details on using hashes here.

Provenance

The following attestation bundles were made for pulumi_lagoon-0.4.1.tar.gz:

Publisher: publish.yml on tag1consulting/pulumi-lagoon-provider

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

File details

Details for the file pulumi_lagoon-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: pulumi_lagoon-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 59.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for pulumi_lagoon-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7f5ae6a4d5af21a5db7d499b26e498c6375d910c1905d02205cb6a121d6cb0d3
MD5 404e290918335c265701beb0f5e9b23d
BLAKE2b-256 7b6d66a62c22dd82fd14ed0c9fad2b6923f4f74c1a1bf274975aebae1089c7e1

See more details on using hashes here.

Provenance

The following attestation bundles were made for pulumi_lagoon-0.4.1-py3-none-any.whl:

Publisher: publish.yml on tag1consulting/pulumi-lagoon-provider

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