Skip to main content

Redis Entities

Project description

RedisEntities

How to install it?

You can install RedisEntites from this Github repository with python3 setup.py install, or just install it directly from pypi with pip3 install redis-entities.

What is it?

Redis Entities is a small library that allows you to map represent certain entities in Redis. An Entity could be for example a Hashmap type and stores information about one User that currently requested a password reset. Each Entity has a predefined Prefix used to differentiate the different types of Entities you create. There are 3 different RedisEntities you can use:

  • RedisListEntity
  • RedisSetEntity
  • RedisHashmapEntity

In addition there are a couple of mixins, which can be used to provide additional functionality to your entities. There are 3 different Mixins you can use:

  • HashedIdentifierMixin: All identifiers are hashed before stored in Redis
  • AuthenticatedEncryptionMixin: All values are encrypted and authenticated before stored in Redis
  • DeterministicAuthenticatedEncryptionMixin: All values are encrypted and authenticated deterministically (the same value is encrypted to the same ciphertext) before stored in Redis

You can also combine multiple Mixins, except AuthenticatedEncryptionMixin and DeterministicAuthenticatedEncryptionMixin.

How does it work?

To create an own Entity, just subclass from one of the Provided RedisEntity Base classes.
Note, that every Entity has to set the RedisClient Class Attribute to an instances of Redis from redis-py, or a class that supports all methods that Redis from redis-py does.

Under the hood all keys are stored as strings, and all values are stored as bytes in Redis.

RedisListEntity:

import redis
from redis_entities import RedisListEntity
from redis_entities.mixins import AuthenticatedEncryptionMixin
class JobQueueEntity(RedisListEntity, AuthenticatedEncryptionMixin):
    RedisClient = redis.Redis(...)
    Prefix = "JobQueue"
    AesKey = b"deaddeaddeaddeaddeaddeaddeaddead" # AES-128 in this case

JobQueueEntity.lpush("Worker1", "command1")
assert JobQueueEntity.length("Worker1") == 1

Supported Methods are:

  • lpush
  • brpop
  • lindex
  • length
  • clear

RedisSetEntity:

import redis
from redis_entities import RedisSetEntity
from redis_entities.mixins import DeterministicAuthenticatedEncryptionMixin
class AccessTokensEntity(RedisSetEntity, DeterministicAuthenticatedEncryptionMixin):
    RedisClient = redis.Redis(...)
    Prefix = "AccessTokens"
    Expire = 180
    AesKey = b"deaddeaddeaddeaddeaddeaddeaddeaddeaddeaddeaddeaddeaddeaddeaddead" # need to be twice the size of the key required by the underlying cipher (e.g. 64 bytes for AES-256)

AccessTokensEntity.add("User1", "Token1")
AccessTokensEntity.add("User2", "Token1")
assert AccessTokensEntity.exists("User1", "Token1") is True

Supported Methods are:

  • add
  • delete
  • clear
  • exists
  • list_all
  • length

NOTE: It is strongly recommended to use the DeterministicAuthenticatedEncryptionMixin instead of the AuthenticatedEncryptionMixin when you are working with RedisSetEntity , as most methods need to know the exact value that is stored in Redis. With the DeterministicAuthenticatedEncryptionMixin , the same plaintext results in the same ciphertext and thus makes this possible.

RedisHashmapEntity

import redis
from redis_entities import RedisHashmapEntity, 
from redis_entities.mixins import HashedIdentifierMixin, AuthenticatedEncryptionMixin
class VerifyEmailTokens(RedisHashmapEntity, HashedIdentifierMixin, AuthenticatedEncryptionMixin):
    RedisClient = redis.Redis(...)
    Prefix = "VerifyEmailTokens"
    Contents = (
        "MandatoryKey1",
        "MandatoryKey2"
    )
    Expire = 180
    HashName = "sha512_256"
    Salt = b"VerifyEmailTokens"
    AesKey = b"deaddeaddeaddeaddeaddeaddeaddead"

VerifyEmailTokens.store("test@example.com", MandatoryKey1="Value1", MandatoryKey2="Value2")
loaded_entity = VerifyEmailTokens.load("test@example.com")
assert loaded_entity.MandatoryKey1 == b"Value1"
assert loaded_entity.MandatoryKey1 == b"Value2"
assert VerifyEmailTokens.exists("test@example.com") is True

Supported Methods are:

  • store

  • load

  • exists

  • delete

  • length

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

redis_entities-1.0.8.tar.gz (6.5 kB view details)

Uploaded Source

Built Distribution

redis_entities-1.0.8-py3-none-any.whl (9.5 kB view details)

Uploaded Python 3

File details

Details for the file redis_entities-1.0.8.tar.gz.

File metadata

  • Download URL: redis_entities-1.0.8.tar.gz
  • Upload date:
  • Size: 6.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.0 CPython/3.10.4

File hashes

Hashes for redis_entities-1.0.8.tar.gz
Algorithm Hash digest
SHA256 1f424db079ac02909bacdc555482b8742f35a053082924da5438c04547910c2a
MD5 5a2abd497bb4ebf0e7325bfbdd073a1a
BLAKE2b-256 a77ed3dba2735ebf446eb628edf661d130791805803aeb42c050aa133fe1e995

See more details on using hashes here.

File details

Details for the file redis_entities-1.0.8-py3-none-any.whl.

File metadata

File hashes

Hashes for redis_entities-1.0.8-py3-none-any.whl
Algorithm Hash digest
SHA256 1a542d72cc79ea548482e55efb62be3b14cc8eb1691bc4e93efecb0c60653184
MD5 cd7e79f0ab3ca1ef497e4439426bb61b
BLAKE2b-256 6ae894ea61d54bf613580f98b39069f6250549a4edb4510acca22724ec2f4cb5

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page