#7 'Single record' type initialise

This commit is contained in:
Michael Shanks 2019-11-03 11:26:21 +00:00
parent 2646d7c69e
commit 8cad5e72fe
6 changed files with 50 additions and 30 deletions

View File

@ -5,7 +5,8 @@ import { AUTH_FOLDER, USERS_LIST_FILE, ACCESS_LEVELS_FILE } from '../authApi/aut
import { initialiseRootCollections } from '../collectionApi/initialise'; import { initialiseRootCollections } from '../collectionApi/initialise';
import { initialiseIndex } from '../indexing/initialiseIndex'; import { initialiseIndex } from '../indexing/initialiseIndex';
import { getFlattenedHierarchy, isGlobalIndex, isSingleRecord } from '../templateApi/hierarchy'; import { getFlattenedHierarchy, isGlobalIndex, isSingleRecord } from '../templateApi/hierarchy';
import { _getNew } from "../recordApi/getNew";
import { _save } from "../recordApi/save";
export const initialiseData = async (datastore, applicationDefinition, accessLevels) => { export const initialiseData = async (datastore, applicationDefinition, accessLevels) => {
await datastore.createFolder(configFolder); await datastore.createFolder(configFolder);
@ -14,8 +15,6 @@ export const initialiseData = async (datastore, applicationDefinition, accessLev
await initialiseRootCollections(datastore, applicationDefinition.hierarchy); await initialiseRootCollections(datastore, applicationDefinition.hierarchy);
await initialiseRootIndexes(datastore, applicationDefinition.hierarchy); await initialiseRootIndexes(datastore, applicationDefinition.hierarchy);
await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy);
await datastore.createFolder(TRANSACTIONS_FOLDER); await datastore.createFolder(TRANSACTIONS_FOLDER);
await datastore.createFolder(AUTH_FOLDER); await datastore.createFolder(AUTH_FOLDER);
@ -25,6 +24,8 @@ export const initialiseData = async (datastore, applicationDefinition, accessLev
await datastore.createJson( await datastore.createJson(
ACCESS_LEVELS_FILE, ACCESS_LEVELS_FILE,
accessLevels ? accessLevels : { version: 0, levels: [] }); accessLevels ? accessLevels : { version: 0, levels: [] });
await initialiseRootSingleRecords(datastore, applicationDefinition.hierarchy);
}; };
const initialiseRootIndexes = async (datastore, hierarchy) => { const initialiseRootIndexes = async (datastore, hierarchy) => {
@ -38,20 +39,20 @@ const initialiseRootIndexes = async (datastore, hierarchy) => {
} }
}; };
const initialiseRootSingleRecords = async (datastore, hierachy) => { const initialiseRootSingleRecords = async (datastore, hierarchy) => {
const flathierarchy = getFlattenedHierarchy(hierachy); const app = {
publish:()=>{},
cleanupTransactions: () => {},
datastore, hierarchy
};
const flathierarchy = getFlattenedHierarchy(hierarchy);
const singleRecords = $(flathierarchy, [ const singleRecords = $(flathierarchy, [
filter(isSingleRecord), filter(isSingleRecord),
]); ]);
/* for (let record of singleRecords) { for (let record of singleRecords) {
const result = getNew({ datastore: datastore, hierarchy: appDefinition.hierarchy }) const result = _getNew(record, "");
(record.nodeKey(), await _save(app,result);
record.name }
);
_save({ datastore: datastore, hierarchy: appDefinition.hierarchy },
result
);
} */
}; };

View File

@ -2,7 +2,9 @@ import {
keyBy, mapValues, keyBy, mapValues,
} from 'lodash/fp'; } from 'lodash/fp';
import { generate } from 'shortid'; import { generate } from 'shortid';
import { getNodeForCollectionPath } from '../templateApi/hierarchy'; import {
getNodeForCollectionPath, isSingleRecord
} from '../templateApi/hierarchy';
import { getNewFieldValue } from '../types'; import { getNewFieldValue } from '../types';
import { import {
$, joinKey, safeKey, apiWrapperSync, events, $, joinKey, safeKey, apiWrapperSync, events,
@ -21,7 +23,7 @@ export const getNew = app => (collectionKey, recordTypeName) => {
); );
}; };
const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey); export const _getNew = (recordNode, collectionKey) => constructRecord(recordNode, getNewFieldValue, collectionKey);
const getRecordNode = (app, collectionKey) => { const getRecordNode = (app, collectionKey) => {
collectionKey = safeKey(collectionKey); collectionKey = safeKey(collectionKey);
@ -38,7 +40,9 @@ export const constructRecord = (recordNode, getFieldValue, collectionKey) => {
]); ]);
record.id = `${recordNode.nodeId}-${generate()}`; record.id = `${recordNode.nodeId}-${generate()}`;
record.key = joinKey(collectionKey, record.id); record.key = isSingleRecord(recordNode)
? joinKey(collectionKey, recordNode.name)
: joinKey(collectionKey, record.id);
record.isNew = true; record.isNew = true;
record.type = recordNode.name; record.type = recordNode.name;
return record; return record;

