Skip to main content

A specialized library developed by Credenti for efficient caching in Flask applications.

Project description

Ct Cache Lib

A specialized library developed by Credenti for efficient caching in Flask applications.


Features

  • Decorator-based caching for Flask endpoints and functions
  • Configurable Valkey connection pooling
  • Supports cache key templating with nested attribute access
  • Easy integration with Flask app lifecycle

Installation

pip install ct-cache-lib

Configuration

Add the following to your Flask app configuration:

app.config['CACHE'] = True              # Enable or disable caching
app.config['CACHE_EXPIRE_TIME'] = 60    # Default cache expiration time in seconds
app.config['CACHE_HOST'] = 'localhost'  # Cache host
app.config['CACHE_PORT'] = 6379         # Cache port
app.config['CACHE_USERNAME'] = 'user'   # Cache username (if required)
app.config['CACHE_PASSWORD'] = 'pass'   # Cache password (if required)
app.config['CACHE_CLIENT_NAME'] = 'my-client' # Cache client name

Usage

from flask import Flask
from ct_cache_lib import init_cache
import logging

app = Flask(__name__)
logger = logging.getLogger(__name__)

# Initialize the cache
ct_cache = init_cache(app, logger)

@app.route('/idle_time')
@ct_cache.cache(template_cache_key='idle_time_value:$idle_time', field='$idle_time')
def get_idle_time_value(idle_time: str):
    # Your function logic here
    return {'idle_time': idle_time}

Updating a Cache Entry

Update a cache entry directly:

ct_cache.update(
    cache_key='idle_time_value:123',  # Actual cache key
    field='some_field',
    value={'idle_time': 123},
    is_global=False,                  # or True if the key is global
    expire_time=120                   # optional, in seconds
)

Deleting a Cache Entry

Delete a cache entry:

ct_cache.delete(
    cache_key='idle_time_value:123',  # Actual cache key, not a template
    field='some_field',
    is_global=False                   # or True if the key is global
)

Committing and Resetting Cache

Commit cache writes after each request:

@app.after_request
def after_request(response):
    ct_cache.commit(response)
    return response

Reset cache if you need to roll back changes:

ct_cache.reset()

Cache Key Specification Examples

You can use dynamic cache keys by referencing function arguments or nested data using $.

Basic Example

@ct_cache.cache(template_cache_key='idle_time_value:$idle_time', field='$idle_time')
def get_idle_time_value(idle_time: str):
    return {'idle_time': idle_time}
  • If idle_time = 123, the cache key will be idle_time_value:123.

Nested Dictionary Example

@ct_cache.cache(template_cache_key='user_cache:$user.id', field='$user.id')
def get_user(user: dict):
    return user
  • If user = {'id': 01, 'name': 'User1'}, the cache key will be user_cache:01.

Nested Object Example

class User:
    def __init__(self, id, name):
        self.id = id
        self.name = name

@ct_cache.cache(template_cache_key='user_cache:$user.id', field='$user.id')
def get_user_obj(user: User):
    return {'id': user.id, 'name': user.name}
  • If user.id = 01, the cache key will be user_cache:01.

Deeply Nested Example

@ct_cache.cache(template_cache_key='deep_cache:$data.profile.info.id', field='$data.profile.info.id')
def get_deep(data: dict):
    return data
  • If data = {'profile': {'info': {'id': 01}}}, the cache key will be deep_cache:01.

Static Key Example

@ct_cache.cache(template_cache_key='static_key')
def get_static():
    return {'result': 1}
  • The cache key will always be static_key.

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

sample_test_lib-0.1.0.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

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

sample_test_lib-0.1.0-py3-none-any.whl (7.5 kB view details)

Uploaded Python 3

File details

Details for the file sample_test_lib-0.1.0.tar.gz.

File metadata

  • Download URL: sample_test_lib-0.1.0.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.11

File hashes

Hashes for sample_test_lib-0.1.0.tar.gz
Algorithm Hash digest
SHA256 7f7f31a28207975e2e8576420e036686e5afbe91e0edbeb6b3001cd9a597f830
MD5 4f68b24f477200167f711ed3d238cf1e
BLAKE2b-256 557e0b12bb20e41781e5b9d765d91679fdf052dd96b3125b561ea5c01248382c

See more details on using hashes here.

File details

Details for the file sample_test_lib-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for sample_test_lib-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 3ae62ff3ea9461daf3683da33fe5d2cd49f4637c52f860065ed4b9cbe8e4e81c
MD5 50e84208b68a520c2277fc949ee61806
BLAKE2b-256 163fab7ff1a2617f2dff4e3411de6d781ef766c2377aca58a78f1f3baa050445

See more details on using hashes here.

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