Skip to content

Latest commit

 

History

History
79 lines (57 loc) · 3.79 KB

File metadata and controls

79 lines (57 loc) · 3.79 KB

mongodb_client

Usage

This relation interface describes the expected behaviour of any charm claiming to be able to interact with a MongoDB database. Our intent to have different interface names with <database>_client pattern (like mongodb_client) and the same validation rules for multiple databases (e.g. MySQL, PostgreSQL, MongoDB, etc).

In most cases, this will be accomplished using the database provider library, although charm developers are free to provide alternative libraries as long as they fulfil the behavioural and schematic requirements described in this document.

Direction

flowchart TD
    Requirer -- database, extra-user-roles --> Provider
    Provider -- database, username, password, endpoints --> Requirer
Loading

As with all Juju relations, the database interface consists of two parties: a Provider (database charm), and a Requirer (application charm). The Requirer will be expected to provide a database name, and the Provider will provide new unique credentials (along with other optional fields), which can be used to access the actual database cluster.

Behavior

Both the Requirer and the Provider need to adhere to criteria to be considered compatible with the interface.

Provider

  • Is expected to create an application user inside the database cluster when the requirer provides the database field.
  • Is expected to provide username and password fields when Requirer provides the database field.
  • Is expected to provide the endpoints field with a comma-separated list of hosts, which can be used for database connection.
  • Is expected to provide the database field with the database that was actually created.
  • Is expected to provide optional replset field with Replica Set name which is needed for proper connection to MongoDB if sharding is disabled.
  • Is expected to provide optional uris field with URI which can be passed to MongoDB client libraries as it is (not needed to construct it on client side).
  • Is expected to provide the version field whenever database charm wants to communicate its database version.

Requirer

  • Is expected to provide a database name in the database field.
  • Is expected to have unique credentials for each relation. Therefore, different instances of the same Charm (juju applications) will have different relations with different credentials.
  • Is expected to have different relations names on Requirer with the same interface name if Requirer needs access to multiple database charms.
  • Is expected to allow multiple different Juju applications to access the same database name.
  • Is expected to add any extra-user-roles provided by the Requirer to the created user (e.g. extra-user-roles=admin).
  • Is expected to tolerate that the Provider may ignore the database field in some cases and instead use the database name received.

Relation Data

Provider

[JSON Schema]

Provider provides credentials, endpoints, TLS info and database-specific fields. It should be placed in the application databag.

Example

  relation-info:
  - endpoint: database
    related-endpoint: database
    application-data:
      database: myappB
      endpoints: mongodb-k8s-1.mongodb-k8s-endpoints,mongodb-k8s-0.mongodb-k8s-endpoints
      password: Dy0k2UTfyNt2B13cfe412K7YGs07S4U7
      replset: mongodb-k8s
      uris: mongodb://relation-68:Dy0k2UTfyNt2B13cfe412K7YGs07S4U7@mongodb-k8s-1.mongodb-k8s-endpoints,mongodb-k8s-0.mongodb-k8s-endpoints/myappB?replicaSet=mongodb-k8s&authSource=admin
      username: relation-68

Requirer

[JSON Schema]

Requirer provides database name. It should be placed in the application databag.

Example

  relation-info:
  - endpoint: database
    related-endpoint: database
    application-data:
      database: myappA