View File

@ -12,15 +12,10 @@ import {
apiWrapper, events, $, joinKey, apiWrapper, events, $, joinKey,
} from '../common'; } from '../common';
import { import {
getFlattenedHierarchy, getFlattenedHierarchy, getExactNodeForPath,
getExactNodeForPath, isRecord, getNode, isSingleRecord,
isRecord,
getNode,
getLastPartInKey,
fieldReversesReferenceToNode, fieldReversesReferenceToNode,
} from '../templateApi/hierarchy'; } from '../templateApi/hierarchy';
import { mapRecord } from '../indexing/evaluate';
import { listItems } from '../indexApi/listItems';
import { addToAllIds } from '../indexing/allIds'; import { addToAllIds } from '../indexing/allIds';
import { import {
transactionForCreateRecord, transactionForCreateRecord,
@ -52,7 +47,13 @@ export const _save = async (app, record, context, skipValidation = false) => {
} }
if (recordClone.isNew) { if (recordClone.isNew) {
await addToAllIds(app.hierarchy, app.datastore)(recordClone); const recordNode = getExactNodeForPath(app.hierarchy)(record.key);
if(!recordNode)
throw new Error("Cannot find node for " + record.key);
if(!isSingleRecord(recordNode))
await addToAllIds(app.hierarchy, app.datastore)(recordClone);
const transaction = await transactionForCreateRecord( const transaction = await transactionForCreateRecord(
app, recordClone, app, recordClone,
); );

View File

@ -65,6 +65,14 @@ describe("initialiseData", () => {
expect(levels.levels[0].name).toBe("owner"); expect(levels.levels[0].name).toBe("owner");
}); });
it("should initialise 'single record' type nodes", async () => {
const {appDef, datastore} = getApplicationDefinition();
await initialiseData(datastore, appDef);
expect(await datastore.exists(`/settings`)).toBeTruthy();
const settings = await datastore.loadJson("/settings/record.json");
expect(settings.type).toBe("settings");
});
const getApplicationDefinition = () => { const getApplicationDefinition = () => {
const {templateApi, app} = getMemoryTemplateApi(); const {templateApi, app} = getMemoryTemplateApi();
const h = basicAppHierarchyCreator_WithFields_AndIndexes(templateApi); const h = basicAppHierarchyCreator_WithFields_AndIndexes(templateApi);

View File

@ -1,6 +1,4 @@
import {setupApphierarchy, basicAppHierarchyCreator_WithFields, import {setupApphierarchy, basicAppHierarchyCreator_WithFields} from "./specHelpers";
getNewFieldAndAdd, stubEventHandler} from "./specHelpers";
import { iterateIndex } from "../src/indexing/read";
describe("get customId", () => { describe("get customId", () => {
it("should generate an id with given value", async () => { it("should generate an id with given value", async () => {

View File

@ -3,6 +3,7 @@ import {setupApphierarchy, basicAppHierarchyCreator_WithFields,
import {events, isNonEmptyString} from "../src/common"; import {events, isNonEmptyString} from "../src/common";
import { isBoolean } from "util"; import { isBoolean } from "util";
import {permission} from "../src/authApi/permissions"; import {permission} from "../src/authApi/permissions";
import { _getNew } from "../src/recordApi/getNew";
describe("recordApi > getNew", () => { describe("recordApi > getNew", () => {
@ -32,7 +33,7 @@ describe("recordApi > getNew", () => {
it("should create object with all declared fields, and use inital values", async () => { it("should create object with all declared fields, and use inital values", async () => {
const {recordApi} = await setupApphierarchy(templateApi => { const {recordApi} = await setupApphierarchy(templateApi => {
const hierarchy = basicAppHierarchyCreator_WithFields(templateApi); const hierarchy = basicAppHierarchyCreator_WithFields(templateApi);
const {root, customerRecord} = hierarchy; const {customerRecord} = hierarchy;
customerRecord.fields = []; customerRecord.fields = [];
@ -80,6 +81,13 @@ describe("recordApi > getNew", () => {
app.withOnlyThisPermission(permission.createRecord.get(appHierarchy.customerRecord.nodeKey())); app.withOnlyThisPermission(permission.createRecord.get(appHierarchy.customerRecord.nodeKey()));
recordApi.getNew("/customers", "customer"); recordApi.getNew("/customers", "customer");
}); });
it("for 'single record' type, should create with key ending in node name", async () => {
const {appHierarchy} = await setupApphierarchy(basicAppHierarchyCreator_WithFields);
const {settingsRecord} = appHierarchy;
const result = _getNew(settingsRecord, "");
expect(result.key).toBe("/settings")
})
}); });
describe('recordApi > save then load', () => { describe('recordApi > save then load', () => {