@memberjunction/server 0.9.129 → 0.9.142
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/build.log.json +27 -0
- package/dist/apolloServer/TransactionPlugin.js +45 -45
- package/dist/apolloServer/TransactionPlugin.js.map +1 -1
- package/dist/apolloServer/index.js +26 -26
- package/dist/auth/exampleNewUserSubClass.js +53 -53
- package/dist/auth/exampleNewUserSubClass.js.map +1 -1
- package/dist/auth/index.js +110 -110
- package/dist/auth/index.js.map +1 -1
- package/dist/auth/newUsers.js +65 -66
- package/dist/auth/newUsers.js.map +1 -1
- package/dist/cache.js +10 -10
- package/dist/config.js +62 -62
- package/dist/config.js.map +1 -1
- package/dist/context.js +101 -101
- package/dist/context.js.map +1 -1
- package/dist/directives/Public.js +33 -33
- package/dist/directives/Public.js.map +1 -1
- package/dist/directives/index.js +17 -17
- package/dist/entitySubclasses/userViewEntity.server.js +127 -127
- package/dist/entitySubclasses/userViewEntity.server.js.map +1 -1
- package/dist/generated/generated.js +20205 -19004
- package/dist/generated/generated.js.map +1 -1
- package/dist/generic/PushStatusResolver.js +58 -58
- package/dist/generic/PushStatusResolver.js.map +1 -1
- package/dist/generic/ResolverBase.js +231 -231
- package/dist/generic/ResolverBase.js.map +1 -1
- package/dist/generic/RunViewResolver.js +400 -400
- package/dist/generic/RunViewResolver.js.map +1 -1
- package/dist/index.js +131 -131
- package/dist/index.js.map +1 -1
- package/dist/orm.js +33 -33
- package/dist/orm.js.map +1 -1
- package/dist/resolvers/AskSkipResolver.js +246 -246
- package/dist/resolvers/AskSkipResolver.js.map +1 -1
- package/dist/resolvers/ColorResolver.js +93 -93
- package/dist/resolvers/ColorResolver.js.map +1 -1
- package/dist/resolvers/DatasetResolver.js +167 -167
- package/dist/resolvers/DatasetResolver.js.map +1 -1
- package/dist/resolvers/EntityRecordNameResolver.js +111 -111
- package/dist/resolvers/EntityRecordNameResolver.js.map +1 -1
- package/dist/resolvers/EntityResolver.js +59 -59
- package/dist/resolvers/EntityResolver.js.map +1 -1
- package/dist/resolvers/MergeRecordsResolver.js +282 -282
- package/dist/resolvers/MergeRecordsResolver.js.map +1 -1
- package/dist/resolvers/QueryResolver.js +74 -0
- package/dist/resolvers/QueryResolver.js.map +1 -0
- package/dist/resolvers/ReportResolver.js +73 -73
- package/dist/resolvers/ReportResolver.js.map +1 -1
- package/dist/resolvers/UserFavoriteResolver.js +161 -161
- package/dist/resolvers/UserFavoriteResolver.js.map +1 -1
- package/dist/resolvers/UserResolver.js +69 -69
- package/dist/resolvers/UserResolver.js.map +1 -1
- package/dist/resolvers/UserViewResolver.js +101 -101
- package/dist/resolvers/UserViewResolver.js.map +1 -1
- package/dist/types.js +2 -2
- package/package.json +11 -11
- package/src/apolloServer/TransactionPlugin.ts +1 -1
- package/src/generated/generated.ts +921 -2
- package/src/resolvers/AskSkipResolver.ts +1 -1
- package/src/resolvers/QueryResolver.ts +42 -0
- package/src/resolvers/ReportResolver.ts +0 -15
- package/tsconfig.json +2 -2
package/dist/directives/index.js
CHANGED
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
-
};
|
|
16
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
-
__exportStar(require("./Public"), exports);
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./Public"), exports);
|
|
18
18
|
//# sourceMappingURL=index.js.map
|
|
@@ -1,81 +1,81 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
-
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
-
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
-
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
-
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
-
};
|
|
8
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
exports.UserViewEntity_Server = void 0;
|
|
10
|
-
const global_1 = require("@memberjunction/global");
|
|
11
|
-
const core_1 = require("@memberjunction/core");
|
|
12
|
-
const core_entities_1 = require("@memberjunction/core-entities");
|
|
13
|
-
const ai_1 = require("@memberjunction/ai");
|
|
14
|
-
let UserViewEntity_Server = class UserViewEntity_Server extends core_entities_1.UserViewEntityExtended {
|
|
15
|
-
get SmartFilterImplemented() {
|
|
16
|
-
return true;
|
|
17
|
-
}
|
|
18
|
-
async GenerateSmartFilterWhereClause(prompt, entityInfo) {
|
|
19
|
-
try {
|
|
20
|
-
const llm = new ai_1.OpenAILLM();
|
|
21
|
-
const chatParams = {
|
|
22
|
-
model: 'gpt-4',
|
|
23
|
-
systemPrompt: this.GenerateSysPrompt(entityInfo),
|
|
24
|
-
userMessage: '',
|
|
25
|
-
messages: [
|
|
26
|
-
{
|
|
27
|
-
role: 'user',
|
|
28
|
-
content: `${prompt}`,
|
|
29
|
-
},
|
|
30
|
-
],
|
|
31
|
-
};
|
|
32
|
-
const result = await llm.ChatCompletion(chatParams);
|
|
33
|
-
if (result && result.data) {
|
|
34
|
-
const llmResponse = result.data.choices[0].message.content;
|
|
35
|
-
if (llmResponse) {
|
|
36
|
-
try {
|
|
37
|
-
const parsed = JSON.parse(llmResponse);
|
|
38
|
-
if (parsed.whereClause && parsed.whereClause.length > 0) {
|
|
39
|
-
const trimmed = parsed.whereClause.trim();
|
|
40
|
-
let ret = '';
|
|
41
|
-
if (trimmed.toLowerCase().startsWith('where '))
|
|
42
|
-
ret = trimmed.substring(6);
|
|
43
|
-
else
|
|
44
|
-
ret = parsed.whereClause;
|
|
45
|
-
return {
|
|
46
|
-
whereClause: ret,
|
|
47
|
-
userExplanation: parsed.userExplanationMessage
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
else if (parsed.whereClause !== undefined && parsed.whereClause !== null) {
|
|
51
|
-
return {
|
|
52
|
-
whereClause: '',
|
|
53
|
-
userExplanation: parsed.userExplanationMessage
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
else {
|
|
57
|
-
throw new Error('Invalid response from AI, no whereClause property found in response: ' + llmResponse);
|
|
58
|
-
}
|
|
59
|
-
}
|
|
60
|
-
catch (e) {
|
|
61
|
-
(0, core_1.LogError)(e);
|
|
62
|
-
throw new Error('Error parsing JSON response from AI: ' + llmResponse);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
else
|
|
66
|
-
throw new Error('Null response from AI');
|
|
67
|
-
}
|
|
68
|
-
else
|
|
69
|
-
throw new Error('No result returned from AI');
|
|
70
|
-
}
|
|
71
|
-
catch (e) {
|
|
72
|
-
(0, core_1.LogError)(e);
|
|
73
|
-
throw e;
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
GenerateSysPrompt(entityInfo) {
|
|
77
|
-
const processedViews = [entityInfo.BaseView];
|
|
78
|
-
const md = new core_1.Metadata();
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.UserViewEntity_Server = void 0;
|
|
10
|
+
const global_1 = require("@memberjunction/global");
|
|
11
|
+
const core_1 = require("@memberjunction/core");
|
|
12
|
+
const core_entities_1 = require("@memberjunction/core-entities");
|
|
13
|
+
const ai_1 = require("@memberjunction/ai");
|
|
14
|
+
let UserViewEntity_Server = class UserViewEntity_Server extends core_entities_1.UserViewEntityExtended {
|
|
15
|
+
get SmartFilterImplemented() {
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
async GenerateSmartFilterWhereClause(prompt, entityInfo) {
|
|
19
|
+
try {
|
|
20
|
+
const llm = new ai_1.OpenAILLM();
|
|
21
|
+
const chatParams = {
|
|
22
|
+
model: 'gpt-4',
|
|
23
|
+
systemPrompt: this.GenerateSysPrompt(entityInfo),
|
|
24
|
+
userMessage: '',
|
|
25
|
+
messages: [
|
|
26
|
+
{
|
|
27
|
+
role: 'user',
|
|
28
|
+
content: `${prompt}`,
|
|
29
|
+
},
|
|
30
|
+
],
|
|
31
|
+
};
|
|
32
|
+
const result = await llm.ChatCompletion(chatParams);
|
|
33
|
+
if (result && result.data) {
|
|
34
|
+
const llmResponse = result.data.choices[0].message.content;
|
|
35
|
+
if (llmResponse) {
|
|
36
|
+
try {
|
|
37
|
+
const parsed = JSON.parse(llmResponse);
|
|
38
|
+
if (parsed.whereClause && parsed.whereClause.length > 0) {
|
|
39
|
+
const trimmed = parsed.whereClause.trim();
|
|
40
|
+
let ret = '';
|
|
41
|
+
if (trimmed.toLowerCase().startsWith('where '))
|
|
42
|
+
ret = trimmed.substring(6);
|
|
43
|
+
else
|
|
44
|
+
ret = parsed.whereClause;
|
|
45
|
+
return {
|
|
46
|
+
whereClause: ret,
|
|
47
|
+
userExplanation: parsed.userExplanationMessage
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
else if (parsed.whereClause !== undefined && parsed.whereClause !== null) {
|
|
51
|
+
return {
|
|
52
|
+
whereClause: '',
|
|
53
|
+
userExplanation: parsed.userExplanationMessage
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
throw new Error('Invalid response from AI, no whereClause property found in response: ' + llmResponse);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
catch (e) {
|
|
61
|
+
(0, core_1.LogError)(e);
|
|
62
|
+
throw new Error('Error parsing JSON response from AI: ' + llmResponse);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
else
|
|
66
|
+
throw new Error('Null response from AI');
|
|
67
|
+
}
|
|
68
|
+
else
|
|
69
|
+
throw new Error('No result returned from AI');
|
|
70
|
+
}
|
|
71
|
+
catch (e) {
|
|
72
|
+
(0, core_1.LogError)(e);
|
|
73
|
+
throw e;
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
GenerateSysPrompt(entityInfo) {
|
|
77
|
+
const processedViews = [entityInfo.BaseView];
|
|
78
|
+
const md = new core_1.Metadata();
|
|
79
79
|
const gptSysPrompt = `You are an expert in SQL and Microsoft SQL Server.
|
|
80
80
|
You will be provided a user prompt representing how they want to filter the data.
|
|
81
81
|
You may *NOT* use JOINS, only sub-queries for related tables.
|
|
@@ -88,58 +88,58 @@ const returnType = {
|
|
|
88
88
|
};
|
|
89
89
|
|
|
90
90
|
The view that the user is querying is called ${entityInfo.BaseView} and has these fields:
|
|
91
|
-
${entityInfo.Fields.map(f => {
|
|
92
|
-
let ret = `${f.Name} (${f.Type})`;
|
|
93
|
-
if (f.RelatedEntity) {
|
|
94
|
-
ret += ` (fkey to ${f.RelatedEntityBaseView})`;
|
|
95
|
-
}
|
|
96
|
-
return ret;
|
|
97
|
-
}).join(',')}`;
|
|
98
|
-
const fkeyFields = entityInfo.Fields.filter(f => f.RelatedEntity && f.RelatedEntity.length > 0);
|
|
99
|
-
const fkeyBaseViewsDistinct = fkeyFields.map(f => f.RelatedEntityBaseView).filter((v, i, a) => a.indexOf(v) === i);
|
|
91
|
+
${entityInfo.Fields.map(f => {
|
|
92
|
+
let ret = `${f.Name} (${f.Type})`;
|
|
93
|
+
if (f.RelatedEntity) {
|
|
94
|
+
ret += ` (fkey to ${f.RelatedEntityBaseView})`;
|
|
95
|
+
}
|
|
96
|
+
return ret;
|
|
97
|
+
}).join(',')}`;
|
|
98
|
+
const fkeyFields = entityInfo.Fields.filter(f => f.RelatedEntity && f.RelatedEntity.length > 0);
|
|
99
|
+
const fkeyBaseViewsDistinct = fkeyFields.map(f => f.RelatedEntityBaseView).filter((v, i, a) => a.indexOf(v) === i);
|
|
100
100
|
const relationships = `
|
|
101
101
|
In addition, ${entityInfo.BaseView} has links to other views, as shown here, you can use these views in sub-queries to achieve the request from the user.
|
|
102
102
|
If there are multiple filters related to a single related view, attempt to combine them into a single sub-query for efficiency.
|
|
103
|
-
${fkeyBaseViewsDistinct.map(v => {
|
|
104
|
-
if (processedViews.indexOf(v) === -1) {
|
|
105
|
-
const e = md.Entities.find(e => e.BaseView === v);
|
|
106
|
-
if (e) {
|
|
107
|
-
processedViews.push(v);
|
|
108
|
-
return `* ${e.SchemaName}.${e.BaseView}: ${e.Fields.map(ef => {
|
|
109
|
-
return ef.Name + ' (' + ef.Type + ')';
|
|
110
|
-
}).join(',')}`;
|
|
111
|
-
}
|
|
112
|
-
else
|
|
113
|
-
return '';
|
|
114
|
-
}
|
|
115
|
-
else
|
|
116
|
-
return '';
|
|
103
|
+
${fkeyBaseViewsDistinct.map(v => {
|
|
104
|
+
if (processedViews.indexOf(v) === -1) {
|
|
105
|
+
const e = md.Entities.find(e => e.BaseView === v);
|
|
106
|
+
if (e) {
|
|
107
|
+
processedViews.push(v);
|
|
108
|
+
return `* ${e.SchemaName}.${e.BaseView}: ${e.Fields.map(ef => {
|
|
109
|
+
return ef.Name + ' (' + ef.Type + ')';
|
|
110
|
+
}).join(',')}`;
|
|
111
|
+
}
|
|
112
|
+
else
|
|
113
|
+
return '';
|
|
114
|
+
}
|
|
115
|
+
else
|
|
116
|
+
return '';
|
|
117
117
|
}).join('\n')}
|
|
118
|
-
${entityInfo.RelatedEntities.map(r => {
|
|
119
|
-
const e = md.Entities.find(e => e.Name === r.RelatedEntity);
|
|
120
|
-
if (e) {
|
|
121
|
-
if (processedViews.indexOf(e.BaseView) === -1) {
|
|
122
|
-
processedViews.push(e.BaseView);
|
|
123
|
-
return `* ${e.SchemaName}.${e.BaseView}: ${e.Fields.map(ef => {
|
|
124
|
-
let ret = `${ef.Name} (${ef.Type})`;
|
|
125
|
-
if (ef.RelatedEntity) {
|
|
126
|
-
ret += ` (fkey to ${ef.RelatedEntityBaseView})`;
|
|
127
|
-
}
|
|
128
|
-
return ret;
|
|
129
|
-
}).join(',')}`;
|
|
130
|
-
}
|
|
131
|
-
else
|
|
132
|
-
return '';
|
|
133
|
-
}
|
|
134
|
-
else
|
|
135
|
-
return '';
|
|
136
|
-
}).join('\n')}`;
|
|
118
|
+
${entityInfo.RelatedEntities.map(r => {
|
|
119
|
+
const e = md.Entities.find(e => e.Name === r.RelatedEntity);
|
|
120
|
+
if (e) {
|
|
121
|
+
if (processedViews.indexOf(e.BaseView) === -1) {
|
|
122
|
+
processedViews.push(e.BaseView);
|
|
123
|
+
return `* ${e.SchemaName}.${e.BaseView}: ${e.Fields.map(ef => {
|
|
124
|
+
let ret = `${ef.Name} (${ef.Type})`;
|
|
125
|
+
if (ef.RelatedEntity) {
|
|
126
|
+
ret += ` (fkey to ${ef.RelatedEntityBaseView})`;
|
|
127
|
+
}
|
|
128
|
+
return ret;
|
|
129
|
+
}).join(',')}`;
|
|
130
|
+
}
|
|
131
|
+
else
|
|
132
|
+
return '';
|
|
133
|
+
}
|
|
134
|
+
else
|
|
135
|
+
return '';
|
|
136
|
+
}).join('\n')}`;
|
|
137
137
|
return gptSysPrompt + (processedViews.length > 1 ? relationships : '') + `
|
|
138
|
-
**** REMEMBER **** I am a BOT, do not return anything other than JSON to me or I will choke on your response!`;
|
|
139
|
-
}
|
|
140
|
-
};
|
|
141
|
-
UserViewEntity_Server =
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
138
|
+
**** REMEMBER **** I am a BOT, do not return anything other than JSON to me or I will choke on your response!`;
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
exports.UserViewEntity_Server = UserViewEntity_Server;
|
|
142
|
+
exports.UserViewEntity_Server = UserViewEntity_Server = __decorate([
|
|
143
|
+
(0, global_1.RegisterClass)(core_1.BaseEntity, 'User Views', 3)
|
|
144
|
+
], UserViewEntity_Server);
|
|
145
145
|
//# sourceMappingURL=userViewEntity.server.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"userViewEntity.server.js","sourceRoot":"","sources":["../../src/entitySubclasses/userViewEntity.server.ts"],"names":[],"mappings":";;;;;;;;;AAAA,mDAAiE;AACjE,+CAAkF;AAClF,iEAAsE;AACtE,2CAAsF;AAG/E,IAAM,qBAAqB,GAA3B,MAAM,qBAAsB,SAAQ,sCAAsB;IAI7D,IAAuB,sBAAsB;QACzC,OAAO,IAAI,CAAC;IAChB,CAAC;IAOM,KAAK,CAAC,8BAA8B,CAAC,MAAc,EAAE,UAAsB;QAC9E,IAAI;
|
|
1
|
+
{"version":3,"file":"userViewEntity.server.js","sourceRoot":"","sources":["../../src/entitySubclasses/userViewEntity.server.ts"],"names":[],"mappings":"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"}
|