Hydra
- Identity Charmers
Channel | Revision | Published | Runs on |
---|---|---|---|
latest/stable | 276 | 24 Apr 2024 | |
latest/edge | 333 | 12 Dec 2024 | |
istio/edge | 329 | 29 Nov 2024 | |
0.3/edge | 320 | 07 Nov 2024 | |
0.2/stable | 285 | 26 Jun 2024 | |
0.2/edge | 285 | 09 May 2024 | |
0.1/edge | 270 | 24 Nov 2023 |
juju deploy hydra
Deploy Kubernetes operators easily with Juju, the Universal Operator Lifecycle Manager. Need a Kubernetes cluster? Install MicroK8s to create a full CNCF-certified Kubernetes system in under 60 seconds.
Platform:
charms.hydra.v0.hydra_endpoints
-
- Last updated 21 Aug 2023
- Revision Library version 0.5
#!/usr/bin/env python3
# Copyright 2023 Canonical Ltd.
# See LICENSE file for licensing details.
"""Interface library for sharing hydra endpoints.
This library provides a Python API for both requesting and providing public and admin endpoints.
## Getting Started
To get started using the library, you need to fetch the library using `charmcraft`.
```shell
cd some-charm
charmcraft fetch-lib charms.hydra.v0.hydra_endpoints
```
To use the library from the requirer side:
In the `metadata.yaml` of the charm, add the following:
```yaml
requires:
hydra-endpoint-info:
interface: hydra_endpoints
limit: 1
```
Then, to initialise the library:
```python
from charms.hydra.v0.hydra_endpoints import (
HydraEndpointsRelationError,
HydraEndpointsRequirer,
)
Class SomeCharm(CharmBase):
def __init__(self, *args):
self.hydra_endpoints_relation = HydraEndpointsRequirer(self)
self.framework.observe(self.on.some_event_emitted, self.some_event_function)
def some_event_function():
# fetch the relation info
try:
hydra_data = self.hydra_endpoints_relation.get_hydra_endpoints()
except HydraEndpointsRelationError as error:
...
```
"""
import logging
from typing import Dict
from ops.charm import CharmBase, RelationCreatedEvent
from ops.framework import EventBase, EventSource, Object, ObjectEvents
# The unique Charmhub library identifier, never change it
LIBID = "a9dbc14576874a508dc3b7f717c72f73"
# Increment this major API version when introducing breaking changes
LIBAPI = 0
# Increment this PATCH version before using `charmcraft publish-lib` or reset
# to 0 if you are raising the major API version
LIBPATCH = 5
RELATION_NAME = "hydra-endpoint-info"
INTERFACE_NAME = "hydra_endpoints"
logger = logging.getLogger(__name__)
class HydraEndpointsRelationReadyEvent(EventBase):
"""Event to notify the charm that the relation is ready."""
class HydraEndpointsProviderEvents(ObjectEvents):
"""Event descriptor for events raised by `HydraEndpointsProvider`."""
ready = EventSource(HydraEndpointsRelationReadyEvent)
class HydraEndpointsProvider(Object):
"""Provider side of the hydra-endpoint-info relation."""
on = HydraEndpointsProviderEvents()
def __init__(self, charm: CharmBase, relation_name: str = RELATION_NAME):
super().__init__(charm, relation_name)
self._charm = charm
self._relation_name = relation_name
events = self._charm.on[relation_name]
self.framework.observe(
events.relation_created, self._on_provider_endpoint_relation_created
)
def _on_provider_endpoint_relation_created(self, event: RelationCreatedEvent) -> None:
self.on.ready.emit()
def send_endpoint_relation_data(self, admin_endpoint: str, public_endpoint: str) -> None:
"""Updates relation with endpoints info."""
if not self._charm.unit.is_leader():
return
relations = self.model.relations[self._relation_name]
for relation in relations:
relation.data[self._charm.app].update(
{
"admin_endpoint": admin_endpoint,
"public_endpoint": public_endpoint,
}
)
class HydraEndpointsRelationError(Exception):
"""Base class for the relation exceptions."""
pass
class HydraEndpointsRelationMissingError(HydraEndpointsRelationError):
"""Raised when the relation is missing."""
def __init__(self) -> None:
self.message = "Missing hydra-endpoint-info relation with hydra"
super().__init__(self.message)
class HydraEndpointsRelationDataMissingError(HydraEndpointsRelationError):
"""Raised when information is missing from the relation."""
def __init__(self, message: str) -> None:
self.message = message
super().__init__(self.message)
class HydraEndpointsRequirer(Object):
"""Requirer side of the hydra-endpoint-info relation."""
def __init__(self, charm: CharmBase, relation_name: str = RELATION_NAME) -> None:
super().__init__(charm, relation_name)
self.charm = charm
self.relation_name = relation_name
def get_hydra_endpoints(self) -> Dict:
"""Get the hydra endpoints."""
endpoints = self.model.relations[self.relation_name]
if len(endpoints) == 0:
raise HydraEndpointsRelationMissingError()
data = endpoints[0].data[endpoints[0].app]
if "admin_endpoint" not in data:
raise HydraEndpointsRelationDataMissingError(
"Missing admin endpoint in hydra-endpoint-info relation data"
)
return {
"admin_endpoint": data["admin_endpoint"],
"public_endpoint": data["public_endpoint"],
}