@memberjunction/server 2.112.0 → 2.113.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/dist/agents/skip-agent.d.ts +4 -4
- package/dist/agents/skip-agent.d.ts.map +1 -1
- package/dist/agents/skip-agent.js +951 -808
- package/dist/agents/skip-agent.js.map +1 -1
- package/dist/agents/skip-sdk.d.ts +1 -1
- package/dist/agents/skip-sdk.d.ts.map +1 -1
- package/dist/agents/skip-sdk.js +43 -53
- package/dist/agents/skip-sdk.js.map +1 -1
- package/dist/apolloServer/index.js +1 -1
- package/dist/auth/AuthProviderFactory.d.ts +1 -1
- package/dist/auth/AuthProviderFactory.d.ts.map +1 -1
- package/dist/auth/AuthProviderFactory.js +3 -1
- package/dist/auth/AuthProviderFactory.js.map +1 -1
- package/dist/auth/BaseAuthProvider.d.ts +1 -1
- package/dist/auth/BaseAuthProvider.d.ts.map +1 -1
- package/dist/auth/BaseAuthProvider.js +2 -3
- package/dist/auth/BaseAuthProvider.js.map +1 -1
- package/dist/auth/IAuthProvider.d.ts +1 -1
- package/dist/auth/IAuthProvider.d.ts.map +1 -1
- package/dist/auth/exampleNewUserSubClass.d.ts.map +1 -1
- package/dist/auth/exampleNewUserSubClass.js +1 -1
- package/dist/auth/exampleNewUserSubClass.js.map +1 -1
- package/dist/auth/index.d.ts +1 -1
- package/dist/auth/index.d.ts.map +1 -1
- package/dist/auth/index.js +6 -6
- package/dist/auth/index.js.map +1 -1
- package/dist/auth/initializeProviders.js +1 -1
- package/dist/auth/initializeProviders.js.map +1 -1
- package/dist/auth/newUsers.d.ts +1 -1
- package/dist/auth/newUsers.d.ts.map +1 -1
- package/dist/auth/newUsers.js +7 -7
- package/dist/auth/newUsers.js.map +1 -1
- package/dist/auth/providers/Auth0Provider.d.ts +1 -1
- package/dist/auth/providers/Auth0Provider.d.ts.map +1 -1
- package/dist/auth/providers/Auth0Provider.js +1 -1
- package/dist/auth/providers/Auth0Provider.js.map +1 -1
- package/dist/auth/providers/CognitoProvider.d.ts +1 -1
- package/dist/auth/providers/CognitoProvider.d.ts.map +1 -1
- package/dist/auth/providers/CognitoProvider.js +6 -3
- package/dist/auth/providers/CognitoProvider.js.map +1 -1
- package/dist/auth/providers/GoogleProvider.d.ts +1 -1
- package/dist/auth/providers/GoogleProvider.d.ts.map +1 -1
- package/dist/auth/providers/GoogleProvider.js +1 -1
- package/dist/auth/providers/GoogleProvider.js.map +1 -1
- package/dist/auth/providers/MSALProvider.d.ts +1 -1
- package/dist/auth/providers/MSALProvider.d.ts.map +1 -1
- package/dist/auth/providers/MSALProvider.js +1 -1
- package/dist/auth/providers/MSALProvider.js.map +1 -1
- package/dist/auth/providers/OktaProvider.d.ts +1 -1
- package/dist/auth/providers/OktaProvider.d.ts.map +1 -1
- package/dist/auth/providers/OktaProvider.js +1 -1
- package/dist/auth/providers/OktaProvider.js.map +1 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +10 -22
- package/dist/config.js.map +1 -1
- package/dist/context.d.ts +1 -1
- package/dist/context.d.ts.map +1 -1
- package/dist/context.js +7 -9
- package/dist/context.js.map +1 -1
- package/dist/entitySubclasses/entityPermissions.server.d.ts +1 -1
- package/dist/entitySubclasses/entityPermissions.server.d.ts.map +1 -1
- package/dist/entitySubclasses/entityPermissions.server.js +1 -1
- package/dist/entitySubclasses/entityPermissions.server.js.map +1 -1
- package/dist/generated/generated.d.ts +788 -658
- package/dist/generated/generated.d.ts.map +1 -1
- package/dist/generated/generated.js +2050 -3054
- package/dist/generated/generated.js.map +1 -1
- package/dist/generic/KeyInputOutputTypes.d.ts +1 -1
- package/dist/generic/KeyInputOutputTypes.d.ts.map +1 -1
- package/dist/generic/KeyInputOutputTypes.js +1 -1
- package/dist/generic/KeyInputOutputTypes.js.map +1 -1
- package/dist/generic/ResolverBase.d.ts +1 -1
- package/dist/generic/ResolverBase.d.ts.map +1 -1
- package/dist/generic/ResolverBase.js +10 -15
- package/dist/generic/ResolverBase.js.map +1 -1
- package/dist/generic/RunViewResolver.d.ts +1 -1
- package/dist/generic/RunViewResolver.d.ts.map +1 -1
- package/dist/generic/RunViewResolver.js +15 -15
- package/dist/generic/RunViewResolver.js.map +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +13 -18
- package/dist/index.js.map +1 -1
- package/dist/resolvers/ActionResolver.d.ts +2 -2
- package/dist/resolvers/ActionResolver.d.ts.map +1 -1
- package/dist/resolvers/ActionResolver.js +30 -28
- package/dist/resolvers/ActionResolver.js.map +1 -1
- package/dist/resolvers/AskSkipResolver.d.ts +2 -2
- package/dist/resolvers/AskSkipResolver.d.ts.map +1 -1
- package/dist/resolvers/AskSkipResolver.js +50 -60
- package/dist/resolvers/AskSkipResolver.js.map +1 -1
- package/dist/resolvers/ComponentRegistryResolver.d.ts.map +1 -1
- package/dist/resolvers/ComponentRegistryResolver.js +38 -36
- package/dist/resolvers/ComponentRegistryResolver.js.map +1 -1
- package/dist/resolvers/CreateQueryResolver.d.ts +1 -1
- package/dist/resolvers/CreateQueryResolver.d.ts.map +1 -1
- package/dist/resolvers/CreateQueryResolver.js +40 -43
- package/dist/resolvers/CreateQueryResolver.js.map +1 -1
- package/dist/resolvers/DatasetResolver.d.ts.map +1 -1
- package/dist/resolvers/DatasetResolver.js +1 -1
- package/dist/resolvers/DatasetResolver.js.map +1 -1
- package/dist/resolvers/EntityRecordNameResolver.d.ts +1 -1
- package/dist/resolvers/EntityRecordNameResolver.d.ts.map +1 -1
- package/dist/resolvers/EntityRecordNameResolver.js +1 -1
- package/dist/resolvers/EntityRecordNameResolver.js.map +1 -1
- package/dist/resolvers/EntityResolver.d.ts.map +1 -1
- package/dist/resolvers/EntityResolver.js +1 -1
- package/dist/resolvers/EntityResolver.js.map +1 -1
- package/dist/resolvers/FileCategoryResolver.js +1 -1
- package/dist/resolvers/FileCategoryResolver.js.map +1 -1
- package/dist/resolvers/FileResolver.js +1 -1
- package/dist/resolvers/FileResolver.js.map +1 -1
- package/dist/resolvers/GetDataContextDataResolver.d.ts +1 -1
- package/dist/resolvers/GetDataContextDataResolver.d.ts.map +1 -1
- package/dist/resolvers/GetDataContextDataResolver.js +5 -5
- package/dist/resolvers/GetDataContextDataResolver.js.map +1 -1
- package/dist/resolvers/GetDataResolver.d.ts.map +1 -1
- package/dist/resolvers/GetDataResolver.js +6 -8
- package/dist/resolvers/GetDataResolver.js.map +1 -1
- package/dist/resolvers/MergeRecordsResolver.d.ts +3 -3
- package/dist/resolvers/MergeRecordsResolver.d.ts.map +1 -1
- package/dist/resolvers/MergeRecordsResolver.js +3 -3
- package/dist/resolvers/MergeRecordsResolver.js.map +1 -1
- package/dist/resolvers/PotentialDuplicateRecordResolver.d.ts +1 -1
- package/dist/resolvers/PotentialDuplicateRecordResolver.d.ts.map +1 -1
- package/dist/resolvers/PotentialDuplicateRecordResolver.js +1 -1
- package/dist/resolvers/PotentialDuplicateRecordResolver.js.map +1 -1
- package/dist/resolvers/QueryResolver.d.ts.map +1 -1
- package/dist/resolvers/QueryResolver.js +11 -11
- package/dist/resolvers/QueryResolver.js.map +1 -1
- package/dist/resolvers/ReportResolver.js +1 -1
- package/dist/resolvers/ReportResolver.js.map +1 -1
- package/dist/resolvers/RunAIAgentResolver.d.ts.map +1 -1
- package/dist/resolvers/RunAIAgentResolver.js +28 -27
- package/dist/resolvers/RunAIAgentResolver.js.map +1 -1
- package/dist/resolvers/RunAIPromptResolver.d.ts.map +1 -1
- package/dist/resolvers/RunAIPromptResolver.js +31 -31
- package/dist/resolvers/RunAIPromptResolver.js.map +1 -1
- package/dist/resolvers/RunTemplateResolver.d.ts.map +1 -1
- package/dist/resolvers/RunTemplateResolver.js +9 -9
- package/dist/resolvers/RunTemplateResolver.js.map +1 -1
- package/dist/resolvers/SqlLoggingConfigResolver.d.ts.map +1 -1
- package/dist/resolvers/SqlLoggingConfigResolver.js +10 -10
- package/dist/resolvers/SqlLoggingConfigResolver.js.map +1 -1
- package/dist/resolvers/SyncDataResolver.d.ts +1 -1
- package/dist/resolvers/SyncDataResolver.d.ts.map +1 -1
- package/dist/resolvers/SyncDataResolver.js +14 -15
- package/dist/resolvers/SyncDataResolver.js.map +1 -1
- package/dist/resolvers/SyncRolesUsersResolver.d.ts +1 -1
- package/dist/resolvers/SyncRolesUsersResolver.d.ts.map +1 -1
- package/dist/resolvers/SyncRolesUsersResolver.js +44 -48
- package/dist/resolvers/SyncRolesUsersResolver.js.map +1 -1
- package/dist/resolvers/TaskResolver.d.ts.map +1 -1
- package/dist/resolvers/TaskResolver.js +7 -7
- package/dist/resolvers/TaskResolver.js.map +1 -1
- package/dist/resolvers/TransactionGroupResolver.d.ts +1 -1
- package/dist/resolvers/TransactionGroupResolver.d.ts.map +1 -1
- package/dist/resolvers/TransactionGroupResolver.js +12 -12
- package/dist/resolvers/TransactionGroupResolver.js.map +1 -1
- package/dist/resolvers/UserFavoriteResolver.d.ts +1 -1
- package/dist/resolvers/UserFavoriteResolver.d.ts.map +1 -1
- package/dist/resolvers/UserFavoriteResolver.js +1 -1
- package/dist/resolvers/UserFavoriteResolver.js.map +1 -1
- package/dist/resolvers/UserViewResolver.d.ts.map +1 -1
- package/dist/resolvers/UserViewResolver.js.map +1 -1
- package/dist/rest/EntityCRUDHandler.d.ts +1 -1
- package/dist/rest/EntityCRUDHandler.d.ts.map +1 -1
- package/dist/rest/EntityCRUDHandler.js +16 -14
- package/dist/rest/EntityCRUDHandler.js.map +1 -1
- package/dist/rest/RESTEndpointHandler.d.ts.map +1 -1
- package/dist/rest/RESTEndpointHandler.js +25 -23
- package/dist/rest/RESTEndpointHandler.js.map +1 -1
- package/dist/rest/ViewOperationsHandler.d.ts +1 -1
- package/dist/rest/ViewOperationsHandler.d.ts.map +1 -1
- package/dist/rest/ViewOperationsHandler.js +21 -17
- package/dist/rest/ViewOperationsHandler.js.map +1 -1
- package/dist/scheduler/LearningCycleScheduler.d.ts.map +1 -1
- package/dist/scheduler/LearningCycleScheduler.js.map +1 -1
- package/dist/services/ScheduledJobsService.d.ts.map +1 -1
- package/dist/services/ScheduledJobsService.js +6 -4
- package/dist/services/ScheduledJobsService.js.map +1 -1
- package/dist/services/TaskOrchestrator.d.ts +1 -1
- package/dist/services/TaskOrchestrator.d.ts.map +1 -1
- package/dist/services/TaskOrchestrator.js +30 -30
- package/dist/services/TaskOrchestrator.js.map +1 -1
- package/dist/types.d.ts +3 -3
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +1 -0
- package/dist/types.js.map +1 -1
- package/dist/util.d.ts +1 -1
- package/dist/util.d.ts.map +1 -1
- package/dist/util.js +2 -2
- package/dist/util.js.map +1 -1
- package/package.json +39 -36
- package/src/agents/skip-agent.ts +1200 -1067
- package/src/agents/skip-sdk.ts +851 -877
- package/src/apolloServer/index.ts +2 -2
- package/src/auth/AuthProviderFactory.ts +14 -8
- package/src/auth/BaseAuthProvider.ts +4 -5
- package/src/auth/IAuthProvider.ts +2 -2
- package/src/auth/exampleNewUserSubClass.ts +2 -9
- package/src/auth/index.ts +26 -31
- package/src/auth/initializeProviders.ts +3 -3
- package/src/auth/newUsers.ts +134 -166
- package/src/auth/providers/Auth0Provider.ts +5 -5
- package/src/auth/providers/CognitoProvider.ts +10 -7
- package/src/auth/providers/GoogleProvider.ts +5 -4
- package/src/auth/providers/MSALProvider.ts +5 -5
- package/src/auth/providers/OktaProvider.ts +7 -6
- package/src/config.ts +54 -63
- package/src/context.ts +30 -42
- package/src/entitySubclasses/entityPermissions.server.ts +3 -3
- package/src/generated/generated.ts +40442 -48106
- package/src/generic/KeyInputOutputTypes.ts +6 -3
- package/src/generic/ResolverBase.ts +78 -119
- package/src/generic/RunViewResolver.ts +23 -27
- package/src/index.ts +48 -66
- package/src/resolvers/ActionResolver.ts +57 -46
- package/src/resolvers/AskSkipResolver.ts +533 -607
- package/src/resolvers/ComponentRegistryResolver.ts +562 -547
- package/src/resolvers/CreateQueryResolver.ts +655 -683
- package/src/resolvers/DatasetResolver.ts +6 -5
- package/src/resolvers/EntityCommunicationsResolver.ts +1 -1
- package/src/resolvers/EntityRecordNameResolver.ts +5 -9
- package/src/resolvers/EntityResolver.ts +7 -9
- package/src/resolvers/FileCategoryResolver.ts +2 -2
- package/src/resolvers/FileResolver.ts +4 -4
- package/src/resolvers/GetDataContextDataResolver.ts +118 -106
- package/src/resolvers/GetDataResolver.ts +205 -194
- package/src/resolvers/MergeRecordsResolver.ts +5 -5
- package/src/resolvers/PotentialDuplicateRecordResolver.ts +1 -1
- package/src/resolvers/QueryResolver.ts +78 -95
- package/src/resolvers/ReportResolver.ts +2 -2
- package/src/resolvers/RunAIAgentResolver.ts +828 -818
- package/src/resolvers/RunAIPromptResolver.ts +709 -693
- package/src/resolvers/RunTemplateResolver.ts +103 -105
- package/src/resolvers/SqlLoggingConfigResolver.ts +72 -69
- package/src/resolvers/SyncDataResolver.ts +352 -386
- package/src/resolvers/SyncRolesUsersResolver.ts +350 -387
- package/src/resolvers/TaskResolver.ts +115 -110
- package/src/resolvers/TransactionGroupResolver.ts +138 -143
- package/src/resolvers/UserFavoriteResolver.ts +8 -17
- package/src/resolvers/UserViewResolver.ts +12 -17
- package/src/rest/EntityCRUDHandler.ts +268 -291
- package/src/rest/RESTEndpointHandler.ts +776 -782
- package/src/rest/ViewOperationsHandler.ts +195 -191
- package/src/scheduler/LearningCycleScheduler.ts +52 -8
- package/src/services/ScheduledJobsService.ts +132 -129
- package/src/services/TaskOrchestrator.ts +776 -792
- package/src/types.ts +9 -15
- package/src/util.ts +109 -112
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { Arg, Ctx, ObjectType, Query, Resolver, Field, Int } from 'type-graphql';
|
|
2
|
-
import { RunQuery, QueryInfo, IRunQueryProvider, IMetadataProvider } from '@memberjunction/
|
|
2
|
+
import { RunQuery, QueryInfo, IRunQueryProvider, IMetadataProvider } from '@memberjunction/core';
|
|
3
3
|
import { AppContext } from '../types.js';
|
|
4
4
|
import { RequireSystemUser } from '../directives/RequireSystemUser.js';
|
|
5
5
|
import { GraphQLJSONObject } from 'graphql-type-json';
|
|
6
|
-
import { Metadata } from '@memberjunction/
|
|
6
|
+
import { Metadata } from '@memberjunction/core';
|
|
7
7
|
import { GetReadOnlyProvider } from '../util.js';
|
|
8
8
|
|
|
9
9
|
@ObjectType()
|
|
@@ -44,16 +44,9 @@ export class RunQueryResultType {
|
|
|
44
44
|
|
|
45
45
|
@Resolver()
|
|
46
46
|
export class RunQueryResolver {
|
|
47
|
-
private async findQuery(
|
|
48
|
-
md: IMetadataProvider,
|
|
49
|
-
QueryID: string,
|
|
50
|
-
QueryName?: string,
|
|
51
|
-
CategoryID?: string,
|
|
52
|
-
CategoryPath?: string,
|
|
53
|
-
refreshMetadataIfNotFound: boolean = false
|
|
54
|
-
): Promise<QueryInfo | null> {
|
|
47
|
+
private async findQuery(md: IMetadataProvider, QueryID: string, QueryName?: string, CategoryID?: string, CategoryPath?: string, refreshMetadataIfNotFound: boolean = false): Promise<QueryInfo | null> {
|
|
55
48
|
// Filter queries based on provided criteria
|
|
56
|
-
const queries = md.Queries.filter(
|
|
49
|
+
const queries = md.Queries.filter(q => {
|
|
57
50
|
if (QueryID) {
|
|
58
51
|
return q.ID.trim().toLowerCase() === QueryID.trim().toLowerCase();
|
|
59
52
|
} else if (QueryName) {
|
|
@@ -74,31 +67,31 @@ export class RunQueryResolver {
|
|
|
74
67
|
// If we didn't find the query, refresh metadata and try again
|
|
75
68
|
await md.Refresh();
|
|
76
69
|
return this.findQuery(md, QueryID, QueryName, CategoryID, CategoryPath, false); // change the refresh flag to false so we don't loop infinitely
|
|
77
|
-
}
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
78
72
|
return null; // No query found and not refreshing metadata
|
|
79
73
|
}
|
|
80
|
-
}
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
81
76
|
return queries[0];
|
|
82
77
|
}
|
|
83
78
|
}
|
|
84
79
|
@Query(() => RunQueryResultType)
|
|
85
|
-
async GetQueryData(
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
): Promise<RunQueryResultType> {
|
|
96
|
-
const provider = GetReadOnlyProvider(context.providers, { allowFallbackToReadWrite: true });
|
|
80
|
+
async GetQueryData(@Arg('QueryID', () => String) QueryID: string,
|
|
81
|
+
@Ctx() context: AppContext,
|
|
82
|
+
@Arg('CategoryID', () => String, {nullable: true}) CategoryID?: string,
|
|
83
|
+
@Arg('CategoryPath', () => String, {nullable: true}) CategoryPath?: string,
|
|
84
|
+
@Arg('Parameters', () => GraphQLJSONObject, {nullable: true}) Parameters?: Record<string, any>,
|
|
85
|
+
@Arg('MaxRows', () => Int, {nullable: true}) MaxRows?: number,
|
|
86
|
+
@Arg('StartRow', () => Int, {nullable: true}) StartRow?: number,
|
|
87
|
+
@Arg('ForceAuditLog', () => Boolean, {nullable: true}) ForceAuditLog?: boolean,
|
|
88
|
+
@Arg('AuditLogDescription', () => String, {nullable: true}) AuditLogDescription?: string): Promise<RunQueryResultType> {
|
|
89
|
+
const provider = GetReadOnlyProvider(context.providers, {allowFallbackToReadWrite: true});
|
|
97
90
|
const md = provider as unknown as IMetadataProvider;
|
|
98
91
|
const rq = new RunQuery(provider as unknown as IRunQueryProvider);
|
|
99
92
|
console.log('GetQueryData called with:', { QueryID, Parameters, MaxRows, StartRow, ForceAuditLog, AuditLogDescription });
|
|
100
93
|
const result = await rq.RunQuery(
|
|
101
|
-
{
|
|
94
|
+
{
|
|
102
95
|
QueryID: QueryID,
|
|
103
96
|
CategoryID: CategoryID,
|
|
104
97
|
CategoryPath: CategoryPath,
|
|
@@ -106,16 +99,15 @@ export class RunQueryResolver {
|
|
|
106
99
|
MaxRows: MaxRows,
|
|
107
100
|
StartRow: StartRow,
|
|
108
101
|
ForceAuditLog: ForceAuditLog,
|
|
109
|
-
AuditLogDescription: AuditLogDescription
|
|
110
|
-
},
|
|
111
|
-
context.userPayload.userRecord
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
Success: result.Success,
|
|
102
|
+
AuditLogDescription: AuditLogDescription
|
|
103
|
+
},
|
|
104
|
+
context.userPayload.userRecord);
|
|
105
|
+
console.log('RunQuery result:', {
|
|
106
|
+
Success: result.Success,
|
|
115
107
|
ErrorMessage: result.ErrorMessage,
|
|
116
|
-
AppliedParameters: result.AppliedParameters
|
|
108
|
+
AppliedParameters: result.AppliedParameters
|
|
117
109
|
});
|
|
118
|
-
|
|
110
|
+
|
|
119
111
|
// If QueryName is not populated by the provider, use efficient lookup
|
|
120
112
|
let queryName = result.QueryName;
|
|
121
113
|
if (!queryName) {
|
|
@@ -128,7 +120,7 @@ export class RunQueryResolver {
|
|
|
128
120
|
console.error('Error finding query to get name:', error);
|
|
129
121
|
}
|
|
130
122
|
}
|
|
131
|
-
|
|
123
|
+
|
|
132
124
|
return {
|
|
133
125
|
QueryID: QueryID,
|
|
134
126
|
QueryName: queryName || 'Unknown Query',
|
|
@@ -140,38 +132,35 @@ export class RunQueryResolver {
|
|
|
140
132
|
ErrorMessage: result.ErrorMessage || '',
|
|
141
133
|
AppliedParameters: result.AppliedParameters ? JSON.stringify(result.AppliedParameters) : undefined,
|
|
142
134
|
CacheHit: (result as any).CacheHit,
|
|
143
|
-
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
135
|
+
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
144
136
|
};
|
|
145
137
|
}
|
|
146
138
|
|
|
147
139
|
@Query(() => RunQueryResultType)
|
|
148
|
-
async GetQueryDataByName(
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
): Promise<RunQueryResultType> {
|
|
159
|
-
const provider = GetReadOnlyProvider(context.providers, { allowFallbackToReadWrite: true });
|
|
140
|
+
async GetQueryDataByName(@Arg('QueryName', () => String) QueryName: string,
|
|
141
|
+
@Ctx() context: AppContext,
|
|
142
|
+
@Arg('CategoryID', () => String, {nullable: true}) CategoryID?: string,
|
|
143
|
+
@Arg('CategoryPath', () => String, {nullable: true}) CategoryPath?: string,
|
|
144
|
+
@Arg('Parameters', () => GraphQLJSONObject, {nullable: true}) Parameters?: Record<string, any>,
|
|
145
|
+
@Arg('MaxRows', () => Int, {nullable: true}) MaxRows?: number,
|
|
146
|
+
@Arg('StartRow', () => Int, {nullable: true}) StartRow?: number,
|
|
147
|
+
@Arg('ForceAuditLog', () => Boolean, {nullable: true}) ForceAuditLog?: boolean,
|
|
148
|
+
@Arg('AuditLogDescription', () => String, {nullable: true}) AuditLogDescription?: string): Promise<RunQueryResultType> {
|
|
149
|
+
const provider = GetReadOnlyProvider(context.providers, {allowFallbackToReadWrite: true});
|
|
160
150
|
const rq = new RunQuery(provider as unknown as IRunQueryProvider);
|
|
161
151
|
const result = await rq.RunQuery(
|
|
162
|
-
{
|
|
163
|
-
QueryName: QueryName,
|
|
152
|
+
{
|
|
153
|
+
QueryName: QueryName,
|
|
164
154
|
CategoryID: CategoryID,
|
|
165
155
|
CategoryPath: CategoryPath,
|
|
166
156
|
Parameters: Parameters,
|
|
167
157
|
MaxRows: MaxRows,
|
|
168
158
|
StartRow: StartRow,
|
|
169
159
|
ForceAuditLog: ForceAuditLog,
|
|
170
|
-
AuditLogDescription: AuditLogDescription
|
|
160
|
+
AuditLogDescription: AuditLogDescription
|
|
171
161
|
},
|
|
172
|
-
context.userPayload.userRecord
|
|
173
|
-
|
|
174
|
-
|
|
162
|
+
context.userPayload.userRecord);
|
|
163
|
+
|
|
175
164
|
return {
|
|
176
165
|
QueryID: result.QueryID || '',
|
|
177
166
|
QueryName: QueryName,
|
|
@@ -183,29 +172,27 @@ export class RunQueryResolver {
|
|
|
183
172
|
ErrorMessage: result.ErrorMessage || '',
|
|
184
173
|
AppliedParameters: result.AppliedParameters ? JSON.stringify(result.AppliedParameters) : undefined,
|
|
185
174
|
CacheHit: (result as any).CacheHit,
|
|
186
|
-
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
175
|
+
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
187
176
|
};
|
|
188
177
|
}
|
|
189
178
|
|
|
190
179
|
@RequireSystemUser()
|
|
191
180
|
@Query(() => RunQueryResultType)
|
|
192
|
-
async GetQueryDataSystemUser(
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
): Promise<RunQueryResultType> {
|
|
203
|
-
const provider = GetReadOnlyProvider(context.providers, { allowFallbackToReadWrite: true });
|
|
181
|
+
async GetQueryDataSystemUser(@Arg('QueryID', () => String) QueryID: string,
|
|
182
|
+
@Ctx() context: AppContext,
|
|
183
|
+
@Arg('CategoryID', () => String, {nullable: true}) CategoryID?: string,
|
|
184
|
+
@Arg('CategoryPath', () => String, {nullable: true}) CategoryPath?: string,
|
|
185
|
+
@Arg('Parameters', () => GraphQLJSONObject, {nullable: true}) Parameters?: Record<string, any>,
|
|
186
|
+
@Arg('MaxRows', () => Int, {nullable: true}) MaxRows?: number,
|
|
187
|
+
@Arg('StartRow', () => Int, {nullable: true}) StartRow?: number,
|
|
188
|
+
@Arg('ForceAuditLog', () => Boolean, {nullable: true}) ForceAuditLog?: boolean,
|
|
189
|
+
@Arg('AuditLogDescription', () => String, {nullable: true}) AuditLogDescription?: string): Promise<RunQueryResultType> {
|
|
190
|
+
const provider = GetReadOnlyProvider(context.providers, {allowFallbackToReadWrite: true});
|
|
204
191
|
const md = provider as unknown as IMetadataProvider;
|
|
205
192
|
const rq = new RunQuery(provider as unknown as IRunQueryProvider);
|
|
206
193
|
|
|
207
194
|
const result = await rq.RunQuery(
|
|
208
|
-
{
|
|
195
|
+
{
|
|
209
196
|
QueryID: QueryID,
|
|
210
197
|
CategoryID: CategoryID,
|
|
211
198
|
CategoryPath: CategoryPath,
|
|
@@ -213,11 +200,10 @@ export class RunQueryResolver {
|
|
|
213
200
|
MaxRows: MaxRows,
|
|
214
201
|
StartRow: StartRow,
|
|
215
202
|
ForceAuditLog: ForceAuditLog,
|
|
216
|
-
AuditLogDescription: AuditLogDescription
|
|
217
|
-
},
|
|
218
|
-
context.userPayload.userRecord
|
|
219
|
-
|
|
220
|
-
|
|
203
|
+
AuditLogDescription: AuditLogDescription
|
|
204
|
+
},
|
|
205
|
+
context.userPayload.userRecord);
|
|
206
|
+
|
|
221
207
|
// If QueryName is not populated by the provider, use efficient lookup
|
|
222
208
|
let queryName = result.QueryName;
|
|
223
209
|
if (!queryName) {
|
|
@@ -230,7 +216,7 @@ export class RunQueryResolver {
|
|
|
230
216
|
console.error('Error finding query to get name:', error);
|
|
231
217
|
}
|
|
232
218
|
}
|
|
233
|
-
|
|
219
|
+
|
|
234
220
|
return {
|
|
235
221
|
QueryID: QueryID,
|
|
236
222
|
QueryName: queryName || 'Unknown Query',
|
|
@@ -242,28 +228,26 @@ export class RunQueryResolver {
|
|
|
242
228
|
ErrorMessage: result.ErrorMessage || '',
|
|
243
229
|
AppliedParameters: result.AppliedParameters ? JSON.stringify(result.AppliedParameters) : undefined,
|
|
244
230
|
CacheHit: (result as any).CacheHit,
|
|
245
|
-
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
231
|
+
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
246
232
|
};
|
|
247
233
|
}
|
|
248
234
|
|
|
249
235
|
@RequireSystemUser()
|
|
250
236
|
@Query(() => RunQueryResultType)
|
|
251
|
-
async GetQueryDataByNameSystemUser(
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
): Promise<RunQueryResultType> {
|
|
262
|
-
const provider = GetReadOnlyProvider(context.providers, { allowFallbackToReadWrite: true });
|
|
237
|
+
async GetQueryDataByNameSystemUser(@Arg('QueryName', () => String) QueryName: string,
|
|
238
|
+
@Ctx() context: AppContext,
|
|
239
|
+
@Arg('CategoryID', () => String, {nullable: true}) CategoryID?: string,
|
|
240
|
+
@Arg('CategoryPath', () => String, {nullable: true}) CategoryPath?: string,
|
|
241
|
+
@Arg('Parameters', () => GraphQLJSONObject, {nullable: true}) Parameters?: Record<string, any>,
|
|
242
|
+
@Arg('MaxRows', () => Int, {nullable: true}) MaxRows?: number,
|
|
243
|
+
@Arg('StartRow', () => Int, {nullable: true}) StartRow?: number,
|
|
244
|
+
@Arg('ForceAuditLog', () => Boolean, {nullable: true}) ForceAuditLog?: boolean,
|
|
245
|
+
@Arg('AuditLogDescription', () => String, {nullable: true}) AuditLogDescription?: string): Promise<RunQueryResultType> {
|
|
246
|
+
const provider = GetReadOnlyProvider(context.providers, {allowFallbackToReadWrite: true});
|
|
263
247
|
const rq = new RunQuery(provider as unknown as IRunQueryProvider);
|
|
264
248
|
|
|
265
249
|
const result = await rq.RunQuery(
|
|
266
|
-
{
|
|
250
|
+
{
|
|
267
251
|
QueryName: QueryName,
|
|
268
252
|
CategoryID: CategoryID,
|
|
269
253
|
CategoryPath: CategoryPath,
|
|
@@ -271,11 +255,10 @@ export class RunQueryResolver {
|
|
|
271
255
|
MaxRows: MaxRows,
|
|
272
256
|
StartRow: StartRow,
|
|
273
257
|
ForceAuditLog: ForceAuditLog,
|
|
274
|
-
AuditLogDescription: AuditLogDescription
|
|
275
|
-
},
|
|
276
|
-
context.userPayload.userRecord
|
|
277
|
-
|
|
278
|
-
|
|
258
|
+
AuditLogDescription: AuditLogDescription
|
|
259
|
+
},
|
|
260
|
+
context.userPayload.userRecord);
|
|
261
|
+
|
|
279
262
|
return {
|
|
280
263
|
QueryID: result.QueryID || '',
|
|
281
264
|
QueryName: QueryName,
|
|
@@ -287,7 +270,7 @@ export class RunQueryResolver {
|
|
|
287
270
|
ErrorMessage: result.ErrorMessage || '',
|
|
288
271
|
AppliedParameters: result.AppliedParameters ? JSON.stringify(result.AppliedParameters) : undefined,
|
|
289
272
|
CacheHit: (result as any).CacheHit,
|
|
290
|
-
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
273
|
+
CacheTTLRemaining: (result as any).CacheTTLRemaining
|
|
291
274
|
};
|
|
292
275
|
}
|
|
293
|
-
}
|
|
276
|
+
}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { EntitySaveOptions, IRunReportProvider, Metadata, RunReport } from '@memberjunction/
|
|
1
|
+
import { EntitySaveOptions, IRunReportProvider, Metadata, RunReport } from '@memberjunction/core';
|
|
2
2
|
import { Arg, Ctx, Field, Int, Mutation, ObjectType, Query, Resolver } from 'type-graphql';
|
|
3
3
|
import { AppContext } from '../types.js';
|
|
4
4
|
import { ConversationDetailEntity, ReportEntity } from '@memberjunction/core-entities';
|
|
@@ -49,7 +49,7 @@ export class CreateReportResultType {
|
|
|
49
49
|
export class ReportResolverExtended {
|
|
50
50
|
@Query(() => RunReportResultType)
|
|
51
51
|
async GetReportData(@Arg('ReportID', () => String) ReportID: string, @Ctx() context: AppContext): Promise<RunReportResultType> {
|
|
52
|
-
const provider = GetReadOnlyProvider(context.providers, {
|
|
52
|
+
const provider = GetReadOnlyProvider(context.providers, {allowFallbackToReadWrite: true});
|
|
53
53
|
const rp = new RunReport(provider as unknown as IRunReportProvider);
|
|
54
54
|
|
|
55
55
|
const result = await rp.RunReport({ ReportID: ReportID });
|