interaqt 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +53 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -0
- package/dist/index.js.map +1 -0
- package/dist/runtime/ActivityCall.d.ts +68 -0
- package/dist/runtime/ActivityCall.d.ts.map +1 -0
- package/dist/runtime/ActivityCall.js +379 -0
- package/dist/runtime/ActivityCall.js.map +1 -0
- package/dist/runtime/Controller.d.ts +60 -0
- package/dist/runtime/Controller.d.ts.map +1 -0
- package/dist/runtime/Controller.js +225 -0
- package/dist/runtime/Controller.js.map +1 -0
- package/dist/runtime/InteractionCall.d.ts +102 -0
- package/dist/runtime/InteractionCall.d.ts.map +1 -0
- package/dist/runtime/InteractionCall.js +385 -0
- package/dist/runtime/InteractionCall.js.map +1 -0
- package/dist/runtime/MonoSystem.d.ts +26 -0
- package/dist/runtime/MonoSystem.d.ts.map +1 -0
- package/dist/runtime/MonoSystem.js +331 -0
- package/dist/runtime/MonoSystem.js.map +1 -0
- package/dist/runtime/Mysql.d.ts +35 -0
- package/dist/runtime/Mysql.d.ts.map +1 -0
- package/dist/runtime/Mysql.js +171 -0
- package/dist/runtime/Mysql.js.map +1 -0
- package/dist/runtime/PostgreSQL.d.ts +36 -0
- package/dist/runtime/PostgreSQL.d.ts.map +1 -0
- package/dist/runtime/PostgreSQL.js +172 -0
- package/dist/runtime/PostgreSQL.js.map +1 -0
- package/dist/runtime/SQLite.d.ts +34 -0
- package/dist/runtime/SQLite.d.ts.map +1 -0
- package/dist/runtime/SQLite.js +146 -0
- package/dist/runtime/SQLite.js.map +1 -0
- package/dist/runtime/Scheduler.d.ts +81 -0
- package/dist/runtime/Scheduler.d.ts.map +1 -0
- package/dist/runtime/Scheduler.js +457 -0
- package/dist/runtime/Scheduler.js.map +1 -0
- package/dist/runtime/System.d.ts +312 -0
- package/dist/runtime/System.d.ts.map +1 -0
- package/dist/runtime/System.js +90 -0
- package/dist/runtime/System.js.map +1 -0
- package/dist/runtime/asyncInteractionContext.d.ts +3 -0
- package/dist/runtime/asyncInteractionContext.d.ts.map +1 -0
- package/dist/runtime/asyncInteractionContext.js +3 -0
- package/dist/runtime/asyncInteractionContext.js.map +1 -0
- package/dist/runtime/boolExpression.d.ts +23 -0
- package/dist/runtime/boolExpression.d.ts.map +1 -0
- package/dist/runtime/boolExpression.js +43 -0
- package/dist/runtime/boolExpression.js.map +1 -0
- package/dist/runtime/computedDataHandles/Any.d.ts +52 -0
- package/dist/runtime/computedDataHandles/Any.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/Any.js +152 -0
- package/dist/runtime/computedDataHandles/Any.js.map +1 -0
- package/dist/runtime/computedDataHandles/Computation.d.ts +108 -0
- package/dist/runtime/computedDataHandles/Computation.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/Computation.js +49 -0
- package/dist/runtime/computedDataHandles/Computation.js.map +1 -0
- package/dist/runtime/computedDataHandles/ComputedDataHandle.d.ts +42 -0
- package/dist/runtime/computedDataHandles/ComputedDataHandle.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/ComputedDataHandle.js +4 -0
- package/dist/runtime/computedDataHandles/ComputedDataHandle.js.map +1 -0
- package/dist/runtime/computedDataHandles/Count.d.ts +45 -0
- package/dist/runtime/computedDataHandles/Count.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/Count.js +85 -0
- package/dist/runtime/computedDataHandles/Count.js.map +1 -0
- package/dist/runtime/computedDataHandles/Every.d.ts +56 -0
- package/dist/runtime/computedDataHandles/Every.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/Every.js +178 -0
- package/dist/runtime/computedDataHandles/Every.js.map +1 -0
- package/dist/runtime/computedDataHandles/StateMachine.d.ts +74 -0
- package/dist/runtime/computedDataHandles/StateMachine.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/StateMachine.js +180 -0
- package/dist/runtime/computedDataHandles/StateMachine.js.map +1 -0
- package/dist/runtime/computedDataHandles/Transform.d.ts +26 -0
- package/dist/runtime/computedDataHandles/Transform.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/Transform.js +106 -0
- package/dist/runtime/computedDataHandles/Transform.js.map +1 -0
- package/dist/runtime/computedDataHandles/TransitionFinder.d.ts +57 -0
- package/dist/runtime/computedDataHandles/TransitionFinder.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/TransitionFinder.js +40 -0
- package/dist/runtime/computedDataHandles/TransitionFinder.js.map +1 -0
- package/dist/runtime/computedDataHandles/WeightedSummation.d.ts +57 -0
- package/dist/runtime/computedDataHandles/WeightedSummation.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/WeightedSummation.js +146 -0
- package/dist/runtime/computedDataHandles/WeightedSummation.js.map +1 -0
- package/dist/runtime/computedDataHandles/index.d.ts +7 -0
- package/dist/runtime/computedDataHandles/index.d.ts.map +1 -0
- package/dist/runtime/computedDataHandles/index.js +7 -0
- package/dist/runtime/computedDataHandles/index.js.map +1 -0
- package/dist/runtime/index.d.ts +15 -0
- package/dist/runtime/index.d.ts.map +1 -0
- package/dist/runtime/index.js +15 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/server.d.ts +35 -0
- package/dist/runtime/server.d.ts.map +1 -0
- package/dist/runtime/server.js +171 -0
- package/dist/runtime/server.js.map +1 -0
- package/dist/runtime/types/boolExpression.d.ts +22 -0
- package/dist/runtime/types/boolExpression.d.ts.map +1 -0
- package/dist/runtime/types/boolExpression.js +6 -0
- package/dist/runtime/types/boolExpression.js.map +1 -0
- package/dist/runtime/util.d.ts +10 -0
- package/dist/runtime/util.d.ts.map +1 -0
- package/dist/runtime/util.js +39 -0
- package/dist/runtime/util.js.map +1 -0
- package/dist/shared/BoolExp.d.ts +97 -0
- package/dist/shared/BoolExp.d.ts.map +1 -0
- package/dist/shared/BoolExp.js +252 -0
- package/dist/shared/BoolExp.js.map +1 -0
- package/dist/shared/activity/Activity.d.ts +465 -0
- package/dist/shared/activity/Activity.d.ts.map +1 -0
- package/dist/shared/activity/Activity.js +264 -0
- package/dist/shared/activity/Activity.js.map +1 -0
- package/dist/shared/activity/Condition.d.ts +75 -0
- package/dist/shared/activity/Condition.d.ts.map +1 -0
- package/dist/shared/activity/Condition.js +51 -0
- package/dist/shared/activity/Condition.js.map +1 -0
- package/dist/shared/activity/Data.d.ts +115 -0
- package/dist/shared/activity/Data.d.ts.map +1 -0
- package/dist/shared/activity/Data.js +89 -0
- package/dist/shared/activity/Data.js.map +1 -0
- package/dist/shared/attributive.d.ts +93 -0
- package/dist/shared/attributive.d.ts.map +1 -0
- package/dist/shared/attributive.js +59 -0
- package/dist/shared/attributive.js.map +1 -0
- package/dist/shared/computed.d.ts +607 -0
- package/dist/shared/computed.d.ts.map +1 -0
- package/dist/shared/computed.js +202 -0
- package/dist/shared/computed.js.map +1 -0
- package/dist/shared/createClass.d.ts +102 -0
- package/dist/shared/createClass.d.ts.map +1 -0
- package/dist/shared/createClass.js +276 -0
- package/dist/shared/createClass.js.map +1 -0
- package/dist/shared/dictionary/Dictionary.d.ts +40 -0
- package/dist/shared/dictionary/Dictionary.d.ts.map +1 -0
- package/dist/shared/dictionary/Dictionary.js +51 -0
- package/dist/shared/dictionary/Dictionary.js.map +1 -0
- package/dist/shared/entity/Entity.d.ts +149 -0
- package/dist/shared/entity/Entity.d.ts.map +1 -0
- package/dist/shared/entity/Entity.js +226 -0
- package/dist/shared/entity/Entity.js.map +1 -0
- package/dist/shared/index.d.ts +11 -0
- package/dist/shared/index.d.ts.map +1 -0
- package/dist/shared/index.js +11 -0
- package/dist/shared/index.js.map +1 -0
- package/dist/shared/user/User.d.ts +21 -0
- package/dist/shared/user/User.d.ts.map +1 -0
- package/dist/shared/user/User.js +11 -0
- package/dist/shared/user/User.js.map +1 -0
- package/dist/shared/utils.d.ts +11 -0
- package/dist/shared/utils.d.ts.map +1 -0
- package/dist/shared/utils.js +19 -0
- package/dist/shared/utils.js.map +1 -0
- package/dist/storage/erstorage/AttributeInfo.d.ts +40 -0
- package/dist/storage/erstorage/AttributeInfo.d.ts.map +1 -0
- package/dist/storage/erstorage/AttributeInfo.js +147 -0
- package/dist/storage/erstorage/AttributeInfo.js.map +1 -0
- package/dist/storage/erstorage/AttributeQuery.d.ts +33 -0
- package/dist/storage/erstorage/AttributeQuery.d.ts.map +1 -0
- package/dist/storage/erstorage/AttributeQuery.js +190 -0
- package/dist/storage/erstorage/AttributeQuery.js.map +1 -0
- package/dist/storage/erstorage/EntityQueryHandle.d.ts +29 -0
- package/dist/storage/erstorage/EntityQueryHandle.d.ts.map +1 -0
- package/dist/storage/erstorage/EntityQueryHandle.js +78 -0
- package/dist/storage/erstorage/EntityQueryHandle.js.map +1 -0
- package/dist/storage/erstorage/EntityToTableMap.d.ts +85 -0
- package/dist/storage/erstorage/EntityToTableMap.d.ts.map +1 -0
- package/dist/storage/erstorage/EntityToTableMap.js +262 -0
- package/dist/storage/erstorage/EntityToTableMap.js.map +1 -0
- package/dist/storage/erstorage/LinkInfo.d.ts +35 -0
- package/dist/storage/erstorage/LinkInfo.d.ts.map +1 -0
- package/dist/storage/erstorage/LinkInfo.js +89 -0
- package/dist/storage/erstorage/LinkInfo.js.map +1 -0
- package/dist/storage/erstorage/MatchExp.d.ts +37 -0
- package/dist/storage/erstorage/MatchExp.d.ts.map +1 -0
- package/dist/storage/erstorage/MatchExp.js +211 -0
- package/dist/storage/erstorage/MatchExp.js.map +1 -0
- package/dist/storage/erstorage/Modifier.d.ts +23 -0
- package/dist/storage/erstorage/Modifier.d.ts.map +1 -0
- package/dist/storage/erstorage/Modifier.js +24 -0
- package/dist/storage/erstorage/Modifier.js.map +1 -0
- package/dist/storage/erstorage/NewRecordData.d.ts +42 -0
- package/dist/storage/erstorage/NewRecordData.d.ts.map +1 -0
- package/dist/storage/erstorage/NewRecordData.js +178 -0
- package/dist/storage/erstorage/NewRecordData.js.map +1 -0
- package/dist/storage/erstorage/RecordInfo.d.ts +26 -0
- package/dist/storage/erstorage/RecordInfo.d.ts.map +1 -0
- package/dist/storage/erstorage/RecordInfo.js +111 -0
- package/dist/storage/erstorage/RecordInfo.js.map +1 -0
- package/dist/storage/erstorage/RecordQuery.d.ts +73 -0
- package/dist/storage/erstorage/RecordQuery.d.ts.map +1 -0
- package/dist/storage/erstorage/RecordQuery.js +158 -0
- package/dist/storage/erstorage/RecordQuery.js.map +1 -0
- package/dist/storage/erstorage/RecordQueryAgent.d.ts +84 -0
- package/dist/storage/erstorage/RecordQueryAgent.d.ts.map +1 -0
- package/dist/storage/erstorage/RecordQueryAgent.js +1130 -0
- package/dist/storage/erstorage/RecordQueryAgent.js.map +1 -0
- package/dist/storage/erstorage/Setup.d.ts +49 -0
- package/dist/storage/erstorage/Setup.d.ts.map +1 -0
- package/dist/storage/erstorage/Setup.js +400 -0
- package/dist/storage/erstorage/Setup.js.map +1 -0
- package/dist/storage/erstorage/util.d.ts +6 -0
- package/dist/storage/erstorage/util.d.ts.map +1 -0
- package/dist/storage/erstorage/util.js +25 -0
- package/dist/storage/erstorage/util.js.map +1 -0
- package/dist/storage/index.d.ts +13 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +13 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/utils.d.ts +10 -0
- package/dist/storage/utils.d.ts.map +1 -0
- package/dist/storage/utils.js +48 -0
- package/dist/storage/utils.js.map +1 -0
- package/package.json +59 -0
|
@@ -0,0 +1,331 @@
|
|
|
1
|
+
import { ACTIVITY_RECORD, ActivityStateEntity, EVENT_RECORD, InteractionEventEntity, SYSTEM_RECORD, SystemEntity } from "./System.js";
|
|
2
|
+
import { Property } from "@shared";
|
|
3
|
+
import { DBSetup, EntityQueryHandle, EntityToTableMap, MatchExp } from '@storage';
|
|
4
|
+
import { SQLiteDB } from "./SQLite.js";
|
|
5
|
+
import pino from "pino";
|
|
6
|
+
import { RecordBoundState, RelationBoundState } from "./computedDataHandles/Computation.js";
|
|
7
|
+
import { assert } from "./util.js";
|
|
8
|
+
function JSONStringify(value) {
|
|
9
|
+
return encodeURI(JSON.stringify(value));
|
|
10
|
+
}
|
|
11
|
+
function JSONParse(value) {
|
|
12
|
+
return value === undefined ? undefined : JSON.parse(decodeURI(value));
|
|
13
|
+
}
|
|
14
|
+
class MonoStorage {
|
|
15
|
+
constructor(db) {
|
|
16
|
+
this.db = db;
|
|
17
|
+
this.callbacks = new Set();
|
|
18
|
+
}
|
|
19
|
+
beginTransaction(name = '') {
|
|
20
|
+
return this.db.scheme('BEGIN', name);
|
|
21
|
+
}
|
|
22
|
+
commitTransaction(name = '') {
|
|
23
|
+
return this.db.scheme('COMMIT', name);
|
|
24
|
+
}
|
|
25
|
+
rollbackTransaction(name = '') {
|
|
26
|
+
return this.db.scheme('ROLLBACK', name);
|
|
27
|
+
}
|
|
28
|
+
// CAUTION kv 结构数据的实现也用 er。这是系统约定,因为也需要 Record 事件!
|
|
29
|
+
async get(concept, key, initialValue) {
|
|
30
|
+
const match = MatchExp.atom({ key: 'key', value: ['=', key] }).and({ key: 'concept', value: ['=', concept] });
|
|
31
|
+
const value = (await this.queryHandle.findOne(SYSTEM_RECORD, match, undefined, ['value']))?.value;
|
|
32
|
+
if (value === undefined)
|
|
33
|
+
return initialValue;
|
|
34
|
+
return JSONParse(value);
|
|
35
|
+
}
|
|
36
|
+
async set(concept, key, value, events) {
|
|
37
|
+
const match = MatchExp.atom({ key: 'key', value: ['=', key] }).and({ key: 'concept', value: ['=', concept] });
|
|
38
|
+
const origin = await this.queryHandle.findOne(SYSTEM_RECORD, match, undefined, ['value']);
|
|
39
|
+
if (origin) {
|
|
40
|
+
return this.callWithEvents(this.queryHandle.update.bind(this.queryHandle), [SYSTEM_RECORD, match, { concept, key: key.toString(), value: JSONStringify(value) }], events);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
return this.callWithEvents(this.queryHandle.create.bind(this.queryHandle), [SYSTEM_RECORD, { concept, key: key.toString(), value: encodeURI(JSON.stringify(value)) }], events);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
async setup(entities, relations, createTables = false) {
|
|
47
|
+
await this.db.open();
|
|
48
|
+
const dbSetup = new DBSetup(entities, relations, this.db);
|
|
49
|
+
if (createTables)
|
|
50
|
+
await dbSetup.createTables();
|
|
51
|
+
this.queryHandle = new EntityQueryHandle(new EntityToTableMap(dbSetup.map), this.db);
|
|
52
|
+
this.map = dbSetup.map;
|
|
53
|
+
}
|
|
54
|
+
findOne(...arg) {
|
|
55
|
+
return this.queryHandle.findOne(...arg);
|
|
56
|
+
}
|
|
57
|
+
find(...arg) {
|
|
58
|
+
return this.queryHandle.find(...arg);
|
|
59
|
+
}
|
|
60
|
+
create(entityName, rawData, events) {
|
|
61
|
+
return this.callWithEvents(this.queryHandle.create.bind(this.queryHandle), [entityName, rawData], events);
|
|
62
|
+
}
|
|
63
|
+
update(entity, matchExpressionData, rawData, events) {
|
|
64
|
+
return this.callWithEvents(this.queryHandle.update.bind(this.queryHandle), [entity, matchExpressionData, rawData], events);
|
|
65
|
+
}
|
|
66
|
+
delete(entityName, matchExpressionData, events) {
|
|
67
|
+
return this.callWithEvents(this.queryHandle.delete.bind(this.queryHandle), [entityName, matchExpressionData], events);
|
|
68
|
+
}
|
|
69
|
+
async callWithEvents(method, args, events = []) {
|
|
70
|
+
const result = await method(...args, events);
|
|
71
|
+
// FIXME 还没有实现异步机制
|
|
72
|
+
// nextJob(() => {
|
|
73
|
+
// this.dispatch(events)
|
|
74
|
+
// })
|
|
75
|
+
// CAUTION 特别注意这里会空充 events
|
|
76
|
+
const newEvents = await this.dispatch(events);
|
|
77
|
+
events.push(...newEvents);
|
|
78
|
+
return result;
|
|
79
|
+
}
|
|
80
|
+
findRelationByName(...arg) {
|
|
81
|
+
return this.queryHandle.findRelationByName(...arg);
|
|
82
|
+
}
|
|
83
|
+
findOneRelationByName(...arg) {
|
|
84
|
+
return this.queryHandle.findOneRelationByName(...arg);
|
|
85
|
+
}
|
|
86
|
+
updateRelationByName(relationName, matchExpressionData, rawData, events) {
|
|
87
|
+
return this.callWithEvents(this.queryHandle.updateRelationByName.bind(this.queryHandle), [relationName, matchExpressionData, rawData], events);
|
|
88
|
+
}
|
|
89
|
+
removeRelationByName(relationName, matchExpressionData, events) {
|
|
90
|
+
return this.callWithEvents(this.queryHandle.removeRelationByName.bind(this.queryHandle), [relationName, matchExpressionData], events);
|
|
91
|
+
}
|
|
92
|
+
addRelationByNameById(relationName, sourceEntityId, targetEntityId, rawData = {}, events) {
|
|
93
|
+
if (events?.length === 2)
|
|
94
|
+
debugger;
|
|
95
|
+
return this.callWithEvents(this.queryHandle.addRelationByNameById.bind(this.queryHandle), [relationName, sourceEntityId, targetEntityId, rawData], events);
|
|
96
|
+
}
|
|
97
|
+
getRelationName(...arg) {
|
|
98
|
+
return this.queryHandle.getRelationName(...arg);
|
|
99
|
+
}
|
|
100
|
+
getEntityName(...arg) {
|
|
101
|
+
return this.queryHandle.getEntityName(...arg);
|
|
102
|
+
}
|
|
103
|
+
listen(callback) {
|
|
104
|
+
this.callbacks.add(callback);
|
|
105
|
+
}
|
|
106
|
+
async dispatch(events) {
|
|
107
|
+
const newEvents = [];
|
|
108
|
+
for (let callback of this.callbacks) {
|
|
109
|
+
const callbackResult = await callback(events);
|
|
110
|
+
if (callbackResult?.events) {
|
|
111
|
+
newEvents.push(...callbackResult.events);
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
return newEvents;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
export const defaultLogger = pino();
|
|
118
|
+
export class ConsoleLogger {
|
|
119
|
+
info({ type, name, sql, params }) {
|
|
120
|
+
console.log({ type, name, sql, params });
|
|
121
|
+
}
|
|
122
|
+
child() {
|
|
123
|
+
return new ConsoleLogger();
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
export class MonoSystem {
|
|
127
|
+
constructor(db = new SQLiteDB(undefined, { logger: new ConsoleLogger() }), logger = defaultLogger) {
|
|
128
|
+
this.logger = logger;
|
|
129
|
+
this.conceptClass = new Map();
|
|
130
|
+
this.storage = new MonoStorage(db);
|
|
131
|
+
}
|
|
132
|
+
async saveEvent(event, mutationEvents = []) {
|
|
133
|
+
return this.storage.create(EVENT_RECORD, event, mutationEvents);
|
|
134
|
+
}
|
|
135
|
+
async getEvent(query) {
|
|
136
|
+
return (await this.storage.find(EVENT_RECORD, query, undefined, ['*'])).map(event => ({
|
|
137
|
+
...event,
|
|
138
|
+
}));
|
|
139
|
+
}
|
|
140
|
+
async createActivity(activity) {
|
|
141
|
+
return this.storage.create(ACTIVITY_RECORD, {
|
|
142
|
+
...activity,
|
|
143
|
+
state: JSONStringify(activity.state),
|
|
144
|
+
refs: JSONStringify(activity.refs),
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
async updateActivity(match, activity) {
|
|
148
|
+
const data = {
|
|
149
|
+
...activity
|
|
150
|
+
};
|
|
151
|
+
delete data.state;
|
|
152
|
+
delete data.refs;
|
|
153
|
+
if (activity.state) {
|
|
154
|
+
data.state = JSONStringify(activity.state);
|
|
155
|
+
}
|
|
156
|
+
if (activity.refs) {
|
|
157
|
+
data.refs = JSONStringify(activity.refs);
|
|
158
|
+
}
|
|
159
|
+
return this.storage.update(ACTIVITY_RECORD, match, data);
|
|
160
|
+
}
|
|
161
|
+
async getActivity(query) {
|
|
162
|
+
return (await this.storage.find(ACTIVITY_RECORD, query, undefined, ['*'])).map(activity => ({
|
|
163
|
+
...activity,
|
|
164
|
+
state: JSONParse(activity.state),
|
|
165
|
+
refs: JSONParse(activity.refs),
|
|
166
|
+
}));
|
|
167
|
+
}
|
|
168
|
+
setup(entities, relations, states, install = false) {
|
|
169
|
+
// Function to ensure entities have the required properties
|
|
170
|
+
const prepareEntity = (entity) => {
|
|
171
|
+
const entityAny = entity;
|
|
172
|
+
if (entityAny.isRef === undefined) {
|
|
173
|
+
entityAny.isRef = false;
|
|
174
|
+
}
|
|
175
|
+
return entityAny;
|
|
176
|
+
};
|
|
177
|
+
// Prepare all entities including system entities
|
|
178
|
+
const preparedEntities = [
|
|
179
|
+
...entities.map(prepareEntity),
|
|
180
|
+
prepareEntity(SystemEntity),
|
|
181
|
+
prepareEntity(InteractionEventEntity),
|
|
182
|
+
prepareEntity(ActivityStateEntity)
|
|
183
|
+
];
|
|
184
|
+
states.forEach(({ dataContext, state }) => {
|
|
185
|
+
Object.entries(state).forEach(([stateName, stateItem]) => {
|
|
186
|
+
if (stateItem instanceof RecordBoundState) {
|
|
187
|
+
let boundStateName = '';
|
|
188
|
+
let entity;
|
|
189
|
+
if (dataContext.type === 'property') {
|
|
190
|
+
const propertyDataContext = dataContext;
|
|
191
|
+
entity = propertyDataContext.host;
|
|
192
|
+
const propertyName = propertyDataContext.id;
|
|
193
|
+
boundStateName = `_property_boundState_${entity.name}_${propertyName}_${stateName}`;
|
|
194
|
+
}
|
|
195
|
+
else if (dataContext.type === 'entity' || dataContext.type === 'relation') {
|
|
196
|
+
entity = dataContext.id;
|
|
197
|
+
boundStateName = `_${dataContext.type}_boundState_${dataContext.id.name}_${stateName}`;
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
throw new Error(`Unsupported data context type: ${dataContext.type}`);
|
|
201
|
+
}
|
|
202
|
+
stateItem.key = boundStateName;
|
|
203
|
+
if (stateItem.defaultValue instanceof Property) {
|
|
204
|
+
// TODO 特别注意这里改了 name
|
|
205
|
+
stateItem.defaultValue.name = boundStateName;
|
|
206
|
+
entity.properties.push(stateItem.defaultValue);
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
const defaultValuetype = typeof stateItem.defaultValue;
|
|
210
|
+
entity.properties.push(Property.create({
|
|
211
|
+
name: boundStateName,
|
|
212
|
+
type: defaultValuetype,
|
|
213
|
+
// 应该系统定义
|
|
214
|
+
collection: Array.isArray(stateItem.defaultValue),
|
|
215
|
+
defaultValue: () => stateItem.defaultValue
|
|
216
|
+
}));
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
else if (stateItem instanceof RelationBoundState) {
|
|
220
|
+
const propertyDataContext = dataContext;
|
|
221
|
+
const boundStateName = `_relation_boundState_${propertyDataContext.host.name}_${propertyDataContext.id}_${stateName}`;
|
|
222
|
+
stateItem.key = boundStateName;
|
|
223
|
+
const relationName = stateItem.record;
|
|
224
|
+
const relation = relations.find(relation => relation.name === relationName);
|
|
225
|
+
assert(relation, `relation ${relationName} not found`);
|
|
226
|
+
if (stateItem.defaultValue instanceof Property) {
|
|
227
|
+
// TODO 特别注意这里改了 name
|
|
228
|
+
stateItem.defaultValue.name = boundStateName;
|
|
229
|
+
relation.properties.push(stateItem.defaultValue);
|
|
230
|
+
}
|
|
231
|
+
else {
|
|
232
|
+
const defaultValuetype = typeof stateItem.defaultValue;
|
|
233
|
+
relation.properties.push(Property.create({
|
|
234
|
+
name: boundStateName,
|
|
235
|
+
type: defaultValuetype,
|
|
236
|
+
// 应该系统定义
|
|
237
|
+
collection: Array.isArray(stateItem.defaultValue),
|
|
238
|
+
defaultValue: () => stateItem.defaultValue
|
|
239
|
+
}));
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
});
|
|
243
|
+
});
|
|
244
|
+
// Pass the prepared entities to storage.setup
|
|
245
|
+
return this.storage.setup(preparedEntities, relations, install);
|
|
246
|
+
}
|
|
247
|
+
// Implement the missing methods
|
|
248
|
+
async updateEntityPropertyState(entityId, target, propertyId, fromState, toState) {
|
|
249
|
+
const match = MatchExp.atom({ key: 'id', value: ['=', target.id] });
|
|
250
|
+
const entity = await this.storage.findOne(entityId, match);
|
|
251
|
+
if (entity && entity[propertyId] === fromState) {
|
|
252
|
+
return this.storage.update(entityId, match, { [propertyId]: toState });
|
|
253
|
+
}
|
|
254
|
+
return null;
|
|
255
|
+
}
|
|
256
|
+
async updateGlobalState(id, fromState, toState) {
|
|
257
|
+
const currentState = await this.storage.get('state', id);
|
|
258
|
+
if (currentState === fromState) {
|
|
259
|
+
return this.storage.set('state', id, toState);
|
|
260
|
+
}
|
|
261
|
+
return null;
|
|
262
|
+
}
|
|
263
|
+
async updateEntityState(entityId, target, fromState, toState) {
|
|
264
|
+
const baseMatch = MatchExp.atom({ key: 'id', value: ['=', target.id] });
|
|
265
|
+
if (fromState) {
|
|
266
|
+
let match = baseMatch;
|
|
267
|
+
Object.entries(fromState || {}).forEach(([key, value]) => {
|
|
268
|
+
match = match.and({ key, value: ['=', value] });
|
|
269
|
+
});
|
|
270
|
+
const matchedEntity = await this.storage.findOne(entityId, match);
|
|
271
|
+
if (matchedEntity) {
|
|
272
|
+
if (!toState) {
|
|
273
|
+
// Delete entity
|
|
274
|
+
return this.storage.delete(entityId, MatchExp.atom({ key: 'id', value: ['=', matchedEntity.id] }));
|
|
275
|
+
}
|
|
276
|
+
else {
|
|
277
|
+
// Update entity
|
|
278
|
+
return this.storage.update(entityId, MatchExp.atom({ key: 'id', value: ['=', matchedEntity.id] }), toState);
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
else {
|
|
283
|
+
// Check if entity doesn't exist
|
|
284
|
+
const matchedEntity = await this.storage.findOne(entityId, baseMatch);
|
|
285
|
+
if (!matchedEntity && toState) {
|
|
286
|
+
// Create entity
|
|
287
|
+
return this.storage.create(entityId, toState);
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
return null;
|
|
291
|
+
}
|
|
292
|
+
async updateRelationState(relationId, source, target, fromState, toState) {
|
|
293
|
+
const baseRelationMatch = MatchExp.atom({
|
|
294
|
+
key: 'source.id',
|
|
295
|
+
value: ['=', source.id]
|
|
296
|
+
}).and({
|
|
297
|
+
key: 'target.id',
|
|
298
|
+
value: ['=', target.id]
|
|
299
|
+
});
|
|
300
|
+
if (fromState) {
|
|
301
|
+
let relationMatch = baseRelationMatch;
|
|
302
|
+
Object.entries(fromState).forEach(([key, value]) => {
|
|
303
|
+
relationMatch = relationMatch.and({
|
|
304
|
+
key,
|
|
305
|
+
value: ['=', value]
|
|
306
|
+
});
|
|
307
|
+
});
|
|
308
|
+
const matchedRelation = await this.storage.findOneRelationByName(relationId, relationMatch);
|
|
309
|
+
if (matchedRelation) {
|
|
310
|
+
if (!toState) {
|
|
311
|
+
// Remove relation
|
|
312
|
+
return this.storage.removeRelationByName(relationId, MatchExp.atom({ key: 'id', value: ['=', matchedRelation.id] }));
|
|
313
|
+
}
|
|
314
|
+
else {
|
|
315
|
+
// Update relation
|
|
316
|
+
return this.storage.updateRelationByName(relationId, MatchExp.atom({ key: 'id', value: ['=', matchedRelation.id] }), toState);
|
|
317
|
+
}
|
|
318
|
+
}
|
|
319
|
+
}
|
|
320
|
+
else {
|
|
321
|
+
// Check if relation doesn't exist
|
|
322
|
+
const matchedRelation = await this.storage.findOneRelationByName(relationId, baseRelationMatch);
|
|
323
|
+
if (!matchedRelation && toState) {
|
|
324
|
+
// Create relation
|
|
325
|
+
return this.storage.addRelationByNameById(relationId, source.id, target.id, toState);
|
|
326
|
+
}
|
|
327
|
+
}
|
|
328
|
+
return null;
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
//# sourceMappingURL=MonoSystem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MonoSystem.js","sourceRoot":"","sources":["../../src/runtime/MonoSystem.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Database, DatabaseLogger, EntityIdRef } from "./System.js";
|
|
2
|
+
import mysql, { type Connection, type ConnectionOptions } from 'mysql2/promise';
|
|
3
|
+
declare class IDSystem {
|
|
4
|
+
db: Database;
|
|
5
|
+
constructor(db: Database);
|
|
6
|
+
setup(): Promise<any>;
|
|
7
|
+
getAutoId(recordName: string): Promise<string>;
|
|
8
|
+
}
|
|
9
|
+
export type MysqlDBConfig = Omit<ConnectionOptions, 'database'> & {
|
|
10
|
+
logger?: DatabaseLogger;
|
|
11
|
+
};
|
|
12
|
+
export declare class MysqlDB implements Database {
|
|
13
|
+
database: string;
|
|
14
|
+
options: MysqlDBConfig;
|
|
15
|
+
idSystem: IDSystem;
|
|
16
|
+
logger: DatabaseLogger;
|
|
17
|
+
db: Connection;
|
|
18
|
+
constructor(database: string, options?: MysqlDBConfig);
|
|
19
|
+
open(forceDrop?: boolean): Promise<void>;
|
|
20
|
+
query<T extends any>(sql: string, where?: any[], name?: string): Promise<T[]>;
|
|
21
|
+
update<T extends any>(sql: string, values: any[], idField?: string, name?: string): Promise<T[]>;
|
|
22
|
+
insert(sql: string, values: any[], name?: string): Promise<EntityIdRef>;
|
|
23
|
+
delete<T extends any>(sql: string, where: any[], name?: string): Promise<T[]>;
|
|
24
|
+
scheme(sql: string, name?: string): Promise<[mysql.QueryResult, mysql.FieldPacket[]]>;
|
|
25
|
+
close(): Promise<void>;
|
|
26
|
+
getAutoId(recordName: string): Promise<string>;
|
|
27
|
+
parseMatchExpression(key: string, value: [string, string], fieldName: string, fieldType: string, isReferenceValue: boolean, getReferenceFieldValue: (v: string) => string, p: () => string): {
|
|
28
|
+
fieldValue: string;
|
|
29
|
+
fieldParams: never[];
|
|
30
|
+
} | undefined;
|
|
31
|
+
getPlaceholder(): () => string;
|
|
32
|
+
mapToDBFieldType(type: string, collection?: boolean): string;
|
|
33
|
+
}
|
|
34
|
+
export {};
|
|
35
|
+
//# sourceMappingURL=Mysql.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Mysql.d.ts","sourceRoot":"","sources":["../../src/runtime/Mysql.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,cAAc,EAAE,WAAW,EAAC,MAAM,aAAa,CAAC;AAClE,OAAO,KAAK,EAAE,EAAC,KAAK,UAAU,EAAE,KAAK,iBAAiB,EAAgB,MAAM,gBAAgB,CAAA;AAK5F,cAAM,QAAQ;IACS,EAAE,EAAE,QAAQ;gBAAZ,EAAE,EAAE,QAAQ;IAC/B,KAAK;IAGC,SAAS,CAAC,UAAU,EAAE,MAAM;CAWrC;AAED,MAAM,MAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,EAAE,UAAU,CAAC,GAAG;IAAE,MAAM,CAAC,EAAE,cAAc,CAAA;CAAE,CAAA;AAE7F,qBAAa,OAAQ,YAAW,QAAQ;IAIjB,QAAQ,EAAC,MAAM;IAAS,OAAO,EAAE,aAAa;IAHjE,QAAQ,EAAG,QAAQ,CAAA;IACnB,MAAM,EAAE,cAAc,CAAA;IACtB,EAAE,EAAG,UAAU,CAAA;gBACI,QAAQ,EAAC,MAAM,EAAS,OAAO,GAAE,aAAkB;IAIhE,IAAI,CAAC,SAAS,UAAQ;IA0BtB,KAAK,CAAC,CAAC,SAAS,GAAG,EAAE,GAAG,EAAC,MAAM,EAAE,KAAK,GAAE,GAAG,EAAM,EAAE,IAAI,SAAI;IAa3D,MAAM,CAAC,CAAC,SAAS,GAAG,EAAE,GAAG,EAAC,MAAM,EAAC,MAAM,EAAE,GAAG,EAAE,EAAE,OAAO,CAAC,EAAC,MAAM,EAAE,IAAI,SAAG;IAexE,MAAM,CAAC,GAAG,EAAC,MAAM,EAAE,MAAM,EAAC,GAAG,EAAE,EAAE,IAAI,SAAG;IAmBxC,MAAM,CAAC,CAAC,SAAS,GAAG,EAAG,GAAG,EAAC,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,IAAI,SAAG;IAYxD,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,SAAG;IAUjC,KAAK;IAGC,SAAS,CAAC,UAAU,EAAE,MAAM;IAGlC,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,gBAAgB,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,MAAM,EAAE,CAAC,EAAE,MAAM,MAAM;;;;IAYzL,cAAc;IAKd,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,OAAO;CAmBtD"}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import mysql from 'mysql2/promise';
|
|
2
|
+
import { asyncInteractionContext } from "./asyncInteractionContext.js";
|
|
3
|
+
import pino from "pino";
|
|
4
|
+
class IDSystem {
|
|
5
|
+
constructor(db) {
|
|
6
|
+
this.db = db;
|
|
7
|
+
}
|
|
8
|
+
setup() {
|
|
9
|
+
return this.db.scheme(`CREATE Table IF NOT EXISTS _IDS_ (last INTEGER, name TEXT)`);
|
|
10
|
+
}
|
|
11
|
+
async getAutoId(recordName) {
|
|
12
|
+
const lastId = (await this.db.query(`SELECT last FROM "_IDS_" WHERE name = '${recordName}'`, [], `finding last id of ${recordName}`))[0]?.last;
|
|
13
|
+
const newId = (lastId || 0) + 1;
|
|
14
|
+
const name = `set last id for ${recordName}: ${newId}`;
|
|
15
|
+
if (lastId === undefined) {
|
|
16
|
+
await this.db.scheme(`INSERT INTO "_IDS_" (name, last) VALUES ('${recordName}', ${newId})`, name);
|
|
17
|
+
}
|
|
18
|
+
else {
|
|
19
|
+
await this.db.update(`UPDATE "_IDS_" SET last = ? WHERE name = ?`, [newId, recordName], undefined, name);
|
|
20
|
+
}
|
|
21
|
+
return newId;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
export class MysqlDB {
|
|
25
|
+
constructor(database, options = {}) {
|
|
26
|
+
this.database = database;
|
|
27
|
+
this.options = options;
|
|
28
|
+
this.idSystem = new IDSystem(this);
|
|
29
|
+
this.logger = this.options?.logger || pino();
|
|
30
|
+
}
|
|
31
|
+
async open(forceDrop = false) {
|
|
32
|
+
const options = { ...this.options };
|
|
33
|
+
delete options.logger;
|
|
34
|
+
this.db = await mysql.createConnection({
|
|
35
|
+
...this.options,
|
|
36
|
+
});
|
|
37
|
+
await this.db.connect();
|
|
38
|
+
const [rows] = await this.db.query(`SHOW DATABASES LIKE '${this.database}'`);
|
|
39
|
+
if (rows.length === 0) {
|
|
40
|
+
await this.db.query(`CREATE DATABASE ${this.database}`);
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
if (forceDrop) {
|
|
44
|
+
await this.db.query(`DROP DATABASE ${this.database}`);
|
|
45
|
+
await this.db.query(`CREATE DATABASE ${this.database}`);
|
|
46
|
+
}
|
|
47
|
+
this.db = await mysql.createConnection({
|
|
48
|
+
...this.options,
|
|
49
|
+
database: this.database
|
|
50
|
+
});
|
|
51
|
+
await this.db.connect();
|
|
52
|
+
}
|
|
53
|
+
await this.db.query(`SET sql_mode='ANSI_QUOTES'`);
|
|
54
|
+
await this.idSystem.setup();
|
|
55
|
+
}
|
|
56
|
+
async query(sql, where = [], name = '') {
|
|
57
|
+
const context = asyncInteractionContext.getStore();
|
|
58
|
+
const logger = this.logger.child(context?.logContext || {});
|
|
59
|
+
const params = where.map(x => x === false ? 0 : x === true ? 1 : x);
|
|
60
|
+
logger.info({
|
|
61
|
+
type: 'query',
|
|
62
|
+
name,
|
|
63
|
+
sql,
|
|
64
|
+
params
|
|
65
|
+
});
|
|
66
|
+
return (await this.db.query(sql, params))[0];
|
|
67
|
+
}
|
|
68
|
+
async update(sql, values, idField, name = '') {
|
|
69
|
+
const context = asyncInteractionContext.getStore();
|
|
70
|
+
const logger = this.logger.child(context?.logContext || {});
|
|
71
|
+
const finalSQL = `${sql} ${idField ? `RETURNING "${idField}" AS id` : ''}`;
|
|
72
|
+
const params = values.map(x => {
|
|
73
|
+
return (typeof x === 'object' && x !== null) ? JSON.stringify(x) : x === false ? 0 : x === true ? 1 : x;
|
|
74
|
+
});
|
|
75
|
+
logger.info({
|
|
76
|
+
type: 'update',
|
|
77
|
+
name,
|
|
78
|
+
sql: finalSQL,
|
|
79
|
+
params
|
|
80
|
+
});
|
|
81
|
+
return (await this.db.query(sql, params))[0];
|
|
82
|
+
}
|
|
83
|
+
async insert(sql, values, name = '') {
|
|
84
|
+
const context = asyncInteractionContext.getStore();
|
|
85
|
+
const logger = this.logger.child(context?.logContext || {});
|
|
86
|
+
const params = values.map(x => {
|
|
87
|
+
return (typeof x === 'object' && x !== null) ? JSON.stringify(x) : x === false ? 0 : x === true ? 1 : x;
|
|
88
|
+
});
|
|
89
|
+
logger.info({
|
|
90
|
+
type: 'insert',
|
|
91
|
+
name,
|
|
92
|
+
sql,
|
|
93
|
+
params
|
|
94
|
+
});
|
|
95
|
+
await this.db.query(sql, params);
|
|
96
|
+
const [rows] = (await this.db.query(`SELECT LAST_INSERT_ID();`));
|
|
97
|
+
const insertedId = rows[0]['LAST_INSERT_ID()'];
|
|
98
|
+
return { id: insertedId };
|
|
99
|
+
}
|
|
100
|
+
async delete(sql, where, name = '') {
|
|
101
|
+
const context = asyncInteractionContext.getStore();
|
|
102
|
+
const logger = this.logger.child(context?.logContext || {});
|
|
103
|
+
const params = where.map(x => x === false ? 0 : x === true ? 1 : x);
|
|
104
|
+
logger.info({
|
|
105
|
+
type: 'delete',
|
|
106
|
+
name,
|
|
107
|
+
sql,
|
|
108
|
+
params
|
|
109
|
+
});
|
|
110
|
+
return (await this.db.query(sql, params))[0];
|
|
111
|
+
}
|
|
112
|
+
async scheme(sql, name = '') {
|
|
113
|
+
const context = asyncInteractionContext.getStore();
|
|
114
|
+
const logger = this.logger.child(context?.logContext || {});
|
|
115
|
+
logger.info({
|
|
116
|
+
type: 'scheme',
|
|
117
|
+
name,
|
|
118
|
+
sql,
|
|
119
|
+
});
|
|
120
|
+
return await this.db.query(sql);
|
|
121
|
+
}
|
|
122
|
+
close() {
|
|
123
|
+
return this.db.end();
|
|
124
|
+
}
|
|
125
|
+
async getAutoId(recordName) {
|
|
126
|
+
return this.idSystem.getAutoId(recordName);
|
|
127
|
+
}
|
|
128
|
+
parseMatchExpression(key, value, fieldName, fieldType, isReferenceValue, getReferenceFieldValue, p) {
|
|
129
|
+
if (fieldType === 'JSON') {
|
|
130
|
+
if (value[0].toLowerCase() === 'contains') {
|
|
131
|
+
const fieldNameWithQuotes = fieldName.split('.').map(x => `"${x}"`).join('.');
|
|
132
|
+
return {
|
|
133
|
+
fieldValue: `IS NOT NULL AND JSON_CONTAINS(${fieldNameWithQuotes}, '${JSON.stringify(value[1])}', '$')`,
|
|
134
|
+
fieldParams: []
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
getPlaceholder() {
|
|
140
|
+
return () => {
|
|
141
|
+
return '?';
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
mapToDBFieldType(type, collection) {
|
|
145
|
+
if (type === 'pk') {
|
|
146
|
+
return 'INT AUTO_INCREMENT PRIMARY KEY';
|
|
147
|
+
}
|
|
148
|
+
else if (type === 'id') {
|
|
149
|
+
return 'INT';
|
|
150
|
+
}
|
|
151
|
+
else if (collection || type === 'object') {
|
|
152
|
+
return 'JSON';
|
|
153
|
+
}
|
|
154
|
+
else if (type === 'string') {
|
|
155
|
+
return 'TEXT';
|
|
156
|
+
}
|
|
157
|
+
else if (type === 'boolean') {
|
|
158
|
+
return 'INT(2)';
|
|
159
|
+
}
|
|
160
|
+
else if (type === 'number') {
|
|
161
|
+
return "INT";
|
|
162
|
+
}
|
|
163
|
+
else if (type === 'timestamp') {
|
|
164
|
+
return "TIMESTAMP";
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
return type;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=Mysql.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Mysql.js","sourceRoot":"","sources":["../../src/runtime/Mysql.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { Database, DatabaseLogger, EntityIdRef } from "./System.js";
|
|
2
|
+
import pg, { type ClientConfig } from 'pg';
|
|
3
|
+
declare const Client: typeof pg.Client;
|
|
4
|
+
declare class IDSystem {
|
|
5
|
+
db: Database;
|
|
6
|
+
constructor(db: Database);
|
|
7
|
+
setup(): Promise<any>;
|
|
8
|
+
getAutoId(recordName: string): Promise<string>;
|
|
9
|
+
}
|
|
10
|
+
export type PostgreSQLDBConfig = Omit<ClientConfig, 'database'> & {
|
|
11
|
+
logger?: DatabaseLogger;
|
|
12
|
+
};
|
|
13
|
+
export declare class PostgreSQLDB implements Database {
|
|
14
|
+
database: string;
|
|
15
|
+
options: PostgreSQLDBConfig;
|
|
16
|
+
idSystem: IDSystem;
|
|
17
|
+
logger: DatabaseLogger;
|
|
18
|
+
db: InstanceType<typeof Client>;
|
|
19
|
+
constructor(database: string, options?: PostgreSQLDBConfig);
|
|
20
|
+
open(forceDrop?: boolean): Promise<void>;
|
|
21
|
+
query<T extends any>(sql: string, where?: any[], name?: string): Promise<T[]>;
|
|
22
|
+
update<T extends any>(sql: string, values: any[], idField?: string, name?: string): Promise<T[]>;
|
|
23
|
+
insert(sql: string, values: any[], name?: string): Promise<EntityIdRef>;
|
|
24
|
+
delete<T extends any>(sql: string, where: any[], name?: string): Promise<T[]>;
|
|
25
|
+
scheme(sql: string, name?: string): Promise<pg.QueryResult<any>>;
|
|
26
|
+
close(): Promise<void>;
|
|
27
|
+
getAutoId(recordName: string): Promise<string>;
|
|
28
|
+
parseMatchExpression(key: string, value: [string, string], fieldName: string, fieldType: string, isReferenceValue: boolean, getReferenceFieldValue: (v: string) => string, p: () => string): {
|
|
29
|
+
fieldValue: string;
|
|
30
|
+
fieldParams: string[];
|
|
31
|
+
} | undefined;
|
|
32
|
+
getPlaceholder(): () => string;
|
|
33
|
+
mapToDBFieldType(type: string, collection?: boolean): string;
|
|
34
|
+
}
|
|
35
|
+
export {};
|
|
36
|
+
//# sourceMappingURL=PostgreSQL.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PostgreSQL.d.ts","sourceRoot":"","sources":["../../src/runtime/PostgreSQL.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAE,cAAc,EAAE,WAAW,EAAc,MAAM,aAAa,CAAC;AAC/E,OAAO,EAAE,EAAE,EAAE,KAAK,YAAY,EAAC,MAAM,IAAI,CAAA;AAKzC,QAAA,MAAQ,MAAM,kBAAM,CAAA;AAEpB,cAAM,QAAQ;IACS,EAAE,EAAE,QAAQ;gBAAZ,EAAE,EAAE,QAAQ;IAC/B,KAAK;IAGC,SAAS,CAAC,UAAU,EAAE,MAAM;CAWrC;AAED,MAAM,MAAM,kBAAkB,GAAG,IAAI,CAAC,YAAY,EAAE,UAAU,CAAC,GAAG;IAAE,MAAM,CAAC,EAAE,cAAc,CAAA;CAAE,CAAA;AAE7F,qBAAa,YAAa,YAAW,QAAQ;IAItB,QAAQ,EAAC,MAAM;IAAS,OAAO,EAAE,kBAAkB;IAHtE,QAAQ,EAAG,QAAQ,CAAA;IACnB,MAAM,EAAE,cAAc,CAAA;IACtB,EAAE,EAAE,YAAY,CAAC,OAAO,MAAM,CAAC,CAAA;gBACZ,QAAQ,EAAC,MAAM,EAAS,OAAO,GAAE,kBAAuB;IAOrE,IAAI,CAAC,SAAS,UAAQ;IAsBtB,KAAK,CAAC,CAAC,SAAS,GAAG,EAAE,GAAG,EAAC,MAAM,EAAE,KAAK,GAAE,GAAG,EAAM,EAAE,IAAI,SAAI;IAa3D,MAAM,CAAC,CAAC,SAAS,GAAG,EAAE,GAAG,EAAC,MAAM,EAAC,MAAM,EAAE,GAAG,EAAE,EAAE,OAAO,CAAC,EAAC,MAAM,EAAE,IAAI,SAAG;IAexE,MAAM,CAAC,GAAG,EAAC,MAAM,EAAE,MAAM,EAAC,GAAG,EAAE,EAAE,IAAI,SAAG;IAgBxC,MAAM,CAAC,CAAC,SAAS,GAAG,EAAG,GAAG,EAAC,MAAM,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,IAAI,SAAG;IAYxD,MAAM,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,SAAG;IAUjC,KAAK;IAGC,SAAS,CAAC,UAAU,EAAE,MAAM;IAGlC,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAC,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,gBAAgB,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,MAAM,EAAE,CAAC,EAAE,MAAM,MAAM;;;;IAYzL,cAAc;IAOd,gBAAgB,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,OAAO;CAmBtD"}
|