Crynamo
Crynamo is a simple interface to Amazon's DynamoDB written in Crystal. Right now it is a fairly low-level wrapper that provides type marshalling between your Crystal program and DynamoDB.
- ✔️ Simple API with get,put, anddeletesupport
- ✔️ DynamoDB type marshalling
- ✔️ Native exceptions for every AWS error
- ✔️ Non-blocking
Installation
Add this to your application's shard.yml:
dependencies:
  crynamo:
    github: timkendall/crynamo
    version: ~> 0.1.1Usage
Configuration
require "crynamo"
config = Crynamo::Configuration.new(
  access_key_id: "aws-access-key",
  secret_access_key: "aws-secret-key",
  region: "us-east-1",
  endpoint: "http://localhost:8000",
)
dynamodb = Crynamo::Client.new(config)
Client
Crynamo exposes Crynamo::Client as a basic DynamoDB client. The client's API is low-level and mimics the base DynamoDB Low-Level HTTP API.
# Get an item
dynamodb.get!("pets", { name: "Doobie" })
# Insert an item
dynamodb.put!("pets", { name: "Thor", lifespan: 100 })
# Remove an item
dynamodb.delete!("pets", { name: "Doobie" })Development
- Follow the instructions here to setup Local DynamoDB
- Install Crystal deps with shards install
- Use icr to play with things
Tip
It's useful to define a bash command for launching DynamoDB. Add this to your .bash_profile to start DynamoDB with a simple dynamodb command.
dynamodb() {
 cd /path/to/dynamodb
 java -Djava.library.path=./DynamoDBLocal_lib -jar DynamoDBLocal.jar -sharedDb
}Contributing
- Fork it ( https://github.com/[your-github-name]/crynamo/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
Contributors
- timkendall - creator, maintainer