prostgles-server 3.0.44 → 3.0.46

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.
Files changed (50) hide show
  1. package/README.md +20 -21
  2. package/dist/DboBuilder/QueryBuilder/Functions.d.ts +64 -0
  3. package/dist/DboBuilder/QueryBuilder/Functions.d.ts.map +1 -0
  4. package/dist/DboBuilder/QueryBuilder/Functions.js +940 -0
  5. package/dist/DboBuilder/QueryBuilder/Functions.js.map +1 -0
  6. package/dist/DboBuilder/QueryBuilder/QueryBuilder.d.ts +1 -62
  7. package/dist/DboBuilder/QueryBuilder/QueryBuilder.d.ts.map +1 -1
  8. package/dist/DboBuilder/QueryBuilder/QueryBuilder.js +6 -896
  9. package/dist/DboBuilder/QueryBuilder/QueryBuilder.js.map +1 -1
  10. package/dist/DboBuilder/TableHandler.d.ts.map +1 -1
  11. package/dist/DboBuilder/TableHandler.js +5 -6
  12. package/dist/DboBuilder/TableHandler.js.map +1 -1
  13. package/dist/DboBuilder/ViewHandler.d.ts.map +1 -1
  14. package/dist/DboBuilder/ViewHandler.js +4 -3
  15. package/dist/DboBuilder/ViewHandler.js.map +1 -1
  16. package/dist/DboBuilder/parseUpdateRules.d.ts.map +1 -1
  17. package/dist/DboBuilder/parseUpdateRules.js +5 -1
  18. package/dist/DboBuilder/parseUpdateRules.js.map +1 -1
  19. package/dist/DboBuilder.d.ts +1 -1
  20. package/dist/DboBuilder.d.ts.map +1 -1
  21. package/dist/DboBuilder.js.map +1 -1
  22. package/dist/PubSubManager.d.ts.map +1 -1
  23. package/dist/PubSubManager.js +1 -13
  24. package/dist/PubSubManager.js.map +1 -1
  25. package/lib/DboBuilder/QueryBuilder/Functions.d.ts +64 -0
  26. package/lib/DboBuilder/QueryBuilder/Functions.d.ts.map +1 -0
  27. package/lib/DboBuilder/QueryBuilder/Functions.js +939 -0
  28. package/lib/DboBuilder/QueryBuilder/Functions.ts +1071 -0
  29. package/lib/DboBuilder/QueryBuilder/QueryBuilder.d.ts +1 -62
  30. package/lib/DboBuilder/QueryBuilder/QueryBuilder.d.ts.map +1 -1
  31. package/lib/DboBuilder/QueryBuilder/QueryBuilder.js +6 -896
  32. package/lib/DboBuilder/QueryBuilder/QueryBuilder.ts +1 -1025
  33. package/lib/DboBuilder/TableHandler.d.ts.map +1 -1
  34. package/lib/DboBuilder/TableHandler.js +5 -6
  35. package/lib/DboBuilder/TableHandler.ts +7 -8
  36. package/lib/DboBuilder/ViewHandler.d.ts.map +1 -1
  37. package/lib/DboBuilder/ViewHandler.js +4 -3
  38. package/lib/DboBuilder/ViewHandler.ts +2 -1
  39. package/lib/DboBuilder/parseUpdateRules.d.ts.map +1 -1
  40. package/lib/DboBuilder/parseUpdateRules.js +5 -1
  41. package/lib/DboBuilder/parseUpdateRules.ts +8 -1
  42. package/lib/DboBuilder.d.ts +1 -1
  43. package/lib/DboBuilder.d.ts.map +1 -1
  44. package/lib/DboBuilder.ts +5 -9
  45. package/lib/PubSubManager.d.ts.map +1 -1
  46. package/lib/PubSubManager.js +1 -13
  47. package/lib/PubSubManager.ts +1 -13
  48. package/package.json +1 -1
  49. package/tests/client/PID.txt +1 -1
  50. package/tests/server/package-lock.json +1 -1
