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.6.tar.gz (19.7 kB view details)

Uploaded Source

Built Distribution

dynamodb_session_web-0.2.6-py3-none-any.whl (31.6 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for dynamodb-session-web-0.2.6.tar.gz
Algorithm Hash digest
SHA256 b1f3e3794c3080aec66b3362db50c238971faa4cf0747adf638b13a9a3acd33f
MD5 d470a0a677c98ea96501615d9bc69c46
BLAKE2b-256 50daf62b8b71dbc314ff938315b0147ac790cc8b73dc316d922a6e522c75f5a3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for dynamodb_session_web-0.2.6-py3-none-any.whl
Algorithm Hash digest
SHA256 5902566b1691050cbaeb5eee605f3c527c4d817d01128b8701fea89319cbc93c
MD5 a611354dc9b6a2b0a63ef9fb9f10a3c3
BLAKE2b-256 a8bdbe32b428a742b5f9e802f8c71343e89a1c201a189033e04e48f67ad87392

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