Phalanx internal API#

These pages document the Phalanx internal API, which may be of interest when extending the Phalanx command-line tool or documentation build infrastructure.

Phalanx does not provide a library or Python module for external use. This API is only intended for use within the Phalanx code itself.

phalanx Package#

Support tooling for Phalanx, SQuaRE’s application development platform.

Variables#

__version__

The version string, although phalanx isn't technically released like a typical Python package.

phalanx.constants Module#

Constants for the Phalanx support code.

Things that arguably could be configurable but haven’t yet been made into actual configuration options.

Variables#

HELM_DOCLINK_ANNOTATION

Annotation in Chart.yaml for application documentation links.

VAULT_WRITE_TOKEN_LIFETIME

Default lifetime to set for Vault write tokens.

VAULT_WRITE_TOKEN_WARNING_LIFETIME

Remaining lifetime at which to warn that a token is about to expire.

phalanx.docs.crossref Module#

Cross-referencing roles and directives for Phalanx topics.

Functions#

setup(app)

Set up the Phalan cross-referencing extensions.

phalanx.docs.jinja Module#

Helper functions for Sphinx Jinja templating.

Functions#

build_jinja_contexts()

Construct the Jinja contexts used for building Phalanx documentation.

phalanx.exceptions Module#

Exceptions for the Phalanx command-line tool.

Classes#

InvalidApplicationConfigError(name, error, *)

Configuration for an application is invalid.

InvalidEnvironmentConfigError(name, error)

Configuration for an environment is invalid.

InvalidSecretConfigError(application, key, error)

Secret configuration is invalid.

UnknownEnvironmentError(name)

No configuration found for an environment name.

UnresolvedSecretsError(secrets)

Some secrets could not be resolved.

VaultNotFoundError(url, path)

Secret could not be found in Vault.

Class Inheritance Diagram#

Inheritance diagram of phalanx.exceptions.InvalidApplicationConfigError, phalanx.exceptions.InvalidEnvironmentConfigError, phalanx.exceptions.InvalidSecretConfigError, phalanx.exceptions.UnknownEnvironmentError, phalanx.exceptions.UnresolvedSecretsError, phalanx.exceptions.VaultNotFoundError

phalanx.factory Module#

Factory for Phalanx support code components.

Classes#

Factory(path)

Factory to create Phalanx components.

Class Inheritance Diagram#

Inheritance diagram of phalanx.factory.Factory

phalanx.models.applications Module#

Pydantic models for Phalanx applications.

Classes#

Application

A Phalanx application that knows which environments use it.

ApplicationConfig

Configuration for a Phalanx application.

ApplicationInstance

A Phalanx application as configured for a specific environment.

DocLink

A documentation link for an application.

Class Inheritance Diagram#

Inheritance diagram of phalanx.models.applications.Application, phalanx.models.applications.ApplicationConfig, phalanx.models.applications.ApplicationInstance, phalanx.models.applications.DocLink

phalanx.models.environments Module#

Pydantic models for Phalanx environments.

Classes#

Environment

A Phalanx environment and its associated settings.

EnvironmentConfig

Configuration for a Phalanx environment.

EnvironmentDetails

Full details about an environment, including auth and Argo CD.

EnvironmentVaultConfig

Vault configuration for a specific environment.

GafaelfawrGitHubGroup

A group based on a GitHub team.

GafaelfawrGitHubTeam

Designates a GitHub team for use as a Gafaelfawr group.

GafaelfawrScope

A Gafaelfawr scope and its associated groups.

IdentityProvider(value[, names, module, ...])

Type of identity provider used by Gafaelfawr.

PhalanxConfig

Root container for the entire Phalanx configuration.

Class Inheritance Diagram#

Inheritance diagram of phalanx.models.environments.Environment, phalanx.models.environments.EnvironmentConfig, phalanx.models.environments.EnvironmentDetails, phalanx.models.environments.EnvironmentVaultConfig, phalanx.models.environments.GafaelfawrGitHubGroup, phalanx.models.environments.GafaelfawrGitHubTeam, phalanx.models.environments.GafaelfawrScope, phalanx.models.environments.IdentityProvider, phalanx.models.environments.PhalanxConfig

phalanx.models.gafaelfawr Module#

Models for Gafaelfawr data structures.

