Service - Table Config: Difference between revisions
Jump to navigation
Jump to search
No edit summary |
|||
| (One intermediate revision by the same user not shown) | |||
| Line 9: | Line 9: | ||
= DynamoDB tables = | = DynamoDB tables = | ||
== | == ObjectSchema == | ||
=== TableConfig === | |||
=== | |||
<syntaxhighlight lang="JavaScript"> | <syntaxhighlight lang="JavaScript"> | ||
{ | [ | ||
{ | |||
objectType: "tableConfig", | |||
storageResources: { | |||
}, | "dynamodb": { | ||
storageType: "dynamoDB", | |||
tableName: "TableConfigMain", | |||
} | |||
}, | |||
fieldNames: { | |||
tableConfigId: { | |||
type: "string", | |||
randomOnCreate: true, | |||
requiredOnCreate: false, | |||
optionalOnCreate: false, | |||
canUpdate: false, | |||
storageResourceTags: ['dynamodb'], | |||
}, | |||
tableConfig: { | |||
type: "object", | |||
randomOnCreate: false, | |||
requiredOnCreate: true, | |||
optionalOnCreate: false, | |||
canUpdate: true, | |||
storageResourceTags: ['dynamodb'], | |||
}, | |||
tableConfigName: { | |||
type: "string", | |||
randomOnCreate: false, | |||
requiredOnCreate: true, | |||
optionalOnCreate: false, | |||
canUpdate: true, | |||
storageResourceTags: ['dynamodb'], | |||
}, | |||
userId: { | |||
type: "string", | |||
randomOnCreate: false, | |||
requiredOnCreate: true, | |||
optionalOnCreate: false, | |||
canUpdate: false, | |||
storageResourceTags: ['dynamodb'], | |||
}, | |||
}, | |||
identifiers: [ | |||
{ | |||
type: "partitionKey", | |||
fieldNames: "tableConfigId" | |||
}, | |||
], | |||
}, | |||
] | |||
</syntaxhighlight> | </syntaxhighlight> | ||
| Line 25: | Line 69: | ||
<syntaxhighlight lang="JavaScript"> | <syntaxhighlight lang="JavaScript"> | ||
{ | { | ||
tableConfigId: "xx", // | tableConfigId: "xx", // {random uuid} | ||
tableConfig: "xx", // json encoded object of configuration | tableConfig: "xx", // json encoded object of configuration | ||
tableConfigName: "yy", // user specified name of the config | tableConfigName: "yy", // user specified name of the config | ||
| Line 34: | Line 78: | ||
* partition key: tableConfigId | * partition key: tableConfigId | ||
* sort key: {none} | * sort key: {none} | ||
== UsersTableConfigs == | == UsersTableConfigs == | ||
Latest revision as of 02:38, 17 July 2025
Overview
Manages configuration for presentation tables created by users and used in different areas of the project.
Repository
https://bitbucket.org/izara-core-shared/izara-core-shared-table-config
DynamoDB tables
ObjectSchema
TableConfig
[
{
objectType: "tableConfig",
storageResources: {
"dynamodb": {
storageType: "dynamoDB",
tableName: "TableConfigMain",
}
},
fieldNames: {
tableConfigId: {
type: "string",
randomOnCreate: true,
requiredOnCreate: false,
optionalOnCreate: false,
canUpdate: false,
storageResourceTags: ['dynamodb'],
},
tableConfig: {
type: "object",
randomOnCreate: false,
requiredOnCreate: true,
optionalOnCreate: false,
canUpdate: true,
storageResourceTags: ['dynamodb'],
},
tableConfigName: {
type: "string",
randomOnCreate: false,
requiredOnCreate: true,
optionalOnCreate: false,
canUpdate: true,
storageResourceTags: ['dynamodb'],
},
userId: {
type: "string",
randomOnCreate: false,
requiredOnCreate: true,
optionalOnCreate: false,
canUpdate: false,
storageResourceTags: ['dynamodb'],
},
},
identifiers: [
{
type: "partitionKey",
fieldNames: "tableConfigId"
},
],
},
]
TableConfigMain
{
tableConfigId: "xx", // {random uuid}
tableConfig: "xx", // json encoded object of configuration
tableConfigName: "yy", // user specified name of the config
userId: "xx"
}
- partition key: tableConfigId
- sort key: {none}
UsersTableConfigs
{
userId: "xx" // user who owns the tableConfig
tableConfigId: "xx",
}
- partition key: userId
- sort key: tableConfigId