PgBouncer K8s
- Canonical
- Databases
Channel | Revision | Published | Runs on |
---|---|---|---|
1/stable | 360 | 20 Dec 2024 | |
1/stable | 359 | 20 Dec 2024 | |
1/candidate | 360 | 18 Dec 2024 | |
1/candidate | 359 | 18 Dec 2024 | |
1/beta | 360 | 16 Dec 2024 | |
1/beta | 359 | 16 Dec 2024 | |
1/edge | 378 | 17 Jan 2025 | |
1/edge | 377 | 17 Jan 2025 |
juju deploy pgbouncer-k8s --channel 1/stable
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.pgbouncer_k8s.v0.pgb
-
- Last updated 16 Oct 2024
- Revision Library version 0.10
# Copyright 2023 Canonical Ltd.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
"""PgBouncer Charm Library.
This charm library provides common pgbouncer-specific features for the pgbouncer machine and
Kubernetes charms, including automatic config management using the PgbConfig object, and the
default config for pgbouncer.
"""
import logging
import secrets
import string
from hashlib import md5
from typing import Dict
# The unique Charmhub library identifier, never change it
LIBID = "113f4a7480c04631bfdf5fe776f760cd"
# 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 = 10
logger = logging.getLogger(__name__)
PGB = "pgbouncer"
PGB_DIR = "/var/lib/postgresql/pgbouncer"
INI_PATH = f"{PGB_DIR}/pgbouncer.ini"
def parse_kv_string_to_dict(string: str) -> Dict[str, str]:
"""Parses space-separated key=value pairs into a python dict.
TODO this could make use of pgconnstr, but that requires that this charm lib has a dependency.
Args:
string: a string containing a set of key=value pairs, joined with = characters and
separated with spaces
Returns:
A dict containing the key-value pairs represented as strings.
"""
parsed_dict = {}
for kv_pair in string.split(" "):
key, value = kv_pair.split("=")
parsed_dict[key] = value
return parsed_dict
def parse_dict_to_kv_string(dictionary: Dict[str, str]) -> str:
"""Helper function to encode a python dict into a pgbouncer-readable string.
TODO this could make use of pgconnstr, but that requires that this charm lib has a dependency.
Args:
dictionary: A dict containing the key-value pairs represented as strings.
Returns: a string containing a set of key=value pairs, joined with = characters and
separated with spaces
"""
return " ".join([f"{key}={value}" for key, value in dictionary.items()])
def generate_password() -> str:
"""Generates a secure password of alphanumeric characters.
Passwords are alphanumeric only, to ensure compatibility with the userlist.txt format -
specifically, spaces and double quotes may interfere with parsing this file.
Returns:
A random 24-character string of letters and numbers.
"""
choices = string.ascii_letters + string.digits
return "".join([secrets.choice(choices) for _ in range(24)])
def get_hashed_password(username: str, password: str) -> str:
"""Creates an md5 hashed password for the given user, in the format postgresql expects."""
# Should be handled in DPE-1430
hash_password = md5((password + username).encode()).hexdigest() # noqa: S324
return f"md5{hash_password}"