Skip to main content

Package with general devops code

Project description

CCDCOE package

GitHub Release GPLv3 License

pypi

This package contains generic re-usable code.

Install the full package:

pip install ccdcoe[all]

Package has several modules which can be installed separately by specifying them as an extra requirement. To install the http_apis module only, specify:

pip install ccdcoe[http_apis]

Or for multiple modules:

pip install ccdcoe[http_apis, loggers]

Adding modules and/or groups

Everything for this package is defined in the pyproject.toml file. Dependencies are managed by poetry and grouped in, you guessed it, groups. Every poetry group can be installed as an extra using pip.

Extra extras or group on group/extra dependencies can also be defined in the [tool.ccdcoe.group.dependencies] section. Everything defined here will also become an extra if no group already exists. You can use everything defined here as dependency for another group, order does not matter.

example:

[tool.ccdcoe.group.dependencies]
my_awesome_extra = ["my_awesome_group", "my_other_group"]
my_awesome_group = ["my_logging_group"]

[tool.poetry.group.my_awesome_group.dependencies]
<dependency here>

[tool.poetry.group.my_other_group.dependencies]
<dependency here>

[tool.poetry.group.my_logging_group.dependencies]
<dependency here>

Using this example the following extras exist with the correct dependencies:

pip install ccdcoe[all]
pip install ccdcoe[my-awesome-extra]
pip install ccdcoe[my-awesome-group]
pip install ccdcoe[my-other-group]
pip install ccdcoe[my-logging-group]

Modules

The following modules are available in the ccdcoe package:

  • http_apis
  • loggers
  • dumpers
  • deployments
  • cli
  • redis_cache
  • flask_managers
  • flask_middleware
  • flask_plugins
  • auth
  • sso
  • plugins
  • sql_migrations

HTTP apis

Baseclass for http api communication is present under ccdcoe.http_apis.base_class.api_base_class.ApiBaseClass

Loggers

There are three loggers provided:

  • ConsoleLogger (ccdcoe.loggers.app_logger.ConsoleLogger)
  • AppLogger (ccdcoe.loggers.app_logger.AppLogger)
  • GunicornLogger (ccdcoe.loggers.app_logger.GunicornLogger)

The ConsoleLogger is intended as a loggerClass for cli applications.

The AppLogger is intended to be used as a loggerClass to be used for the standard python logging module.

import logging
from ccdcoe.loggers.app_logger import AppLogger

logging.setLoggerClass(AppLogger)

mylogger = logging.getLogger(__name__)

The 'mylogger' instance has all the proper formatting and handlers (according to the desired config) to log messages.

The Gunicorn logger is intended to be used for as a loggerClass for the gunicorn webserver; it enables the FlaskAppManager to set the necessary formatting and handles according to the AppLogger specs and a custom format for the gunicorn access logging.

Flask app manager

The FlaskAppManager is intended to be used to 'run' flask applications in both test, development as in production environments.

from YADA import app
from ccdcoe.flask_managers.flask_app_manager import FlaskAppManager

fam = FlaskAppManager(version="1.0", app=app)
fam.run()

Depending on the configuration the FlaskAppManager uses a werkzeug (DEBUG == True) or a gunicorn webserver. TLS could be set for both webservers iaw the module specific README.md.

SQL Migrations

The sql migrations can be used to facilitate migration between different versions of sql models / versions. It relies on flask migrate to perform the different migrations. It has a CLI as well as an python class based API.

Check the command line help

python3 -m ccdcoe.sql_migrations.flask_sql_migrate -a /path/to/script_with_flask_app.py -i
python3 -m ccdcoe.sql_migrations.flask_sql_migrate -a /path/to/script_with_flask_app.py -m
python3 -m ccdcoe.sql_migrations.flask_sql_migrate -a /path/to/script_with_flask_app.py -u

Or initiate the FlaskSqlMigrate as a class and initiate the migration process from there:

from ccdcoe.sql_migrations.flask_sql_migrate import FlaskSqlMigrate
fsm = FlaskSqlMigrate(app_ref="/path/to/script_with_flask_app.py")

fsm.db_init()
fsm.db_migrate()
fsm.db_update()

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

ccdcoe-0.0.18.tar.gz (96.8 kB view details)

Uploaded Source

Built Distribution

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

ccdcoe-0.0.18-py3-none-any.whl (116.0 kB view details)

Uploaded Python 3

File details

Details for the file ccdcoe-0.0.18.tar.gz.

File metadata

  • Download URL: ccdcoe-0.0.18.tar.gz
  • Upload date:
  • Size: 96.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ccdcoe-0.0.18.tar.gz
Algorithm Hash digest
SHA256 25173b60b797e67187f037cb1eddf88f5105b5ba17f77c19670f3afb17c48633
MD5 9bb1cfca5ceebce182dfdcaba99e659a
BLAKE2b-256 8c6d40dae30bdd7c9032d2d54b68f23c637d1ecd0fc6a7e5e8b166c9cd11a2d5

See more details on using hashes here.

Provenance

The following attestation bundles were made for ccdcoe-0.0.18.tar.gz:

Publisher: package_to_pypi.yaml on ccdcoe/ccdcoe

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

File details

Details for the file ccdcoe-0.0.18-py3-none-any.whl.

File metadata

  • Download URL: ccdcoe-0.0.18-py3-none-any.whl
  • Upload date:
  • Size: 116.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ccdcoe-0.0.18-py3-none-any.whl
Algorithm Hash digest
SHA256 f7117fa11763a9430793a877989884d54f9a0150afad3e6124d4bc88a7f304e7
MD5 53f21372e6b0be3abede9e99ccf3a2b2
BLAKE2b-256 6009a43b88dfb634eac88549764068dfae5bfa28990330a0ce9880fde898db92

See more details on using hashes here.

Provenance

The following attestation bundles were made for ccdcoe-0.0.18-py3-none-any.whl:

Publisher: package_to_pypi.yaml on ccdcoe/ccdcoe

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