Skip to main content

Contains the core API for a DynamoDB-backed session

Project description

dynamodb-session-web

An implementation of a "web" session using DynamoDB as backend storage. This project has the following goals:

  • Focus on core session handling concerns, rather than specific Python frameworks.
  • Follow OWASP Session Management best practices by default. Specifically, best practices for:
    • Session ID
      • Length, value, and entropy: ID is a 32-byte secure random number.
      • Strict session management: ID generation can only occur within the framework.
      • Treat as sensitive: A "loggable session ID" is provided as a property in order to make logging the ID easier (if desired).
    • Timeouts
      • Absolute session timeout - default of 12 hours
      • Idle session timeout - default of 2 hours
      • Manual session timeout - i.e. there's delete/clear support

Usage

Requires a DynamoDB table named app_session (can be changed in settings)

Create session table

aws dynamodb create-table \
    --attribute-definitions \
        AttributeName=id,AttributeType=S \
    --key-schema "AttributeName=id,KeyType=HASH" \
    --provisioned-throughput "ReadCapacityUnits=5,WriteCapacityUnits=5" \
    --table-name app_session 

Default Example

from dynamodb_session_web import SessionManager

session = SessionManager()

# Create a new session object, get the ID for later use
initial_data = session.create()
session_id = initial_data.session_id

initial_data['foo'] = 'bar'
initial_data['one'] = 1
session.save(initial_data)

print(session_id)
#> 'WaHnSSou4d5Rq0k11vFGafe4sjMrkwiVhNziIWLLwMc'
print(initial_data.loggable_session_id)
#> '517286da2682be08dc9975612dc86d65487f0990906656f631d419e64dcda6f41f5e0529c290663be315524a0b35777645e0e827d2e982a048b5e2b4bba4e02b'

loaded_data = session.load(session_id)
print(loaded_data['foo'])
#> 'bar'
print(loaded_data['one'])
#> 1

session.clear(session_id)

Configurable Timeout and NullSession Response

from time import sleep
from dynamodb_session_web import SessionManager

session = SessionManager()

# Create a new session object, get the ID for later use
initial_data = session.create()
initial_data.idle_timeout_seconds = 30
initial_data.absolute_timeout_seconds = 30
session_id = initial_data.session_id

initial_data['foo'] = 'bar'
session.save(initial_data)

sleep(35)

loaded_data = session.load(session_id)
print(loaded_data)
#> <dynamodb_session_web.NullSessionInstance object at 0x109a7da30>

Custom Data Class Example

import json
from dataclasses import asdict, dataclass

from dynamodb_session_web import SessionInstanceBase, SessionManager

@dataclass
class MySession(SessionInstanceBase):
    fruit: str = ''
    color: str = ''

    def __init__(self, **kwargs):
        super().__init__(**kwargs)

    def deserialize(self, data):
        data_dict = json.loads(data)
        self.fruit = data_dict['fruit']
        self.color = data_dict['color']

    def serialize(self):
        return json.dumps(asdict(self))

session = SessionManager(MySession)

# Create a new session object, get the ID for later use
initial_data = session.create()
session_id = initial_data.session_id

initial_data.fruit = 'apple'
initial_data.color = 'red'
session.save(initial_data)

loaded_data = session.load(session_id)
print(loaded_data.fruit)
#> 'apple'
print(loaded_data.color)
#> 'red'

session.clear(session_id)

Configuration

Several behaviors can be configured at the Session Manager level:

  • Custom data class; must provide serialization and deserialization methods (see examples). Defaults to a dictionary.
  • Session ID length. Defaults to 32 bytes.
  • Table name. Defaults to app_session
  • DynamoDB URL. Defaults to None (i.e. Boto3 logic).
  • Idle session timeout (in seconds). Defaults to 7200 seconds (2 hours).
  • Absolute session timeout (in seconds). Defaults to 43200 seconds (12 hours).
from dynamodb_session_web import SessionInstanceBase, SessionManager

class MyCustomDataClass(SessionInstanceBase):
    def deserialize(self, data: str):
        pass

    def serialize(self) -> str:
        pass

SessionManager(
    MyCustomDataClass,
    sid_byte_length=128,
    table_name='my-dynamodb-table',
    endpoint_url='http://localhost:8000',
    idle_timeout_seconds=300,
    absolute_timeout_seconds=3600,
)

Additionally, individual session instances can have their own idle and absolute timeouts, specified in seconds:

from dynamodb_session_web import SessionManager

session = SessionManager()

instance = session.create()
instance.idle_timeout_seconds = 30
instance.absolute_timeout_seconds = 30

Development

Prerequisites:

  • Docker

Tests

The integration tests will use the docker-compose.yml file to create a local DynamoDB instance.

Useful Things

Get a record from local DynamoDB instance

export sid=Jh4f1zvVp9n-YaDbkpZ0Vtru6iCXnERZv40q_ocZ7BA
aws dynamodb query --table-name app_session --endpoint-url http://localhost:8000 \
  --key-condition-expression 'id = :id' \
  --expression-attribute-values '{ ":id": {"S": "'$sid'" }}'

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

dynamodb-session-web-0.2.0.tar.gz (19.1 kB view details)

Uploaded Source

Built Distribution

dynamodb_session_web-0.2.0-py3-none-any.whl (30.7 kB view details)

Uploaded Python 3

File details

Details for the file dynamodb-session-web-0.2.0.tar.gz.

File metadata

  • Download URL: dynamodb-session-web-0.2.0.tar.gz
  • Upload date:
  • Size: 19.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.9.10 Darwin/20.6.0

File hashes

Hashes for dynamodb-session-web-0.2.0.tar.gz
Algorithm Hash digest
SHA256 454a0f68e1402fd9e35d77f681a06bf555f91740491ed559dbb079b0a508ab0c
MD5 2f6e496427f0091ca8fdf0cce8c581cb
BLAKE2b-256 8ec51e3f9b3a4243a2d4c34c43487e1d1290285ce69f3a3e363faaec182d0d45

See more details on using hashes here.

File details

Details for the file dynamodb_session_web-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for dynamodb_session_web-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d21c2854a7b8900d8661313719aa84cf7a6e656e8bd61bcb030dcc11548f7d17
MD5 0d39ba5c7210b4e056c0291fe0bbb02d
BLAKE2b-256 9bf20cbb99e7b3a8394b520f04abf51e29f614b6221336a1d0c973a109471c17

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