@@ -2,6 +2,7 @@ import { Filter, LocalParams, SortItem } from "../../DboBuilder";
2
2
  import { TableRule } from "../../PublishParser";
3
3
  import { SelectParams, ColumnInfo, PG_COLUMN_UDT_DATA_TYPE, Select } from "prostgles-types";
4
4
  import { TableHandler } from "../TableHandler";
5
+ import { FieldSpec, FunctionSpec } from "./Functions";
5
6
  export declare type SelectItem = {
6
7
  type: "column" | "function" | "aggregation" | "joinedColumn" | "computed";
7
8
  getFields: (args?: any[]) => string[] | "*";
@@ -39,67 +40,6 @@ export declare const parseFunctionObject: (funcData: any) => {
39
40
  funcName: string;
40
41
  args: any[];
41
42
  };
42
- export declare const parseFunction: (funcData: {
43
- func: string | FunctionSpec;
44
- args: any[];
45
- functions: FunctionSpec[];
46
- allowedFields: string[];
47
- }) => FunctionSpec;
48
- declare type GetQueryArgs = {
49
- allColumns: ColumnInfo[];
50
- allowedFields: string[];
51
- args: any[];
52
- tableAlias?: string;
53
- ctidField?: string;
54
- };
55
- export declare type FieldSpec = {
56
- name: string;
57
- type: "column" | "computed";
58
- /**
59
- * allowedFields passed for multicol functions (e.g.: $rowhash)
60
- */
61
- getQuery: (params: Omit<GetQueryArgs, "args">) => string;
62
- };
63
- export declare type FunctionSpec = {
64
- name: string;
65
- description?: string;
66
- /**
67
- * If true then it can be used in filters and is expected to return boolean
68
- */
69
- canBeUsedForFilter?: boolean;
70
- /**
71
- * If true then the first argument is expected to be a column name
72
- */
73
- singleColArg: boolean;
74
- /**
75
- * If true then this func can be used within where clause
76
- */
77
- /**
78
- * Number of arguments expected
79
- */
80
- numArgs: number;
81
- /**
82
- * If provided then the number of column names provided to the function (from getFields()) must not be less than this
83
- * By default every function is checked against numArgs
84
- */
85
- minCols?: number;
86
- type: "function" | "aggregation" | "computed";
87
- /**
88
- * getFields: string[] -> used to validate user supplied field names. It will be fired before querying to validate against allowed columns
89
- * if not field names are used from arguments then return an empty array
90
- */
91
- getFields: (args: any[]) => "*" | string[];
92
- /**
93
- * allowedFields passed for multicol functions (e.g.: $rowhash)
94
- */
95
- getQuery: (params: GetQueryArgs) => string;
96
- returnType?: PG_COLUMN_UDT_DATA_TYPE;
97
- };
98
- /**
99
- * Each function expects a column at the very least
100
- */
101
- export declare const FUNCTIONS: FunctionSpec[];
102
- export declare const COMPUTED_FIELDS: FieldSpec[];
103
43
  export declare class SelectItemBuilder {
104
44
  select: SelectItemValidated[];
105
45
  private allFields;
@@ -128,5 +68,4 @@ export declare class SelectItemBuilder {
128
68
  export declare function getNewQuery(_this: TableHandler, filter: Filter, selectParams: (SelectParams & {
129
69
  alias?: string;
130
70
  }), param3_unused: any, tableRules: TableRule | undefined, localParams: LocalParams | undefined, columns: ColumnInfo[]): Promise<NewQuery>;
131
- export {};
132
71
  //# sourceMappingURL=QueryBuilder.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"QueryBuilder.d.ts","sourceRoot":"","sources":["QueryBuilder.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"QueryBuilder.d.ts","sourceRoot":"","sources":["QueryBuilder.ts"],"names":[],"mappings":"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"}