Ideally, these should use the same models Gafaelfawr itself uses. Until that’s possible via a PyPI library, these models are largely copied from Gafaelfawr.

Classes#

Token

An opaque token.

Class Inheritance Diagram#

Inheritance diagram of phalanx.models.gafaelfawr.Token

phalanx.models.secrets Module#

Pydantic models for Phalanx application secrets.

Classes#

ConditionalMixin

Mix-in class for elements that may have a condition.

ConditionalSecretConfig

Possibly conditional specification for an application secret.

ConditionalSecretCopyRules

Possibly conditional rules for copying a secret value from another.

ConditionalSimpleSecretGenerateRules

Conditional rules for generating a secret value with no source.

ConditionalSourceSecretGenerateRules

Conditional rules for generating a secret from another secret.

ResolvedSecret

A secret that has been resolved for a given application instance.

Secret

Specification for an application secret for a specific environment.

SecretConfig

Specification for an application secret.

SecretCopyRules

Rules for copying a secret value from another secret.

SecretGenerateType(value[, names, module, ...])

Type of secret for generated secrets.

SimpleSecretGenerateRules

Rules for generating a secret value with no source information.

SourceSecretGenerateRules

Rules for generating a secret from another secret.

StaticSecret

Value of a static secret provided in a YAML file.

Variables#

ConditionalSecretGenerateRules

Represent a PEP 604 union type

SecretGenerateRules

Represent a PEP 604 union type

Class Inheritance Diagram#

Inheritance diagram of phalanx.models.secrets.ConditionalMixin, phalanx.models.secrets.ConditionalSecretConfig, phalanx.models.secrets.ConditionalSecretCopyRules, phalanx.models.secrets.ConditionalSimpleSecretGenerateRules, phalanx.models.secrets.ConditionalSourceSecretGenerateRules, phalanx.models.secrets.ResolvedSecret, phalanx.models.secrets.Secret, phalanx.models.secrets.SecretConfig, phalanx.models.secrets.SecretCopyRules, phalanx.models.secrets.SecretGenerateType, phalanx.models.secrets.SimpleSecretGenerateRules, phalanx.models.secrets.SourceSecretGenerateRules, phalanx.models.secrets.StaticSecret

phalanx.models.vault Module#

Models representing Vault objects.

Classes#

VaultAppRole

Newly-created Vault AppRole for secret access.

VaultAppRoleMetadata

Metadata about a new or existing Vault AppRole.

VaultToken

Newly-created Vault token for secret access.

VaultTokenMetadata

Metadata about a new or existing Vault token.

Class Inheritance Diagram#

Inheritance diagram of phalanx.models.vault.VaultAppRole, phalanx.models.vault.VaultAppRoleMetadata, phalanx.models.vault.VaultToken, phalanx.models.vault.VaultTokenMetadata

phalanx.services.secrets Module#

Service to manipulate Phalanx secrets.

Classes#

SecretsService(config_storage, vault_storage)

Service to manipulate Phalanx secrets.

Class Inheritance Diagram#

Inheritance diagram of phalanx.services.secrets.SecretsService

phalanx.services.vault Module#

Service to manage Vault authentication.

Classes#

VaultService(config_storage, vault_storage)

Service to manage Vault authentication.

Class Inheritance Diagram#

Inheritance diagram of phalanx.services.vault.VaultService

phalanx.storage.config Module#

Parsing and analysis of Phalanx configuration.

Classes#

ConfigStorage(path)

Analyze Phalanx configuration and convert it to models.

Class Inheritance Diagram#

Inheritance diagram of phalanx.storage.config.ConfigStorage

phalanx.storage.vault Module#

Store, retrieve, and manipulate data stored in Vault.

Classes#

VaultClient(url, path)

Store, retrieve, and manipulate data stored in Vault.

VaultStorage()

Create Vault clients for specific environments.

Class Inheritance Diagram#

Inheritance diagram of phalanx.storage.vault.VaultClient, phalanx.storage.vault.VaultStorage

phalanx.yaml Module#

Utility functions for manipulating YAML.

In several places in the Phalanx code, we want to be able to wrap long strings to make them more readable or be able to dump collections.defaultdict objects without adding special object tagging. This module collects utility functions to make this easier.

Classes#

YAMLFoldedString

A string that will be folded when encoded in YAML.

Class Inheritance Diagram#

Inheritance diagram of phalanx.yaml.YAMLFoldedString