@carbonorm/carbonnode 6.1.0 → 6.1.1
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 +509 -292
- package/dist/index.cjs.js +209 -37
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.esm.js +208 -38
- package/dist/index.esm.js.map +1 -1
- package/dist/orm/utils/sqlUtils.d.ts +1 -0
- package/dist/types/ormInterfaces.d.ts +1 -0
- package/dist/utils/sqlAllowList.d.ts +5 -3
- package/package.json +1 -1
- package/src/__tests__/fixtures/c6.fixture.ts +33 -0
- package/src/__tests__/sakila-db/C6.js +1 -1
- package/src/__tests__/sakila-db/C6.mysqldump.json +1 -1
- package/src/__tests__/sakila-db/C6.mysqldump.sql +1 -1
- package/src/__tests__/sakila-db/C6.ts +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.post.json +6 -6
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.post.latest.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.actor.put.lookup.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.address.post.json +10 -10
- package/src/__tests__/sakila-db/sqlResponses/C6.address.post.latest.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.address.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.address.put.lookup.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.category.post.json +4 -4
- package/src/__tests__/sakila-db/sqlResponses/C6.category.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.category.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.category.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.city.post.json +4 -4
- package/src/__tests__/sakila-db/sqlResponses/C6.city.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.city.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.city.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.country.post.json +4 -4
- package/src/__tests__/sakila-db/sqlResponses/C6.country.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.country.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.country.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.post.json +10 -10
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.post.latest.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.customer.put.lookup.json +5 -5
- package/src/__tests__/sakila-db/sqlResponses/C6.film.post.json +4 -4
- package/src/__tests__/sakila-db/sqlResponses/C6.film.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.film.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.film.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.post.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.post.latest.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.inventory.put.lookup.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.language.post.json +4 -4
- package/src/__tests__/sakila-db/sqlResponses/C6.language.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.language.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.language.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.payment.post.json +4 -4
- package/src/__tests__/sakila-db/sqlResponses/C6.payment.post.latest.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.payment.put.lookup.json +2 -2
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.join.json +10 -10
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.post.json +6 -6
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.post.latest.json +3 -3
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.put.json +1 -1
- package/src/__tests__/sakila-db/sqlResponses/C6.rental.put.lookup.json +3 -3
- package/src/__tests__/sqlAllowList.test.ts +56 -1
- package/src/__tests__/sqlBuilders.test.ts +38 -1
- package/src/executors/SqlExecutor.ts +4 -3
- package/src/orm/builders/ConditionBuilder.ts +3 -10
- package/src/orm/utils/sqlUtils.ts +172 -4
- package/src/types/ormInterfaces.ts +1 -0
- package/src/utils/sqlAllowList.ts +44 -11
|
@@ -196,6 +196,7 @@ export interface iRest<RestShortTableName extends string = any, RestTableInterfa
|
|
|
196
196
|
logLevel?: number;
|
|
197
197
|
verbose?: boolean;
|
|
198
198
|
sqlAllowListPath?: string;
|
|
199
|
+
sqlQueryNormalizer?: (sql: string) => string;
|
|
199
200
|
}
|
|
200
201
|
export interface iConstraint {
|
|
201
202
|
TABLE: string;
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
export type SqlQueryNormalizer = (sql: string) => string;
|
|
1
2
|
export declare const normalizeSql: (sql: string) => string;
|
|
2
|
-
export declare const
|
|
3
|
+
export declare const normalizeSqlWith: (sql: string, sqlQueryNormalizer?: SqlQueryNormalizer) => string;
|
|
4
|
+
export declare const loadSqlAllowList: (allowListPath: string, sqlQueryNormalizer?: SqlQueryNormalizer) => Promise<Set<string>>;
|
|
3
5
|
export declare const extractSqlEntries: (payload: unknown) => string[];
|
|
4
|
-
export declare const collectSqlAllowListEntries: (payload: unknown, entries?: Set<string
|
|
5
|
-
export declare const compileSqlAllowList: (allowListPath: string, entries: Iterable<string
|
|
6
|
+
export declare const collectSqlAllowListEntries: (payload: unknown, entries?: Set<string>, sqlQueryNormalizer?: SqlQueryNormalizer) => Set<string>;
|
|
7
|
+
export declare const compileSqlAllowList: (allowListPath: string, entries: Iterable<string>, sqlQueryNormalizer?: SqlQueryNormalizer) => Promise<string[]>;
|
package/package.json
CHANGED
|
@@ -136,6 +136,39 @@ export function buildBinaryTestConfigFqn() {
|
|
|
136
136
|
return baseConfig;
|
|
137
137
|
}
|
|
138
138
|
|
|
139
|
+
export function buildTemporalTestConfig() {
|
|
140
|
+
const temporalCols = {
|
|
141
|
+
'events.id': 'id',
|
|
142
|
+
'events.read_at': 'read_at',
|
|
143
|
+
'events.read_on': 'read_on',
|
|
144
|
+
'events.read_time': 'read_time',
|
|
145
|
+
} as const;
|
|
146
|
+
|
|
147
|
+
const C6 = {
|
|
148
|
+
C6VERSION: 'test',
|
|
149
|
+
TABLES: {
|
|
150
|
+
events: tableModel<'events' & any>('events', temporalCols as any),
|
|
151
|
+
},
|
|
152
|
+
PREFIX: '',
|
|
153
|
+
ORM: {} as any,
|
|
154
|
+
} as any;
|
|
155
|
+
|
|
156
|
+
C6.TABLES.events.TYPE_VALIDATION['id'].MYSQL_TYPE = 'INT';
|
|
157
|
+
C6.TABLES.events.TYPE_VALIDATION['read_at'].MYSQL_TYPE = 'TIMESTAMP(3)';
|
|
158
|
+
C6.TABLES.events.TYPE_VALIDATION['read_on'].MYSQL_TYPE = 'DATE';
|
|
159
|
+
C6.TABLES.events.TYPE_VALIDATION['read_time'].MYSQL_TYPE = 'TIME(3)';
|
|
160
|
+
|
|
161
|
+
const baseConfig: iRest<any, any, any> = {
|
|
162
|
+
C6,
|
|
163
|
+
restModel: C6.TABLES.events,
|
|
164
|
+
requestMethod: 'POST',
|
|
165
|
+
verbose: false,
|
|
166
|
+
logLevel: LogLevel.DEBUG,
|
|
167
|
+
} as any;
|
|
168
|
+
|
|
169
|
+
return baseConfig;
|
|
170
|
+
}
|
|
171
|
+
|
|
139
172
|
export function buildParcelConfig() {
|
|
140
173
|
const propertyUnitsCols = {
|
|
141
174
|
'property_units.unit_id': 'unit_id',
|
|
@@ -1342,7 +1342,7 @@ export const TABLES = {
|
|
|
1342
1342
|
};
|
|
1343
1343
|
export const C6 = {
|
|
1344
1344
|
...C6Constants,
|
|
1345
|
-
C6VERSION: '6.1.
|
|
1345
|
+
C6VERSION: '6.1.1',
|
|
1346
1346
|
IMPORT: async (tableName) => {
|
|
1347
1347
|
tableName = tableName.toLowerCase();
|
|
1348
1348
|
// if tableName is not a key in the TABLES object then throw an error
|