-
Notifications
You must be signed in to change notification settings - Fork 120
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support Map, List and Bool type #44
Conversation
MapMap can be declared for any attributes, except for hash and range keys. var Photo = vogels.define('Photo', function (schema) {
schema.String('userid', {hashKey: true});
schema.Map('tags');
});
Photo.create({userid:'john', tags: {emily: {x:10, y:8}}}, console.log); Map can recursively define its schema: var Photo = vogels.define('Photo', function (schema) {
schema.String('userid', {hashKey: true});
schema.Map('location', function(schema) {
schema.String('name');
schema.Number('latitude');
schema.Number('longitude');
});
}); ListList can be declared for any attributes, except for hash and range keys. var Photo = vogels.define('Photo', function (schema) {
schema.String('userid', {hashKey: true});
schema.List('likes');
});
Photo.create({userid:'john', likes: ['emily']}, console.log); List can define schema of its element: var Photo = vogels.define('Photo', function (schema) {
schema.String('userid', {hashKey: true});
schema.List('likes', function(schema) {
schema.String('userid');
schema.Date('likedAt');
});
}); |
Any chance this pull request will make it in to master? |
I haven't had a chance to work much on this lib, but am planning on getting full document support working over the holidays. I have partial support working in a separate branch, which isn't completely fleshed out yet. Amazon has released a number of new features to DynamoDB in the past couple of months and unfortunately the current api exposed with vogels makes it impossible to fully utilize these new features. Part of the document support will include a modified way of defining schema to get access to all the new features as well as hopefully better support new DynamoDB features in the future. tl;dr - No, this will not make it into master, but will offer full document support in the near future |
1 similar comment
I haven't had a chance to work much on this lib, but am planning on getting full document support working over the holidays. I have partial support working in a separate branch, which isn't completely fleshed out yet. Amazon has released a number of new features to DynamoDB in the past couple of months and unfortunately the current api exposed with vogels makes it impossible to fully utilize these new features. Part of the document support will include a modified way of defining schema to get access to all the new features as well as hopefully better support new DynamoDB features in the future. tl;dr - No, this will not make it into master, but will offer full document support in the near future |
Hi, that is great news. Looking forward to these changes! |
Looking forward to this as well! |
Ryan, Any ETA on document support? Trying to decide whether to consider this module for inclusion in a Q2 2015 project. |
@keithchilders I'm looking to get a beta version ready by end of this week |
@ryanfitz You are the man, thanks! Can't wait to see the new schema API. |
@keithchilders @winduptoy If you want to take a look, I've pushed up the new json document support branch. I'm still working on updating the README. Most of the examples have been updates, but I still have a few that needed updating to the new api. The only change for a user is the new way models get defined, all other apis remain the same. Takes no more than a minute to migrate from the old schema define api to the new configuration based api. There are still a few outstanding issues (mostly related to updating nested items), but let me know of any feedback you have. |
@ryanfitz I will take a look today. Thanks! |
Ryan, As you iterate on this would you mind publishing it to npm as 3.0-betaX? It makes pulling in dependencies a lot easier. |
@ryanfitz Also I like what you're doing with using the Joi module to handle schema validation, default values, etc. I especially like that it uses a chainable API. But, since you're also using your own vogels.types, it would be great if you could maybe wrap the Joi types in a matching vogels.types item so I don't need to remember which type goes with which type library. You could just throw errors on all the Joi methods you don't expose for your own types? I enjoyed being able to define my own model pseudo-dialect in pure JSON then pass that into some middleware for transforming it to the appropriate vogels constructs and spitting out a vogels model. That's a lot harder to do now that the types aren't described in object keys anymore but in chained method calls. |
@keithchilders Im planning on getting an rc1 build out later on tonight or tomorrow. I'll let you know once its out. As for custom types and wrapping joi types, if you look at the code its actually 100% Joi under the hood, its simply some syntax sugar to declare Sets and UUIDs a bit more easily. With the old schema api, I was wrapping joi types and this lead to a number of major pain points. The joi module moves very quickly and keeping up with their changes its extremely difficult. One of my main goals with this new api is to allow users to update their joi module independently of vogels. I do agree that its a bit odd to expose a few custom types and not expose the basic types. I don't know the best solution for this, but I am opposed to wrapping Joi. The new define api is now 100% JSON, the schema param is actually completely optional and it even supports unknown keys (if you configure it to accept unknown). I don't know how your current pseudo dialect works, but I would think it should actually be much easier to implement with the new api. |
Tell me more about how to define schema without chaining Joi methods together! That will make me happy :) Here's some example psuedo dialect based on your previous API: key: {type: 'String', required: true}, All I had to do before was pass my string 'type' as your schema[type] method and invoke it. Now I have to know ahead of time whether stringSet() is a Joi type or or vogels.types type, and there are two sets of supported attributes per-type (default, required, etc.) I also don't love having to require Joi from outside my model; I'd much rather use it at the dependency level you specify in the vogels version I'm using, plus if the models are vogels models it seems like the vogels package should contain everything they need to instantiate them, so at least something like vogels.Joi as a reference to your dependency that I could bring in rather than a separate require of Joi at a version that may or may not be compatible would be preferable from my perspective. I have moved this feature request into your 3.0 release notes issue, which I figured would be more visible to all your users than this rejected pull request thread :) |
New Features * Full JSON document support, including support for List, Map, and BOOL datatypes. Closes #16, #44 * New timestamps config option to automatically add the attributes createdAt and updatedAt when defining a model. These attributes will get automatically get set when you create and update a record. * Flexible schema configuration to allow unknown, dynamic attributes both on top level and nested records * Ability to fully configure global and local secondary indexes. Allows to configure index names, attribute projection settings and index throughput. Closes #43 , #48 * adding deleteTable api to remove the table from DynamoDB. Closes #10 * 100% code coverage with new integration test suite and integration with travis-ci. Bug Fixes * CreateTables checks if error occurs while attempting to create a table. Fixes #41 * Fixed error handling when streaming query, scan and parallel scan requests. * Fixed retry handling when running query and scans. Fixes #45 Updated dependencies * Joi to v5.1.0 * aws-sdk to v2.1.5 - Closes #49 * async to v0.9.0 * lodash to v2.4.1
New Features * Full JSON document support, including support for List, Map, and BOOL datatypes. Closes #16 and Closes #44 * New timestamps config option to automatically add the attributes createdAt and updatedAt when defining a model. These attributes will get automatically get set when you create and update a record. * Flexible schema configuration to allow unknown, dynamic attributes both on top level and nested records * Ability to fully configure global and local secondary indexes. Allows to configure index names, attribute projection settings and index throughput. Closes #43 , #48 * adding deleteTable api to remove the table from DynamoDB. Closes #10 * 100% code coverage with new integration test suite and integration with travis-ci. Bug Fixes * CreateTables checks if error occurs while attempting to create a table. Fixes #41 * Fixed error handling when streaming query, scan and parallel scan requests. * Fixed retry handling when running query and scans. Fixes #45 Updated dependencies * Joi to v5.1.0 * aws-sdk to v2.1.5 - Closes #49 * async to v0.9.0 * lodash to v2.4.1
New Features * Full JSON document support, including support for List, Map, and BOOL datatypes. Closes #16, #44 * New timestamps config option to automatically add the attributes createdAt and updatedAt when defining a model. These attributes will get automatically get set when you create and update a record. * Flexible schema configuration to allow unknown, dynamic attributes both on top level and nested records * Ability to fully configure global and local secondary indexes. Allows to configure index names, attribute projection settings and index throughput. Closes #43 , #48 * adding deleteTable api to remove the table from DynamoDB. Closes #10 * 100% code coverage with new integration test suite and integration with travis-ci. Bug Fixes * CreateTables checks if error occurs while attempting to create a table. Fixes #41 * Fixed error handling when streaming query, scan and parallel scan requests. * Fixed retry handling when running query and scans. Fixes #45 Updated dependencies * Joi to v5.1.0 * aws-sdk to v2.1.5 - Closes #49 * async to v0.9.0 * lodash to v2.4.1
New Features * Full JSON document support, including support for List, Map, and BOOL datatypes. Closes #16, #44 * New timestamps config option to automatically add the attributes createdAt and updatedAt when defining a model. These attributes will get automatically get set when you create and update a record. * Flexible schema configuration to allow unknown, dynamic attributes both on top level and nested records * Ability to fully configure global and local secondary indexes. Allows to configure index names, attribute projection settings and index throughput. Closes #43 , #48 * adding deleteTable api to remove the table from DynamoDB. Closes #10 * 100% code coverage with new integration test suite and integration with travis-ci. Bug Fixes * CreateTables checks if error occurs while attempting to create a table. Fixes #41 * Fixed error handling when streaming query, scan and parallel scan requests. * Fixed retry handling when running query and scans. Fixes #45 Updated dependencies * Joi to v5.1.0 * aws-sdk to v2.1.5 - Closes #49 * async to v0.9.0 * lodash to v2.4.1
New Features * Full JSON document support, including support for List, Map, and BOOL datatypes. Closes #16, #44 * New timestamps config option to automatically add the attributes createdAt and updatedAt when defining a model. These attributes will get automatically get set when you create and update a record. * Flexible schema configuration to allow unknown, dynamic attributes both on top level and nested records * Ability to fully configure global and local secondary indexes. Allows to configure index names, attribute projection settings and index throughput. Closes #43 , #48 * adding deleteTable api to remove the table from DynamoDB. Closes #10 * 100% code coverage with new integration test suite and integration with travis-ci. Bug Fixes * CreateTables checks if error occurs while attempting to create a table. Fixes #41 * Fixed error handling when streaming query, scan and parallel scan requests. * Fixed retry handling when running query and scans. Fixes #45 Updated dependencies * Joi to v5.1.0 * aws-sdk to v2.1.5 - Closes #49 * async to v0.9.0 * lodash to v2.4.1
New Features * Full JSON document support, including support for List, Map, and BOOL datatypes. Closes #16, #44 * New timestamps config option to automatically add the attributes createdAt and updatedAt when defining a model. These attributes will get automatically get set when you create and update a record. * Flexible schema configuration to allow unknown, dynamic attributes both on top level and nested records * Ability to fully configure global and local secondary indexes. Allows to configure index names, attribute projection settings and index throughput. Closes #43 , #48 * adding deleteTable api to remove the table from DynamoDB. Closes #10 * 100% code coverage with new integration test suite and integration with travis-ci. Bug Fixes * CreateTables checks if error occurs while attempting to create a table. Fixes #41 * Fixed error handling when streaming query, scan and parallel scan requests. * Fixed retry handling when running query and scans. Fixes #45 Updated dependencies * Joi to v5.1.0 * aws-sdk to v2.1.5 - Closes #49 * async to v0.9.0 * lodash to v2.4.1
New Features * Full JSON document support, including support for List, Map, and BOOL datatypes. Closes #16, #44 * New timestamps config option to automatically add the attributes createdAt and updatedAt when defining a model. These attributes will get automatically get set when you create and update a record. * Flexible schema configuration to allow unknown, dynamic attributes both on top level and nested records * Ability to fully configure global and local secondary indexes. Allows to configure index names, attribute projection settings and index throughput. Closes #43 , #48 * adding deleteTable api to remove the table from DynamoDB. Closes #10 * 100% code coverage with new integration test suite and integration with travis-ci. Bug Fixes * CreateTables checks if error occurs while attempting to create a table. Fixes #41 * Fixed error handling when streaming query, scan and parallel scan requests. * Fixed retry handling when running query and scans. Fixes #45 Updated dependencies * Joi to v5.1.0 * aws-sdk to v2.1.5 - Closes #49 * async to v0.9.0 * lodash to v2.4.1
Commit 6d5e70e adds full document support |
DynamoDB now supports to store entire JSON-formatted documents as single items.
http://aws.amazon.com/jp/blogs/aws/dynamodb-update-json-and-more/
In this update, following new attribute types have been added:
This pull request adds a feature to support Map, List and Boolean type of attribute.
In Map and List attribute, it currently does not validate its content format.