Skip to main content

A simple session manager for aws lambda function using dynamodb

Project description

Session Lambda

A simple way to manage sessions for AWS Lambdas

Install

pip install session-lambda

Prerequisites

DynamoDB Table

  • A table in DynamoDB with a primary key named key with type string
  • [optional] Enable TTL in your DynamoDB table with attribute named ttl

Usage

Set SESSION_LAMBDA_DYNAMODB_TABLE_NAME env var:

export SESSION_LAMBDA_DYNAMODB_TABLE_NAME=<table-name>

Run the following python code:

import time
from session_lambda import session, set_session_data, get_session_data

@session
def lambda_handler(event, context):
    print(get_session_data())
    set_session_data((get_session_data() or 0)+1)
    return {"headers":{}}
# first client_a call 
response = lambda_handler({'headers':{}}, {})  
# get session id from response (created by the server)
session_id = response.get('headers').get('session-id')
# use session id in subsequent calls
lambda_handler({'headers':{'session-id':session_id}}, {})
lambda_handler({'headers':{'session-id':session_id}}, {})
lambda_handler({'headers':{'session-id':session_id}}, {})

# first client_b call 
lambda_handler({'headers':{}}, {})

You should get the following prints:

None
1
1
1
None

This time using the update=True mode:

import time
from session_lambda import session, set_session_data, get_session_data

@session(update=True)
def lambda_handler(event, context):
    print(get_session_data())
    set_session_data((get_session_data() or 0)+1)
    return {"headers":{}}
# first client_a call 
response = lambda_handler({'headers':{}}, {})  
# get session id from response (created by the server)
session_id = response.get('headers').get('session-id')
# use session id in subsequent calls
lambda_handler({'headers':{'session-id':session_id}}, {})
lambda_handler({'headers':{'session-id':session_id}}, {})
lambda_handler({'headers':{'session-id':session_id}}, {})

# first client_b call 
lambda_handler({'headers':{}}, {})

Now you should see:

None
1
2
3
None

Features

@session(id_key_name='session-id', update=False, ttl=0)
def lambda_handler(event, context):
    ...
  • id_key_name is the expected key name in the event[headers]. It is default to session-id. It is case-sensitive.
  • update flag control weather set_sessions_data updates the data. It is default to False.
  • ttl is seconds interval for the session to live (since the last update time). By default it is disabled. Any value larger then 0 will enable this feature. Make sure to set the TTL key name in your dynamodb to ttl.

Future Features

  • Support Schema validation for session data

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

session_lambda-0.3.5.tar.gz (5.9 kB view details)

Uploaded Source

Built Distribution

session_lambda-0.3.5-py3-none-any.whl (7.1 kB view details)

Uploaded Python 3

File details

Details for the file session_lambda-0.3.5.tar.gz.

File metadata

  • Download URL: session_lambda-0.3.5.tar.gz
  • Upload date:
  • Size: 5.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.9.5 Darwin/21.1.0

File hashes

Hashes for session_lambda-0.3.5.tar.gz
Algorithm Hash digest
SHA256 9979cf320b255e10da3e7f90c96b0d4049e4ce65c371553b89a795d0330298ad
MD5 996e18e35e1914ef3d7052f3dd4f5919
BLAKE2b-256 5377832f18e2a00ee7fb05b82f95a5e97b5a795394ba8e8061c2cb3636492b48

See more details on using hashes here.

Provenance

File details

Details for the file session_lambda-0.3.5-py3-none-any.whl.

File metadata

  • Download URL: session_lambda-0.3.5-py3-none-any.whl
  • Upload date:
  • Size: 7.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.9.5 Darwin/21.1.0

File hashes

Hashes for session_lambda-0.3.5-py3-none-any.whl
Algorithm Hash digest
SHA256 2fba64a2ea270fe11d11c0e5ed0615c88ebc88704b572135e8624b3570e8ce20
MD5 aecaa1fb3ca169ab49a509179cec49a3
BLAKE2b-256 5fd16a9d55a97f0410118acd08964edb1b3a0b2cada14995c026f4824d087a20

See more details on using hashes here.

Provenance

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