Skip to main content

SDK for Momento

Project description

logo

project status project stability

Momento Python Client Library

Momento Cache is a fast, simple, pay-as-you-go caching solution without any of the operational overhead required by traditional caching solutions. This repo contains the source code for the Momento Python client library.

To get started with Momento you will need a Momento Auth Token. You can get one from the Momento Console.

Packages

The Momento Python SDK package is available on pypi: momento.

Usage

The examples below require an environment variable named MOMENTO_API_KEY which must be set to a valid Momento API key. You can get one from the Momento Console.

Python 3.10 introduced the match statement, which allows for structural pattern matching on objects. If you are running python 3.10 or greater, here is a quickstart you can use in your own project:

from datetime import timedelta

from momento import CacheClient, Configurations, CredentialProvider
from momento.responses import CacheGet

cache_client = CacheClient(
    Configurations.Laptop.v1(), CredentialProvider.from_environment_variable("MOMENTO_API_KEY"), timedelta(seconds=60)
)

cache_client.create_cache("cache")
cache_client.set("cache", "my-key", "my-value")
get_response = cache_client.get("cache", "my-key")
match get_response:
    case CacheGet.Hit() as hit:
        print(f"Got value: {hit.value_string}")
    case _:
        print(f"Response was not a hit: {get_response}")

The above code uses structural pattern matching, a feature introduced in Python 3.10. Using a Python version less than 3.10? No problem. Here is the same example compatible across all versions of Python:

from datetime import timedelta

from momento import CacheClient, Configurations, CredentialProvider
from momento.responses import CacheGet

cache_client = CacheClient(
    configuration=Configurations.Laptop.v1(),
    credential_provider=CredentialProvider.from_environment_variable("MOMENTO_API_KEY"),
    default_ttl=timedelta(seconds=60),
)
cache_client.create_cache("cache")
cache_client.set("cache", "myKey", "myValue")
get_response = cache_client.get("cache", "myKey")
if isinstance(get_response, CacheGet.Hit):
    print(f"Got value: {get_response.value_string}")

Getting Started and Documentation

Documentation is available on the Momento Docs website.

Examples

Working example projects, with all required build configuration files, are available for both Python 3.10 and up and Python versions before 3.10:

Developing

If you are interested in contributing to the SDK, please see the CONTRIBUTING docs.


For more info, visit our website at https://gomomento.com!

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

momento-1.21.1.tar.gz (73.3 kB view details)

Uploaded Source

Built Distribution

momento-1.21.1-py3-none-any.whl (118.1 kB view details)

Uploaded Python 3

File details

Details for the file momento-1.21.1.tar.gz.

File metadata

  • Download URL: momento-1.21.1.tar.gz
  • Upload date:
  • Size: 73.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.12.3 Linux/6.8.0-1014-azure

File hashes

Hashes for momento-1.21.1.tar.gz
Algorithm Hash digest
SHA256 15b1c571e3c469057a96e893e1e105e164365f3a3c43f63fa93f8dbdcc864d28
MD5 a9a057c76d461f89b514873c168d1313
BLAKE2b-256 83b4383ffb3f20b58895522dae91fe0e40e61748dc86e658a931bf18876a728c

See more details on using hashes here.

File details

Details for the file momento-1.21.1-py3-none-any.whl.

File metadata

  • Download URL: momento-1.21.1-py3-none-any.whl
  • Upload date:
  • Size: 118.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.1 CPython/3.12.3 Linux/6.8.0-1014-azure

File hashes

Hashes for momento-1.21.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d3044a2fe4f61cd9263f4571c99de5480707c20f8f9e45db8c66ed1d6d27cf82
MD5 6c9c05b0fb869518069783004ac76bcb
BLAKE2b-256 84febd86b33a07ccfde2bb77e9f07c837b5ade4158af49a7bf252504a42a2e63

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