DynamoDB easy library for Lambda functions.
Documentación completa en https://github.com/javichur/dynamola/blob/master/docs/index.md
- Buscar elementos en una tabla DynamoDB (por Clave de Partición, por Clave de Ordenación, por Índice Local Secundario (LSI), Por Índice Global Secundario (GSI), por rango, por Clave de Ordenación que "empieza por", etc...).
- Obtener valor máximo de la Clave de Ordenación de una tabla o de un LSI.
- Añadir elementos en una tabla DynamoDB.
- Borrar elementos de una tabla DynamoDB.
- Actualizar un elemento de una tabla DynamoDB.
- Incrementar el valor de un atributo de un elemento, de una tabla DynamoDB.
- Crear tablas sencillas, con o sin Clave de Ordenación.
- Crear tablas sencillas, con o sin Índice Local Secundario (LSI).
- Crear tablas sencillas, con o sin Índice Global Secundario (GSI).
const Dynamola = require('dynamola');
let myDb = new Dynamola("nombre-tabla-en-dynamodb", "nombre-primary-key-en-tabla-dynamodb", null);
myDb.getItem(userID).then((data) => {
if(!data){
// item no existe
}
else {
// item devuelto OK
}
})
.catch((err) => {
// error al acceder a dynamodb
});
-
Crea tu tabla DynamoDB desde https://console.aws.amazon.com/dynamodb, indicando nombre de la tabla, nombre de la clave de partición (Partition Key) y opcionalmente: el nombre de la clave de ordenación (Sort Key), Índices Secundarios Locales (LSI).
-
Opciones de acceso: a. Si vas a acceder a la tabla DynamoDB desde AWS (por ejemplo, desde una función AWS Lambda), crea una política de seguridad (https://console.aws.amazon.com/iam/home#/policies), que tenga acceso limitado a tu tabla DynamoDB. A continuación, añade la política recién creada al rol de ejecución de la función AWS Lambda (https://console.aws.amazon.com/iam/home?#/roles).Ejemplo de política de seguridad:
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "VisualEditor0",
"Effect": "Allow",
"Action": [
"dynamodb:PutItem",
"dynamodb:DeleteItem",
"dynamodb:GetItem",
"dynamodb:Scan",
"dynamodb:Query",
"dynamodb:UpdateItem"
],
"Resource": "<ARN de tu tabla DynamoDB>"
}
]
}
b. Si quieres acceder a la tabla DynamoDB desde fuera de Amazon Web Services, puedes utilizar un fichero de credenciales compartidas (https://docs.aws.amazon.com/es_es/sdk-for-javascript/v2/developer-guide/setting-credentials-node.html). Este método se usa por ejemplo en los tests de este módulo.
Puedes probar en local descargando la herramienta "DynamoDB Local" (https://docs.aws.amazon.com/es_es/amazondynamodb/latest/developerguide/DynamoDBLocal.DownloadingAndRunning.html):
java -Djava.library.path=./DynamoDBLocal_lib -jar DynamoDBLocal.jar -sharedDb
En windows:
java -D"java.library.path"=./DynamoDBLocal_lib -jar DynamoDBLocal.jar -sharedDb
- Clave de Partición (Partition Key).
- Clave de Ordenación (Sort Key).
- Clave Principal Simple (Simple Primary Key). Formada solo por Clave de Partición.
- Clave Principal Compuesta (Composite Primary Key). Formada por una Clave de Partición y una Clave de Ordenación.
- Índice Secundario Local (LSI). Un índice que tiene la misma Clave de Partición que la tabla base, pero una clave de ordenación diferente.
- Índice Secundario Global (GSI). Un índice con una clave de partición y opcionalmente una clave de ordenación que pueden diferir de las claves de la tabla base.
https://github.com/javichur/alexa-skill-clean-code-template
https://github.com/javichur/Alexa-Skill-Lavaplatos
https://github.com/javichur/alexa-skill-nevera-estado/