@xxmachina/common 19.2.0 → 19.3.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.
@@ -1,9 +1,10 @@
1
1
  import * as i0 from '@angular/core';
2
2
  import { inject, Injectable } from '@angular/core';
3
3
  import { ApolloClientManagerService } from '@nx-ddd/hasura';
4
- import { switchMap } from 'rxjs';
4
+ import { switchMap, of, combineLatest } from 'rxjs';
5
5
  import { gql } from 'apollo-angular';
6
- import { getIntrospectionQuery } from 'graphql';
6
+ import { getIntrospectionQuery, parse, visit, OperationTypeNode, Kind, print } from 'graphql';
7
+ import { map } from 'rxjs/operators';
7
8
 
8
9
  class GraphqlService {
9
10
  apolloClientManager = inject(ApolloClientManagerService);
@@ -52,9 +53,271 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImpor
52
53
  args: [{ providedIn: 'root' }]
53
54
  }] });
54
55
 
56
+ /**
57
+ * AST-based subscription splitter service
58
+ * GraphQL ASTを使用して正確にサブスクリプションを分割
59
+ */
60
+ class AstSubscriptionSplitterService {
61
+ splitSubscription(query) {
62
+ const document = typeof query === 'string' ? parse(query) : query;
63
+ // Find the subscription operation
64
+ let subscriptionOp;
65
+ visit(document, {
66
+ OperationDefinition(node) {
67
+ if (node.operation === OperationTypeNode.SUBSCRIPTION) {
68
+ subscriptionOp = node;
69
+ }
70
+ }
71
+ });
72
+ if (!subscriptionOp || !subscriptionOp.selectionSet.selections.length) {
73
+ return [];
74
+ }
75
+ const results = [];
76
+ // Process each field in the subscription
77
+ subscriptionOp.selectionSet.selections.forEach(selection => {
78
+ if (selection.kind === Kind.FIELD) {
79
+ const field = selection;
80
+ const fieldName = field.alias?.value || field.name.value;
81
+ // Extract variables used in this field
82
+ const usedVariables = this.extractUsedVariables(field);
83
+ // Create a new subscription with only this field and its used variables
84
+ const newDoc = {
85
+ kind: Kind.DOCUMENT,
86
+ definitions: [{
87
+ kind: Kind.OPERATION_DEFINITION,
88
+ operation: OperationTypeNode.SUBSCRIPTION,
89
+ name: subscriptionOp.name ? {
90
+ kind: Kind.NAME,
91
+ value: subscriptionOp.name.value
92
+ } : undefined,
93
+ variableDefinitions: this.filterVariableDefinitions(subscriptionOp.variableDefinitions || [], usedVariables),
94
+ selectionSet: {
95
+ kind: Kind.SELECTION_SET,
96
+ selections: [field]
97
+ }
98
+ }]
99
+ };
100
+ results.push({
101
+ fieldName: field.name.value,
102
+ query: print(newDoc)
103
+ });
104
+ }
105
+ });
106
+ return results;
107
+ }
108
+ /**
109
+ * Extract variables used in a field and its subfields
110
+ */
111
+ extractUsedVariables(field) {
112
+ const usedVars = new Set();
113
+ // Visit all nodes in the field to find variable references
114
+ visit(field, {
115
+ Variable(node) {
116
+ usedVars.add(node.name.value);
117
+ }
118
+ });
119
+ return usedVars;
120
+ }
121
+ /**
122
+ * Filter variable definitions to only include used variables
123
+ */
124
+ filterVariableDefinitions(definitions, usedVariables) {
125
+ return definitions.filter(def => usedVariables.has(def.variable.name.value));
126
+ }
127
+ /**
128
+ * Combine multiple observables from split queries
129
+ */
130
+ combineResults(results, fieldNames) {
131
+ if (results.length === 0) {
132
+ return of({});
133
+ }
134
+ if (results.length === 1) {
135
+ return results[0];
136
+ }
137
+ return combineLatest(results).pipe(map(data => {
138
+ const combined = {};
139
+ fieldNames.forEach((fieldName, index) => {
140
+ if (data[index] && typeof data[index] === 'object') {
141
+ Object.keys(data[index]).forEach(key => {
142
+ if (combined[key]) {
143
+ if (Array.isArray(combined[key])) {
144
+ combined[key] = [...combined[key], ...(Array.isArray(data[index][key]) ? data[index][key] : [data[index][key]])];
145
+ }
146
+ else {
147
+ combined[key] = [combined[key], data[index][key]];
148
+ }
149
+ }
150
+ else {
151
+ combined[key] = data[index][key];
152
+ }
153
+ });
154
+ }
155
+ });
156
+ return combined;
157
+ }));
158
+ }
159
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: AstSubscriptionSplitterService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
160
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: AstSubscriptionSplitterService, providedIn: 'root' });
161
+ }
162
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: AstSubscriptionSplitterService, decorators: [{
163
+ type: Injectable,
164
+ args: [{ providedIn: 'root' }]
165
+ }] });
166
+
167
+ /**
168
+ * GraphqlServiceを拡張して、subscription分割機能を追加
169
+ *
170
+ * GraphQL/Hasuraの制限「1つのsubscriptionには1つのトップレベルフィールドのみ」を回避し、
171
+ * 複数のフィールドを含むsubscriptionを自動的に分割して並列実行します。
172
+ */
173
+ class GraphqlEnhancedService extends GraphqlService {
174
+ splitter = inject(AstSubscriptionSplitterService);
175
+ /**
176
+ * subscriptionクエリを実行
177
+ * デフォルトでsubscriptionは自動的に分割される
178
+ */
179
+ subscribe(graphql) {
180
+ // enableSplittingが明示的にfalseの場合、またはsubscriptionでない場合は通常の処理
181
+ const shouldSplit = graphql.enableSplitting !== false && this.isSubscription(graphql.query);
182
+ if (!shouldSplit) {
183
+ // 未使用変数を削除してから実行
184
+ const filteredGraphql = this.removeUnusedVariables(graphql);
185
+ return super.subscribe(filteredGraphql);
186
+ }
187
+ // subscriptionを分割して実行
188
+ return this.subscribeSplit(graphql);
189
+ }
190
+ /**
191
+ * subscriptionクエリを分割して並列実行し、結果を結合
192
+ */
193
+ subscribeSplit(graphql) {
194
+ const queryStr = typeof graphql.query === 'string' ? graphql.query : graphql.query.loc?.source?.body || '';
195
+ // クエリを分割
196
+ const splitQueries = this.splitter.splitSubscription(graphql.query);
197
+ // 分割が不要な場合(単一フィールド)
198
+ if (splitQueries.length <= 1) {
199
+ return super.subscribe(graphql);
200
+ }
201
+ // 各クエリを並列実行
202
+ const observables = splitQueries.map((splitQuery) => {
203
+ // 使用される変数のみを抽出
204
+ const usedVars = this.extractUsedVariablesFromQuery(splitQuery.query);
205
+ const filteredVariables = this.filterVariableValues(graphql.variables, usedVars);
206
+ const splitGraphql = {
207
+ ...graphql,
208
+ query: splitQuery.query,
209
+ variables: filteredVariables
210
+ };
211
+ return super.subscribe(splitGraphql).pipe(map(result => ({
212
+ fieldName: splitQuery.fieldName,
213
+ result
214
+ })));
215
+ });
216
+ // 結果を結合
217
+ return combineLatest(observables).pipe(map(results => {
218
+ const combinedData = {};
219
+ results.forEach(({ fieldName, result }) => {
220
+ const data = result.data || result;
221
+ if (data[fieldName] !== undefined) {
222
+ combinedData[fieldName] = data[fieldName];
223
+ }
224
+ });
225
+ return {
226
+ data: combinedData,
227
+ loading: false,
228
+ networkStatus: 7
229
+ };
230
+ }));
231
+ }
232
+ /**
233
+ * クエリがsubscriptionかどうかを判定
234
+ */
235
+ isSubscription(query) {
236
+ const queryStr = typeof query === 'string' ? query : query.loc?.source?.body || '';
237
+ return queryStr.trim().startsWith('subscription');
238
+ }
239
+ /**
240
+ * クエリから使用されている変数を抽出
241
+ */
242
+ extractUsedVariablesFromQuery(query) {
243
+ const variables = new Set();
244
+ const regex = /\$(\w+)/g;
245
+ let match;
246
+ while ((match = regex.exec(query)) !== null) {
247
+ variables.add(match[1]);
248
+ }
249
+ return variables;
250
+ }
251
+ /**
252
+ * 変数値から使用される変数のみをフィルタリング
253
+ */
254
+ filterVariableValues(variables, usedVars) {
255
+ const filtered = {};
256
+ for (const [key, value] of Object.entries(variables)) {
257
+ if (usedVars.has(key)) {
258
+ filtered[key] = value;
259
+ }
260
+ }
261
+ return filtered;
262
+ }
263
+ /**
264
+ * GraphQLクエリから未使用の変数を削除
265
+ */
266
+ removeUnusedVariables(graphql) {
267
+ if (!graphql.variables || Object.keys(graphql.variables).length === 0) {
268
+ return graphql;
269
+ }
270
+ const queryStr = typeof graphql.query === 'string' ? graphql.query : graphql.query.loc?.source?.body || '';
271
+ const usedVars = this.extractUsedVariablesFromQuery(queryStr);
272
+ const filteredVariables = this.filterVariableValues(graphql.variables, usedVars);
273
+ return {
274
+ ...graphql,
275
+ variables: filteredVariables
276
+ };
277
+ }
278
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: GraphqlEnhancedService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });
279
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: GraphqlEnhancedService, providedIn: 'root' });
280
+ }
281
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "20.0.5", ngImport: i0, type: GraphqlEnhancedService, decorators: [{
282
+ type: Injectable,
283
+ args: [{ providedIn: 'root' }]
284
+ }] });
285
+
286
+ /**
287
+ * GraphqlServiceをGraphqlEnhancedServiceで置き換えるプロバイダー
288
+ *
289
+ * 使用方法:
290
+ * ```typescript
291
+ * export default <Routes>[
292
+ * {
293
+ * path: '',
294
+ * component: YourComponent,
295
+ * providers: [
296
+ * provideGraphqlEnhancedLocally()
297
+ * ]
298
+ * }
299
+ * ];
300
+ * ```
301
+ */
302
+ function provideGraphqlEnhancedLocally() {
303
+ return [
304
+ {
305
+ provide: GraphqlService,
306
+ useClass: GraphqlEnhancedService
307
+ }
308
+ ];
309
+ }
310
+ /**
311
+ * グローバルにGraphqlEnhancedServiceを提供
312
+ * app.config.tsで使用
313
+ */
314
+ function provideGraphqlEnhancedGlobally() {
315
+ return provideGraphqlEnhancedLocally();
316
+ }
317
+
55
318
  /**
56
319
  * Generated bundle index. Do not edit.
57
320
  */
58
321
 
59
- export { GraphqlService };
322
+ export { GraphqlEnhancedService, GraphqlService, provideGraphqlEnhancedGlobally, provideGraphqlEnhancedLocally };
60
323
  //# sourceMappingURL=xxmachina-common-services-graphql.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"xxmachina-common-services-graphql.mjs","sources":["../tmp-esm2022/services/graphql/graphql.service.js","../tmp-esm2022/services/graphql/xxmachina-common-services-graphql.js"],"sourcesContent":["import { inject, Injectable } from \"@angular/core\";\nimport { ApolloClientManagerService } from \"@nx-ddd/hasura\";\nimport { switchMap } from \"rxjs\";\nimport { gql } from \"apollo-angular\";\nimport { getIntrospectionQuery } from \"graphql\";\nimport * as i0 from \"@angular/core\";\nexport class GraphqlService {\n apolloClientManager = inject(ApolloClientManagerService);\n /**\n * @TODO\n * this.apolloMulti.getClientはendpoint単位でApolloClientを管理しているため、\n * _query.graphql.headersに認証情報などが含まれていないリクエストが初めに来ると、\n * {message: 'no subscriptions exist}のようなエラーが出る。\n * Headersが更新されるたびに、ApolloClientを再生成するような処理も必要。\n */\n subscribe(graphql) {\n const getHeaders = typeof graphql.headers === 'function'\n ? graphql.headers\n : () => Promise.resolve(graphql.headers);\n return this.apolloClientManager.getClient(graphql.endpoint, getHeaders).pipe(switchMap((client) => client.subscribe({\n query: gql `${graphql.query}`,\n variables: graphql.variables,\n fetchPolicy: 'network-only',\n })));\n }\n query(graphql) {\n const getHeaders = typeof graphql.headers === 'function'\n ? graphql.headers\n : () => Promise.resolve(graphql.headers);\n return this.apolloClientManager.getClient(graphql.endpoint, getHeaders).pipe(switchMap((client) => client.query({\n query: gql `${graphql.query}`,\n variables: graphql.variables,\n fetchPolicy: 'network-only',\n })));\n }\n getSchema(graphql) {\n const getHeaders = typeof graphql.headers === 'function'\n ? graphql.headers\n : () => Promise.resolve(graphql.headers);\n return this.apolloClientManager.getClient(graphql.endpoint, getHeaders).pipe(switchMap((client) => client.query({\n query: gql `${getIntrospectionQuery()}`,\n variables: {},\n fetchPolicy: 'network-only',\n })));\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlService, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlService, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'root' }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGhxbC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQHh4bWFjaGluYS9jb21tb24vc3JjL2xpYi9zZXJ2aWNlcy9ncmFwaHFsL2dyYXBocWwuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVuRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM1RCxPQUFPLEVBQWMsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzdDLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQWdCLHFCQUFxQixFQUFFLE1BQU0sU0FBUyxDQUFDOztBQVk5RCxNQUFNLE9BQU8sY0FBYztJQUNoQixtQkFBbUIsR0FBRyxNQUFNLENBQUMsMEJBQTBCLENBQUMsQ0FBQztJQUVsRTs7Ozs7O09BTUc7SUFDSCxTQUFTLENBQUMsT0FBMEI7UUFDbEMsTUFBTSxVQUFVLEdBQWUsT0FBTyxPQUFPLENBQUMsT0FBTyxLQUFLLFVBQVU7WUFDbEUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPO1lBQ2pCLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxPQUFpQyxDQUFDLENBQUM7UUFDckUsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUMxRSxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQXNCO1lBQzFELEtBQUssRUFBRSxHQUFHLENBQUEsR0FBRyxPQUFPLENBQUMsS0FBSyxFQUFFO1lBQzVCLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztZQUM1QixXQUFXLEVBQUUsY0FBYztTQUM1QixDQUFDLENBQUMsQ0FDSixDQUFDO0lBQ0osQ0FBQztJQUVELEtBQUssQ0FBQyxPQUEwQjtRQUM5QixNQUFNLFVBQVUsR0FBZSxPQUFPLE9BQU8sQ0FBQyxPQUFPLEtBQUssVUFBVTtZQUNsRSxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU87WUFDakIsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQWlDLENBQUMsQ0FBQztRQUNyRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQzFFLFNBQVMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBc0I7WUFDdEQsS0FBSyxFQUFFLEdBQUcsQ0FBQSxHQUFHLE9BQU8sQ0FBQyxLQUFLLEVBQUU7WUFDNUIsU0FBUyxFQUFFLE9BQU8sQ0FBQyxTQUFTO1lBQzVCLFdBQVcsRUFBRSxjQUFjO1NBQzVCLENBQUMsQ0FBQyxDQUNKLENBQUM7SUFDSixDQUFDO0lBRUQsU0FBUyxDQUFDLE9BQW1DO1FBQzNDLE1BQU0sVUFBVSxHQUFlLE9BQU8sT0FBTyxDQUFDLE9BQU8sS0FBSyxVQUFVO1lBQ2xFLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTztZQUNqQixDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBaUMsQ0FBQyxDQUFDO1FBQ3JFLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxDQUFDLElBQUksQ0FDMUUsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFzQjtZQUN0RCxLQUFLLEVBQUUsR0FBRyxDQUFBLEdBQUcscUJBQXFCLEVBQUUsRUFBRTtZQUN0QyxTQUFTLEVBQUUsRUFBRTtZQUNiLFdBQVcsRUFBRSxjQUFjO1NBQzVCLENBQUMsQ0FBQyxDQUNKLENBQUM7SUFDSixDQUFDO3VHQS9DVSxjQUFjOzJHQUFkLGNBQWMsY0FERixNQUFNOzsyRkFDbEIsY0FBYztrQkFEMUIsVUFBVTttQkFBQyxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgR2V0SGVhZGVycyB9IGZyb20gXCJAbngtZGRkL2hhc3VyYVwiO1xuaW1wb3J0IHsgQXBvbGxvQ2xpZW50TWFuYWdlclNlcnZpY2UgfSBmcm9tIFwiQG54LWRkZC9oYXN1cmFcIjtcbmltcG9ydCB7IE9ic2VydmFibGUsIHN3aXRjaE1hcCB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBncWwgfSBmcm9tIFwiYXBvbGxvLWFuZ3VsYXJcIjtcbmltcG9ydCB7IERvY3VtZW50Tm9kZSwgZ2V0SW50cm9zcGVjdGlvblF1ZXJ5IH0gZnJvbSBcImdyYXBocWxcIjtcblxuZXhwb3J0IGludGVyZmFjZSBFeGVjdXRhYmxlR3JhcGhxbCB7XG4gIGVuZHBvaW50OiBzdHJpbmc7XG4gIHF1ZXJ5OiBzdHJpbmcgfCBEb2N1bWVudE5vZGU7XG4gIHZhcmlhYmxlczogb2JqZWN0O1xuICBoZWFkZXJzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+IHwgR2V0SGVhZGVycztcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0YWJsZUdldFNjaGVtYUdyYXBocWwgPSBQaWNrPEV4ZWN1dGFibGVHcmFwaHFsLCAnZW5kcG9pbnQnIHwgJ2hlYWRlcnMnPjtcblxuQEluamVjdGFibGUoe3Byb3ZpZGVkSW46ICdyb290J30pXG5leHBvcnQgY2xhc3MgR3JhcGhxbFNlcnZpY2Uge1xuICByZWFkb25seSBhcG9sbG9DbGllbnRNYW5hZ2VyID0gaW5qZWN0KEFwb2xsb0NsaWVudE1hbmFnZXJTZXJ2aWNlKTtcblxuICAvKipcbiAgICogQFRPRE9cbiAgICogdGhpcy5hcG9sbG9NdWx0aS5nZXRDbGllbnTjga9lbmRwb2ludOWNmOS9jeOBp0Fwb2xsb0NsaWVudOOCkueuoeeQhuOBl+OBpuOBhOOCi+OBn+OCgeOAgVxuICAgKiBfcXVlcnkuZ3JhcGhxbC5oZWFkZXJz44Gr6KqN6Ki85oOF5aCx44Gq44Gp44GM5ZCr44G+44KM44Gm44GE44Gq44GE44Oq44Kv44Ko44K544OI44GM5Yid44KB44Gr5p2l44KL44Go44CBXG4gICAqIHttZXNzYWdlOiAnbm8gc3Vic2NyaXB0aW9ucyBleGlzdH3jga7jgojjgYbjgarjgqjjg6njg7zjgYzlh7rjgovjgIJcbiAgICogSGVhZGVyc+OBjOabtOaWsOOBleOCjOOCi+OBn+OBs+OBq+OAgUFwb2xsb0NsaWVudOOCkuWGjeeUn+aIkOOBmeOCi+OCiOOBhuOBquWHpueQhuOCguW/heimgeOAglxuICAgKi9cbiAgc3Vic2NyaWJlKGdyYXBocWw6IEV4ZWN1dGFibGVHcmFwaHFsKSB7XG4gICAgY29uc3QgZ2V0SGVhZGVyczogR2V0SGVhZGVycyA9IHR5cGVvZiBncmFwaHFsLmhlYWRlcnMgPT09ICdmdW5jdGlvbicgXG4gICAgICA/IGdyYXBocWwuaGVhZGVycyBcbiAgICAgIDogKCkgPT4gUHJvbWlzZS5yZXNvbHZlKGdyYXBocWwuaGVhZGVycyBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTtcbiAgICByZXR1cm4gdGhpcy5hcG9sbG9DbGllbnRNYW5hZ2VyLmdldENsaWVudChncmFwaHFsLmVuZHBvaW50LCBnZXRIZWFkZXJzKS5waXBlKFxuICAgICAgc3dpdGNoTWFwKChjbGllbnQpID0+IGNsaWVudC5zdWJzY3JpYmU8UmVjb3JkPHN0cmluZywgYW55Pj4oe1xuICAgICAgICBxdWVyeTogZ3FsYCR7Z3JhcGhxbC5xdWVyeX1gLFxuICAgICAgICB2YXJpYWJsZXM6IGdyYXBocWwudmFyaWFibGVzLFxuICAgICAgICBmZXRjaFBvbGljeTogJ25ldHdvcmstb25seScsXG4gICAgICB9KSksXG4gICAgKTtcbiAgfVxuXG4gIHF1ZXJ5KGdyYXBocWw6IEV4ZWN1dGFibGVHcmFwaHFsKSB7XG4gICAgY29uc3QgZ2V0SGVhZGVyczogR2V0SGVhZGVycyA9IHR5cGVvZiBncmFwaHFsLmhlYWRlcnMgPT09ICdmdW5jdGlvbicgXG4gICAgICA/IGdyYXBocWwuaGVhZGVycyBcbiAgICAgIDogKCkgPT4gUHJvbWlzZS5yZXNvbHZlKGdyYXBocWwuaGVhZGVycyBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTtcbiAgICByZXR1cm4gdGhpcy5hcG9sbG9DbGllbnRNYW5hZ2VyLmdldENsaWVudChncmFwaHFsLmVuZHBvaW50LCBnZXRIZWFkZXJzKS5waXBlKFxuICAgICAgc3dpdGNoTWFwKChjbGllbnQpID0+IGNsaWVudC5xdWVyeTxSZWNvcmQ8c3RyaW5nLCBhbnk+Pih7XG4gICAgICAgIHF1ZXJ5OiBncWxgJHtncmFwaHFsLnF1ZXJ5fWAsXG4gICAgICAgIHZhcmlhYmxlczogZ3JhcGhxbC52YXJpYWJsZXMsXG4gICAgICAgIGZldGNoUG9saWN5OiAnbmV0d29yay1vbmx5JyxcbiAgICAgIH0pKSxcbiAgICApO1xuICB9XG5cbiAgZ2V0U2NoZW1hKGdyYXBocWw6IEV4ZWN1dGFibGVHZXRTY2hlbWFHcmFwaHFsKTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICBjb25zdCBnZXRIZWFkZXJzOiBHZXRIZWFkZXJzID0gdHlwZW9mIGdyYXBocWwuaGVhZGVycyA9PT0gJ2Z1bmN0aW9uJyBcbiAgICAgID8gZ3JhcGhxbC5oZWFkZXJzIFxuICAgICAgOiAoKSA9PiBQcm9taXNlLnJlc29sdmUoZ3JhcGhxbC5oZWFkZXJzIGFzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4pO1xuICAgIHJldHVybiB0aGlzLmFwb2xsb0NsaWVudE1hbmFnZXIuZ2V0Q2xpZW50KGdyYXBocWwuZW5kcG9pbnQsIGdldEhlYWRlcnMpLnBpcGUoXG4gICAgICBzd2l0Y2hNYXAoKGNsaWVudCkgPT4gY2xpZW50LnF1ZXJ5PFJlY29yZDxzdHJpbmcsIGFueT4+KHtcbiAgICAgICAgcXVlcnk6IGdxbGAke2dldEludHJvc3BlY3Rpb25RdWVyeSgpfWAsXG4gICAgICAgIHZhcmlhYmxlczoge30sXG4gICAgICAgIGZldGNoUG9saWN5OiAnbmV0d29yay1vbmx5JyxcbiAgICAgIH0pKSxcbiAgICApO1xuICB9XG59XG4iXX0=","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieHhtYWNoaW5hLWNvbW1vbi1zZXJ2aWNlcy1ncmFwaHFsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQHh4bWFjaGluYS9jb21tb24vc3JjL2xpYi9zZXJ2aWNlcy9ncmFwaHFsL3h4bWFjaGluYS1jb21tb24tc2VydmljZXMtZ3JhcGhxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"xxmachina-common-services-graphql.mjs","sources":["../tmp-esm2022/services/graphql/graphql.service.js","../tmp-esm2022/services/graphql/subscription-splitter/ast-splitter.service.js","../tmp-esm2022/services/graphql/graphql-enhanced.service.js","../tmp-esm2022/services/graphql/graphql-enhanced.provider.js","../tmp-esm2022/services/graphql/xxmachina-common-services-graphql.js"],"sourcesContent":["import { inject, Injectable } from \"@angular/core\";\nimport { ApolloClientManagerService } from \"@nx-ddd/hasura\";\nimport { switchMap } from \"rxjs\";\nimport { gql } from \"apollo-angular\";\nimport { getIntrospectionQuery } from \"graphql\";\nimport * as i0 from \"@angular/core\";\nexport class GraphqlService {\n apolloClientManager = inject(ApolloClientManagerService);\n /**\n * @TODO\n * this.apolloMulti.getClientはendpoint単位でApolloClientを管理しているため、\n * _query.graphql.headersに認証情報などが含まれていないリクエストが初めに来ると、\n * {message: 'no subscriptions exist}のようなエラーが出る。\n * Headersが更新されるたびに、ApolloClientを再生成するような処理も必要。\n */\n subscribe(graphql) {\n const getHeaders = typeof graphql.headers === 'function'\n ? graphql.headers\n : () => Promise.resolve(graphql.headers);\n return this.apolloClientManager.getClient(graphql.endpoint, getHeaders).pipe(switchMap((client) => client.subscribe({\n query: gql `${graphql.query}`,\n variables: graphql.variables,\n fetchPolicy: 'network-only',\n })));\n }\n query(graphql) {\n const getHeaders = typeof graphql.headers === 'function'\n ? graphql.headers\n : () => Promise.resolve(graphql.headers);\n return this.apolloClientManager.getClient(graphql.endpoint, getHeaders).pipe(switchMap((client) => client.query({\n query: gql `${graphql.query}`,\n variables: graphql.variables,\n fetchPolicy: 'network-only',\n })));\n }\n getSchema(graphql) {\n const getHeaders = typeof graphql.headers === 'function'\n ? graphql.headers\n : () => Promise.resolve(graphql.headers);\n return this.apolloClientManager.getClient(graphql.endpoint, getHeaders).pipe(switchMap((client) => client.query({\n query: gql `${getIntrospectionQuery()}`,\n variables: {},\n fetchPolicy: 'network-only',\n })));\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlService, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlService, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'root' }]\n }] });\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGhxbC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQHh4bWFjaGluYS9jb21tb24vc3JjL2xpYi9zZXJ2aWNlcy9ncmFwaHFsL2dyYXBocWwuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVuRCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM1RCxPQUFPLEVBQWMsU0FBUyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQzdDLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNyQyxPQUFPLEVBQWdCLHFCQUFxQixFQUFFLE1BQU0sU0FBUyxDQUFDOztBQVk5RCxNQUFNLE9BQU8sY0FBYztJQUNoQixtQkFBbUIsR0FBRyxNQUFNLENBQUMsMEJBQTBCLENBQUMsQ0FBQztJQUVsRTs7Ozs7O09BTUc7SUFDSCxTQUFTLENBQUMsT0FBMEI7UUFDbEMsTUFBTSxVQUFVLEdBQWUsT0FBTyxPQUFPLENBQUMsT0FBTyxLQUFLLFVBQVU7WUFDbEUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxPQUFPO1lBQ2pCLENBQUMsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxPQUFpQyxDQUFDLENBQUM7UUFDckUsT0FBTyxJQUFJLENBQUMsbUJBQW1CLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLENBQUMsSUFBSSxDQUMxRSxTQUFTLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQXNCO1lBQzFELEtBQUssRUFBRSxHQUFHLENBQUEsR0FBRyxPQUFPLENBQUMsS0FBSyxFQUFFO1lBQzVCLFNBQVMsRUFBRSxPQUFPLENBQUMsU0FBUztZQUM1QixXQUFXLEVBQUUsY0FBYztTQUM1QixDQUFDLENBQUMsQ0FDSixDQUFDO0lBQ0osQ0FBQztJQUVELEtBQUssQ0FBQyxPQUEwQjtRQUM5QixNQUFNLFVBQVUsR0FBZSxPQUFPLE9BQU8sQ0FBQyxPQUFPLEtBQUssVUFBVTtZQUNsRSxDQUFDLENBQUMsT0FBTyxDQUFDLE9BQU87WUFDakIsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQWlDLENBQUMsQ0FBQztRQUNyRSxPQUFPLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLFFBQVEsRUFBRSxVQUFVLENBQUMsQ0FBQyxJQUFJLENBQzFFLFNBQVMsQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBc0I7WUFDdEQsS0FBSyxFQUFFLEdBQUcsQ0FBQSxHQUFHLE9BQU8sQ0FBQyxLQUFLLEVBQUU7WUFDNUIsU0FBUyxFQUFFLE9BQU8sQ0FBQyxTQUFTO1lBQzVCLFdBQVcsRUFBRSxjQUFjO1NBQzVCLENBQUMsQ0FBQyxDQUNKLENBQUM7SUFDSixDQUFDO0lBRUQsU0FBUyxDQUFDLE9BQW1DO1FBQzNDLE1BQU0sVUFBVSxHQUFlLE9BQU8sT0FBTyxDQUFDLE9BQU8sS0FBSyxVQUFVO1lBQ2xFLENBQUMsQ0FBQyxPQUFPLENBQUMsT0FBTztZQUNqQixDQUFDLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBaUMsQ0FBQyxDQUFDO1FBQ3JFLE9BQU8sSUFBSSxDQUFDLG1CQUFtQixDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxDQUFDLElBQUksQ0FDMUUsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFzQjtZQUN0RCxLQUFLLEVBQUUsR0FBRyxDQUFBLEdBQUcscUJBQXFCLEVBQUUsRUFBRTtZQUN0QyxTQUFTLEVBQUUsRUFBRTtZQUNiLFdBQVcsRUFBRSxjQUFjO1NBQzVCLENBQUMsQ0FBQyxDQUNKLENBQUM7SUFDSixDQUFDO3VHQS9DVSxjQUFjOzJHQUFkLGNBQWMsY0FERixNQUFNOzsyRkFDbEIsY0FBYztrQkFEMUIsVUFBVTttQkFBQyxFQUFDLFVBQVUsRUFBRSxNQUFNLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpbmplY3QsIEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0IHsgR2V0SGVhZGVycyB9IGZyb20gXCJAbngtZGRkL2hhc3VyYVwiO1xuaW1wb3J0IHsgQXBvbGxvQ2xpZW50TWFuYWdlclNlcnZpY2UgfSBmcm9tIFwiQG54LWRkZC9oYXN1cmFcIjtcbmltcG9ydCB7IE9ic2VydmFibGUsIHN3aXRjaE1hcCB9IGZyb20gXCJyeGpzXCI7XG5pbXBvcnQgeyBncWwgfSBmcm9tIFwiYXBvbGxvLWFuZ3VsYXJcIjtcbmltcG9ydCB7IERvY3VtZW50Tm9kZSwgZ2V0SW50cm9zcGVjdGlvblF1ZXJ5IH0gZnJvbSBcImdyYXBocWxcIjtcblxuZXhwb3J0IGludGVyZmFjZSBFeGVjdXRhYmxlR3JhcGhxbCB7XG4gIGVuZHBvaW50OiBzdHJpbmc7XG4gIHF1ZXJ5OiBzdHJpbmcgfCBEb2N1bWVudE5vZGU7XG4gIHZhcmlhYmxlczogb2JqZWN0O1xuICBoZWFkZXJzOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+IHwgR2V0SGVhZGVycztcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0YWJsZUdldFNjaGVtYUdyYXBocWwgPSBQaWNrPEV4ZWN1dGFibGVHcmFwaHFsLCAnZW5kcG9pbnQnIHwgJ2hlYWRlcnMnPjtcblxuQEluamVjdGFibGUoe3Byb3ZpZGVkSW46ICdyb290J30pXG5leHBvcnQgY2xhc3MgR3JhcGhxbFNlcnZpY2Uge1xuICByZWFkb25seSBhcG9sbG9DbGllbnRNYW5hZ2VyID0gaW5qZWN0KEFwb2xsb0NsaWVudE1hbmFnZXJTZXJ2aWNlKTtcblxuICAvKipcbiAgICogQFRPRE9cbiAgICogdGhpcy5hcG9sbG9NdWx0aS5nZXRDbGllbnTjga9lbmRwb2ludOWNmOS9jeOBp0Fwb2xsb0NsaWVudOOCkueuoeeQhuOBl+OBpuOBhOOCi+OBn+OCgeOAgVxuICAgKiBfcXVlcnkuZ3JhcGhxbC5oZWFkZXJz44Gr6KqN6Ki85oOF5aCx44Gq44Gp44GM5ZCr44G+44KM44Gm44GE44Gq44GE44Oq44Kv44Ko44K544OI44GM5Yid44KB44Gr5p2l44KL44Go44CBXG4gICAqIHttZXNzYWdlOiAnbm8gc3Vic2NyaXB0aW9ucyBleGlzdH3jga7jgojjgYbjgarjgqjjg6njg7zjgYzlh7rjgovjgIJcbiAgICogSGVhZGVyc+OBjOabtOaWsOOBleOCjOOCi+OBn+OBs+OBq+OAgUFwb2xsb0NsaWVudOOCkuWGjeeUn+aIkOOBmeOCi+OCiOOBhuOBquWHpueQhuOCguW/heimgeOAglxuICAgKi9cbiAgc3Vic2NyaWJlKGdyYXBocWw6IEV4ZWN1dGFibGVHcmFwaHFsKSB7XG4gICAgY29uc3QgZ2V0SGVhZGVyczogR2V0SGVhZGVycyA9IHR5cGVvZiBncmFwaHFsLmhlYWRlcnMgPT09ICdmdW5jdGlvbicgXG4gICAgICA/IGdyYXBocWwuaGVhZGVycyBcbiAgICAgIDogKCkgPT4gUHJvbWlzZS5yZXNvbHZlKGdyYXBocWwuaGVhZGVycyBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTtcbiAgICByZXR1cm4gdGhpcy5hcG9sbG9DbGllbnRNYW5hZ2VyLmdldENsaWVudChncmFwaHFsLmVuZHBvaW50LCBnZXRIZWFkZXJzKS5waXBlKFxuICAgICAgc3dpdGNoTWFwKChjbGllbnQpID0+IGNsaWVudC5zdWJzY3JpYmU8UmVjb3JkPHN0cmluZywgYW55Pj4oe1xuICAgICAgICBxdWVyeTogZ3FsYCR7Z3JhcGhxbC5xdWVyeX1gLFxuICAgICAgICB2YXJpYWJsZXM6IGdyYXBocWwudmFyaWFibGVzLFxuICAgICAgICBmZXRjaFBvbGljeTogJ25ldHdvcmstb25seScsXG4gICAgICB9KSksXG4gICAgKTtcbiAgfVxuXG4gIHF1ZXJ5KGdyYXBocWw6IEV4ZWN1dGFibGVHcmFwaHFsKSB7XG4gICAgY29uc3QgZ2V0SGVhZGVyczogR2V0SGVhZGVycyA9IHR5cGVvZiBncmFwaHFsLmhlYWRlcnMgPT09ICdmdW5jdGlvbicgXG4gICAgICA/IGdyYXBocWwuaGVhZGVycyBcbiAgICAgIDogKCkgPT4gUHJvbWlzZS5yZXNvbHZlKGdyYXBocWwuaGVhZGVycyBhcyBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+KTtcbiAgICByZXR1cm4gdGhpcy5hcG9sbG9DbGllbnRNYW5hZ2VyLmdldENsaWVudChncmFwaHFsLmVuZHBvaW50LCBnZXRIZWFkZXJzKS5waXBlKFxuICAgICAgc3dpdGNoTWFwKChjbGllbnQpID0+IGNsaWVudC5xdWVyeTxSZWNvcmQ8c3RyaW5nLCBhbnk+Pih7XG4gICAgICAgIHF1ZXJ5OiBncWxgJHtncmFwaHFsLnF1ZXJ5fWAsXG4gICAgICAgIHZhcmlhYmxlczogZ3JhcGhxbC52YXJpYWJsZXMsXG4gICAgICAgIGZldGNoUG9saWN5OiAnbmV0d29yay1vbmx5JyxcbiAgICAgIH0pKSxcbiAgICApO1xuICB9XG5cbiAgZ2V0U2NoZW1hKGdyYXBocWw6IEV4ZWN1dGFibGVHZXRTY2hlbWFHcmFwaHFsKTogT2JzZXJ2YWJsZTxhbnk+IHtcbiAgICBjb25zdCBnZXRIZWFkZXJzOiBHZXRIZWFkZXJzID0gdHlwZW9mIGdyYXBocWwuaGVhZGVycyA9PT0gJ2Z1bmN0aW9uJyBcbiAgICAgID8gZ3JhcGhxbC5oZWFkZXJzIFxuICAgICAgOiAoKSA9PiBQcm9taXNlLnJlc29sdmUoZ3JhcGhxbC5oZWFkZXJzIGFzIFJlY29yZDxzdHJpbmcsIHN0cmluZz4pO1xuICAgIHJldHVybiB0aGlzLmFwb2xsb0NsaWVudE1hbmFnZXIuZ2V0Q2xpZW50KGdyYXBocWwuZW5kcG9pbnQsIGdldEhlYWRlcnMpLnBpcGUoXG4gICAgICBzd2l0Y2hNYXAoKGNsaWVudCkgPT4gY2xpZW50LnF1ZXJ5PFJlY29yZDxzdHJpbmcsIGFueT4+KHtcbiAgICAgICAgcXVlcnk6IGdxbGAke2dldEludHJvc3BlY3Rpb25RdWVyeSgpfWAsXG4gICAgICAgIHZhcmlhYmxlczoge30sXG4gICAgICAgIGZldGNoUG9saWN5OiAnbmV0d29yay1vbmx5JyxcbiAgICAgIH0pKSxcbiAgICApO1xuICB9XG59XG4iXX0=","import { Injectable } from '@angular/core';\nimport { parse, print, visit, Kind, OperationTypeNode } from 'graphql';\nimport { combineLatest, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport * as i0 from \"@angular/core\";\n/**\n * AST-based subscription splitter service\n * GraphQL ASTを使用して正確にサブスクリプションを分割\n */\nexport class AstSubscriptionSplitterService {\n splitSubscription(query) {\n const document = typeof query === 'string' ? parse(query) : query;\n // Find the subscription operation\n let subscriptionOp;\n visit(document, {\n OperationDefinition(node) {\n if (node.operation === OperationTypeNode.SUBSCRIPTION) {\n subscriptionOp = node;\n }\n }\n });\n if (!subscriptionOp || !subscriptionOp.selectionSet.selections.length) {\n return [];\n }\n const results = [];\n // Process each field in the subscription\n subscriptionOp.selectionSet.selections.forEach(selection => {\n if (selection.kind === Kind.FIELD) {\n const field = selection;\n const fieldName = field.alias?.value || field.name.value;\n // Extract variables used in this field\n const usedVariables = this.extractUsedVariables(field);\n // Create a new subscription with only this field and its used variables\n const newDoc = {\n kind: Kind.DOCUMENT,\n definitions: [{\n kind: Kind.OPERATION_DEFINITION,\n operation: OperationTypeNode.SUBSCRIPTION,\n name: subscriptionOp.name ? {\n kind: Kind.NAME,\n value: subscriptionOp.name.value\n } : undefined,\n variableDefinitions: this.filterVariableDefinitions(subscriptionOp.variableDefinitions || [], usedVariables),\n selectionSet: {\n kind: Kind.SELECTION_SET,\n selections: [field]\n }\n }]\n };\n results.push({\n fieldName: field.name.value,\n query: print(newDoc)\n });\n }\n });\n return results;\n }\n /**\n * Extract variables used in a field and its subfields\n */\n extractUsedVariables(field) {\n const usedVars = new Set();\n // Visit all nodes in the field to find variable references\n visit(field, {\n Variable(node) {\n usedVars.add(node.name.value);\n }\n });\n return usedVars;\n }\n /**\n * Filter variable definitions to only include used variables\n */\n filterVariableDefinitions(definitions, usedVariables) {\n return definitions.filter(def => usedVariables.has(def.variable.name.value));\n }\n /**\n * Combine multiple observables from split queries\n */\n combineResults(results, fieldNames) {\n if (results.length === 0) {\n return of({});\n }\n if (results.length === 1) {\n return results[0];\n }\n return combineLatest(results).pipe(map(data => {\n const combined = {};\n fieldNames.forEach((fieldName, index) => {\n if (data[index] && typeof data[index] === 'object') {\n Object.keys(data[index]).forEach(key => {\n if (combined[key]) {\n if (Array.isArray(combined[key])) {\n combined[key] = [...combined[key], ...(Array.isArray(data[index][key]) ? data[index][key] : [data[index][key]])];\n }\n else {\n combined[key] = [combined[key], data[index][key]];\n }\n }\n else {\n combined[key] = data[index][key];\n }\n });\n }\n });\n return combined;\n }));\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AstSubscriptionSplitterService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AstSubscriptionSplitterService, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: AstSubscriptionSplitterService, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'root' }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ast-splitter.service.js","sourceRoot":"","sources":["../../../../../../../../packages/@xxmachina/common/src/lib/services/graphql/subscription-splitter/ast-splitter.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { \n  DocumentNode, \n  parse, \n  print,\n  visit,\n  OperationDefinitionNode,\n  FieldNode,\n  VariableDefinitionNode,\n  SelectionSetNode,\n  ArgumentNode,\n  Kind,\n  OperationTypeNode\n} from 'graphql';\nimport { Observable, combineLatest, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\n\n/**\n * AST-based subscription splitter service\n * GraphQL ASTを使用して正確にサブスクリプションを分割\n */\n@Injectable({ providedIn: 'root' })\nexport class AstSubscriptionSplitterService {\n  \n  splitSubscription(query: string | DocumentNode): { fieldName: string; query: string }[] {\n    const document = typeof query === 'string' ? parse(query) : query;\n    \n    // Find the subscription operation\n    let subscriptionOp: OperationDefinitionNode | undefined;\n    visit(document, {\n      OperationDefinition(node) {\n        if (node.operation === OperationTypeNode.SUBSCRIPTION) {\n          subscriptionOp = node;\n        }\n      }\n    });\n    \n    if (!subscriptionOp || !subscriptionOp.selectionSet.selections.length) {\n      return [];\n    }\n    \n    const results: { fieldName: string; query: string }[] = [];\n    \n    // Process each field in the subscription\n    subscriptionOp.selectionSet.selections.forEach(selection => {\n      if (selection.kind === Kind.FIELD) {\n        const field = selection as FieldNode;\n        const fieldName = field.alias?.value || field.name.value;\n        \n        // Extract variables used in this field\n        const usedVariables = this.extractUsedVariables(field);\n        \n        // Create a new subscription with only this field and its used variables\n        const newDoc: DocumentNode = {\n          kind: Kind.DOCUMENT,\n          definitions: [{\n            kind: Kind.OPERATION_DEFINITION,\n            operation: OperationTypeNode.SUBSCRIPTION,\n            name: subscriptionOp.name ? {\n              kind: Kind.NAME,\n              value: subscriptionOp.name.value\n            } : undefined,\n            variableDefinitions: this.filterVariableDefinitions(\n              subscriptionOp.variableDefinitions || [],\n              usedVariables\n            ),\n            selectionSet: {\n              kind: Kind.SELECTION_SET,\n              selections: [field]\n            }\n          }]\n        };\n        \n        results.push({\n          fieldName: field.name.value,\n          query: print(newDoc)\n        });\n      }\n    });\n    \n    return results;\n  }\n  \n  /**\n   * Extract variables used in a field and its subfields\n   */\n  private extractUsedVariables(field: FieldNode): Set<string> {\n    const usedVars = new Set<string>();\n    \n    // Visit all nodes in the field to find variable references\n    visit(field, {\n      Variable(node) {\n        usedVars.add(node.name.value);\n      }\n    });\n    \n    return usedVars;\n  }\n  \n  /**\n   * Filter variable definitions to only include used variables\n   */\n  private filterVariableDefinitions(\n    definitions: ReadonlyArray<VariableDefinitionNode>,\n    usedVariables: Set<string>\n  ): VariableDefinitionNode[] {\n    return definitions.filter(def => \n      usedVariables.has(def.variable.name.value)\n    );\n  }\n  \n  /**\n   * Combine multiple observables from split queries\n   */\n  combineResults(\n    results: Observable<any>[],\n    fieldNames: string[]\n  ): Observable<any> {\n    if (results.length === 0) {\n      return of({});\n    }\n    \n    if (results.length === 1) {\n      return results[0];\n    }\n    \n    return combineLatest(results).pipe(\n      map(data => {\n        const combined: any = {};\n        fieldNames.forEach((fieldName, index) => {\n          if (data[index] && typeof data[index] === 'object') {\n            Object.keys(data[index]).forEach(key => {\n              if (combined[key]) {\n                if (Array.isArray(combined[key])) {\n                  combined[key] = [...combined[key], ...(Array.isArray(data[index][key]) ? data[index][key] : [data[index][key]])];\n                } else {\n                  combined[key] = [combined[key], data[index][key]];\n                }\n              } else {\n                combined[key] = data[index][key];\n              }\n            });\n          }\n        });\n        return combined;\n      })\n    );\n  }\n}"]}","import { inject, Injectable } from '@angular/core';\nimport { combineLatest } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { GraphqlService } from './graphql.service';\nimport { AstSubscriptionSplitterService } from './subscription-splitter/ast-splitter.service';\nimport * as i0 from \"@angular/core\";\n/**\n * GraphqlServiceを拡張して、subscription分割機能を追加\n *\n * GraphQL/Hasuraの制限「1つのsubscriptionには1つのトップレベルフィールドのみ」を回避し、\n * 複数のフィールドを含むsubscriptionを自動的に分割して並列実行します。\n */\nexport class GraphqlEnhancedService extends GraphqlService {\n splitter = inject(AstSubscriptionSplitterService);\n /**\n * subscriptionクエリを実行\n * デフォルトでsubscriptionは自動的に分割される\n */\n subscribe(graphql) {\n // enableSplittingが明示的にfalseの場合、またはsubscriptionでない場合は通常の処理\n const shouldSplit = graphql.enableSplitting !== false && this.isSubscription(graphql.query);\n if (!shouldSplit) {\n // 未使用変数を削除してから実行\n const filteredGraphql = this.removeUnusedVariables(graphql);\n return super.subscribe(filteredGraphql);\n }\n // subscriptionを分割して実行\n return this.subscribeSplit(graphql);\n }\n /**\n * subscriptionクエリを分割して並列実行し、結果を結合\n */\n subscribeSplit(graphql) {\n const queryStr = typeof graphql.query === 'string' ? graphql.query : graphql.query.loc?.source?.body || '';\n // クエリを分割\n const splitQueries = this.splitter.splitSubscription(graphql.query);\n // 分割が不要な場合(単一フィールド)\n if (splitQueries.length <= 1) {\n return super.subscribe(graphql);\n }\n // 各クエリを並列実行\n const observables = splitQueries.map((splitQuery) => {\n // 使用される変数のみを抽出\n const usedVars = this.extractUsedVariablesFromQuery(splitQuery.query);\n const filteredVariables = this.filterVariableValues(graphql.variables, usedVars);\n const splitGraphql = {\n ...graphql,\n query: splitQuery.query,\n variables: filteredVariables\n };\n return super.subscribe(splitGraphql).pipe(map(result => ({\n fieldName: splitQuery.fieldName,\n result\n })));\n });\n // 結果を結合\n return combineLatest(observables).pipe(map(results => {\n const combinedData = {};\n results.forEach(({ fieldName, result }) => {\n const data = result.data || result;\n if (data[fieldName] !== undefined) {\n combinedData[fieldName] = data[fieldName];\n }\n });\n return {\n data: combinedData,\n loading: false,\n networkStatus: 7\n };\n }));\n }\n /**\n * クエリがsubscriptionかどうかを判定\n */\n isSubscription(query) {\n const queryStr = typeof query === 'string' ? query : query.loc?.source?.body || '';\n return queryStr.trim().startsWith('subscription');\n }\n /**\n * クエリから使用されている変数を抽出\n */\n extractUsedVariablesFromQuery(query) {\n const variables = new Set();\n const regex = /\\$(\\w+)/g;\n let match;\n while ((match = regex.exec(query)) !== null) {\n variables.add(match[1]);\n }\n return variables;\n }\n /**\n * 変数値から使用される変数のみをフィルタリング\n */\n filterVariableValues(variables, usedVars) {\n const filtered = {};\n for (const [key, value] of Object.entries(variables)) {\n if (usedVars.has(key)) {\n filtered[key] = value;\n }\n }\n return filtered;\n }\n /**\n * GraphQLクエリから未使用の変数を削除\n */\n removeUnusedVariables(graphql) {\n if (!graphql.variables || Object.keys(graphql.variables).length === 0) {\n return graphql;\n }\n const queryStr = typeof graphql.query === 'string' ? graphql.query : graphql.query.loc?.source?.body || '';\n const usedVars = this.extractUsedVariablesFromQuery(queryStr);\n const filteredVariables = this.filterVariableValues(graphql.variables, usedVars);\n return {\n ...graphql,\n variables: filteredVariables\n };\n }\n static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlEnhancedService, deps: null, target: i0.ɵɵFactoryTarget.Injectable });\n static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlEnhancedService, providedIn: 'root' });\n}\ni0.ɵɵngDeclareClassMetadata({ minVersion: \"12.0.0\", version: \"20.0.5\", ngImport: i0, type: GraphqlEnhancedService, decorators: [{\n type: Injectable,\n args: [{ providedIn: 'root' }]\n }] });\n//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"graphql-enhanced.service.js","sourceRoot":"","sources":["../../../../../../../packages/@xxmachina/common/src/lib/services/graphql/graphql-enhanced.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { Observable, combineLatest, of } from 'rxjs';\nimport { map } from 'rxjs/operators';\nimport { DocumentNode } from 'graphql';\nimport { GraphqlService, ExecutableGraphql } from './graphql.service';\nimport { AstSubscriptionSplitterService } from './subscription-splitter/ast-splitter.service';\nimport { FetchResult } from '@apollo/client/core';\n\nexport interface ExecutableGraphqlWithSplitting extends ExecutableGraphql {\n  enableSplitting?: boolean;\n}\n\n/**\n * GraphqlServiceを拡張して、subscription分割機能を追加\n * \n * GraphQL/Hasuraの制限「1つのsubscriptionには1つのトップレベルフィールドのみ」を回避し、\n * 複数のフィールドを含むsubscriptionを自動的に分割して並列実行します。\n */\n@Injectable({ providedIn: 'root' })\nexport class GraphqlEnhancedService extends GraphqlService {\n  private readonly splitter = inject(AstSubscriptionSplitterService);\n\n  /**\n   * subscriptionクエリを実行\n   * デフォルトでsubscriptionは自動的に分割される\n   */\n  override subscribe(graphql: ExecutableGraphqlWithSplitting): Observable<FetchResult<any>> {\n    // enableSplittingが明示的にfalseの場合、またはsubscriptionでない場合は通常の処理\n    const shouldSplit = graphql.enableSplitting !== false && this.isSubscription(graphql.query);\n    \n    if (!shouldSplit) {\n      // 未使用変数を削除してから実行\n      const filteredGraphql = this.removeUnusedVariables(graphql);\n      return super.subscribe(filteredGraphql);\n    }\n\n    // subscriptionを分割して実行\n    return this.subscribeSplit(graphql);\n  }\n\n  /**\n   * subscriptionクエリを分割して並列実行し、結果を結合\n   */\n  private subscribeSplit(graphql: ExecutableGraphql): Observable<FetchResult<any>> {\n    const queryStr = typeof graphql.query === 'string' ? graphql.query : graphql.query.loc?.source?.body || '';\n    \n    // クエリを分割\n    const splitQueries = this.splitter.splitSubscription(graphql.query);\n    \n    // 分割が不要な場合（単一フィールド）\n    if (splitQueries.length <= 1) {\n      return super.subscribe(graphql);\n    }\n\n    \n    // 各クエリを並列実行\n    const observables = splitQueries.map((splitQuery) => {\n      // 使用される変数のみを抽出\n      const usedVars = this.extractUsedVariablesFromQuery(splitQuery.query);\n      const filteredVariables = this.filterVariableValues(graphql.variables, usedVars);\n      \n      const splitGraphql: ExecutableGraphql = {\n        ...graphql,\n        query: splitQuery.query,\n        variables: filteredVariables\n      };\n      \n      return super.subscribe(splitGraphql).pipe(\n        map(result => ({\n          fieldName: splitQuery.fieldName,\n          result\n        }))\n      );\n    });\n\n    // 結果を結合\n    return combineLatest(observables).pipe(\n      map(results => {\n        const combinedData: any = {};\n        \n        results.forEach(({ fieldName, result }) => {\n          const data = result.data || result;\n          if (data[fieldName] !== undefined) {\n            combinedData[fieldName] = data[fieldName];\n          }\n        });\n        \n        return {\n          data: combinedData,\n          loading: false,\n          networkStatus: 7\n        } as FetchResult;\n      })\n    );\n  }\n\n  /**\n   * クエリがsubscriptionかどうかを判定\n   */\n  private isSubscription(query: string | DocumentNode): boolean {\n    const queryStr = typeof query === 'string' ? query : query.loc?.source?.body || '';\n    return queryStr.trim().startsWith('subscription');\n  }\n  \n  /**\n   * クエリから使用されている変数を抽出\n   */\n  private extractUsedVariablesFromQuery(query: string): Set<string> {\n    const variables = new Set<string>();\n    const regex = /\\$(\\w+)/g;\n    let match;\n    \n    while ((match = regex.exec(query)) !== null) {\n      variables.add(match[1]);\n    }\n    \n    return variables;\n  }\n  \n  /**\n   * 変数値から使用される変数のみをフィルタリング\n   */\n  private filterVariableValues(variables: object, usedVars: Set<string>): object {\n    const filtered: any = {};\n    \n    for (const [key, value] of Object.entries(variables)) {\n      if (usedVars.has(key)) {\n        filtered[key] = value;\n      }\n    }\n    \n    return filtered;\n  }\n\n  /**\n   * GraphQLクエリから未使用の変数を削除\n   */\n  private removeUnusedVariables(graphql: ExecutableGraphql): ExecutableGraphql {\n    if (!graphql.variables || Object.keys(graphql.variables).length === 0) {\n      return graphql;\n    }\n\n    const queryStr = typeof graphql.query === 'string' ? graphql.query : graphql.query.loc?.source?.body || '';\n    const usedVars = this.extractUsedVariablesFromQuery(queryStr);\n    const filteredVariables = this.filterVariableValues(graphql.variables, usedVars);\n\n\n    return {\n      ...graphql,\n      variables: filteredVariables\n    };\n  }\n}"]}","import { GraphqlService } from './graphql.service';\nimport { GraphqlEnhancedService } from './graphql-enhanced.service';\n/**\n * GraphqlServiceをGraphqlEnhancedServiceで置き換えるプロバイダー\n *\n * 使用方法:\n * ```typescript\n * export default <Routes>[\n * {\n * path: '',\n * component: YourComponent,\n * providers: [\n * provideGraphqlEnhancedLocally()\n * ]\n * }\n * ];\n * ```\n */\nexport function provideGraphqlEnhancedLocally() {\n return [\n {\n provide: GraphqlService,\n useClass: GraphqlEnhancedService\n }\n ];\n}\n/**\n * グローバルにGraphqlEnhancedServiceを提供\n * app.config.tsで使用\n */\nexport function provideGraphqlEnhancedGlobally() {\n return provideGraphqlEnhancedLocally();\n}\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JhcGhxbC1lbmhhbmNlZC5wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL0B4eG1hY2hpbmEvY29tbW9uL3NyYy9saWIvc2VydmljZXMvZ3JhcGhxbC9ncmFwaHFsLWVuaGFuY2VkLnByb3ZpZGVyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUVwRTs7Ozs7Ozs7Ozs7Ozs7O0dBZUc7QUFDSCxNQUFNLFVBQVUsNkJBQTZCO0lBQzNDLE9BQU87UUFDTDtZQUNFLE9BQU8sRUFBRSxjQUFjO1lBQ3ZCLFFBQVEsRUFBRSxzQkFBc0I7U0FDakM7S0FDRixDQUFDO0FBQ0osQ0FBQztBQUVEOzs7R0FHRztBQUNILE1BQU0sVUFBVSw4QkFBOEI7SUFDNUMsT0FBTyw2QkFBNkIsRUFBRSxDQUFDO0FBQ3pDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgR3JhcGhxbFNlcnZpY2UgfSBmcm9tICcuL2dyYXBocWwuc2VydmljZSc7XG5pbXBvcnQgeyBHcmFwaHFsRW5oYW5jZWRTZXJ2aWNlIH0gZnJvbSAnLi9ncmFwaHFsLWVuaGFuY2VkLnNlcnZpY2UnO1xuXG4vKipcbiAqIEdyYXBocWxTZXJ2aWNl44KSR3JhcGhxbEVuaGFuY2VkU2VydmljZeOBp+e9ruOBjeaPm+OBiOOCi+ODl+ODreODkOOCpOODgOODvFxuICogXG4gKiDkvb/nlKjmlrnms5U6XG4gKiBgYGB0eXBlc2NyaXB0XG4gKiBleHBvcnQgZGVmYXVsdCA8Um91dGVzPltcbiAqICAge1xuICogICAgIHBhdGg6ICcnLFxuICogICAgIGNvbXBvbmVudDogWW91ckNvbXBvbmVudCxcbiAqICAgICBwcm92aWRlcnM6IFtcbiAqICAgICAgIHByb3ZpZGVHcmFwaHFsRW5oYW5jZWRMb2NhbGx5KClcbiAqICAgICBdXG4gKiAgIH1cbiAqIF07XG4gKiBgYGBcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByb3ZpZGVHcmFwaHFsRW5oYW5jZWRMb2NhbGx5KCk6IFByb3ZpZGVyW10ge1xuICByZXR1cm4gW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IEdyYXBocWxTZXJ2aWNlLFxuICAgICAgdXNlQ2xhc3M6IEdyYXBocWxFbmhhbmNlZFNlcnZpY2VcbiAgICB9XG4gIF07XG59XG5cbi8qKlxuICog44Kw44Ot44O844OQ44Or44GrR3JhcGhxbEVuaGFuY2VkU2VydmljZeOCkuaPkOS+m1xuICogYXBwLmNvbmZpZy50c+OBp+S9v+eUqFxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJvdmlkZUdyYXBocWxFbmhhbmNlZEdsb2JhbGx5KCk6IFByb3ZpZGVyW10ge1xuICByZXR1cm4gcHJvdmlkZUdyYXBocWxFbmhhbmNlZExvY2FsbHkoKTtcbn0iXX0=","/**\n * Generated bundle index. Do not edit.\n */\nexport * from './index';\n//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoieHhtYWNoaW5hLWNvbW1vbi1zZXJ2aWNlcy1ncmFwaHFsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQHh4bWFjaGluYS9jb21tb24vc3JjL2xpYi9zZXJ2aWNlcy9ncmFwaHFsL3h4bWFjaGluYS1jb21tb24tc2VydmljZXMtZ3JhcGhxbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ=="],"names":[],"mappings":"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"}
@@ -1,7 +1,5 @@
1
1
  import { Google } from '@xxmachina/common/domain/models';
2
- import { FirestoreAdapter } from '@nx-ddd/firestore/adapters/base';
3
- import { IFirestoreConverter } from '@nx-ddd/firestore/converter';
4
- import { DocumentSnapshot } from '@nx-ddd/firestore/interfaces';
2
+ import { IFirestoreConverter, FirestoreAdapter, DocumentSnapshot } from '@nx-ddd/firestore';
5
3
  import * as i0 from '@angular/core';
6
4
 
7
5
  declare class GoogleConverter implements IFirestoreConverter<Google> {
package/infra/index.d.ts CHANGED
@@ -6,7 +6,7 @@ import * as _nx_ddd_common_infrastructure_externals_openai_impl from '@nx-ddd/co
6
6
  import { OpenAiConfig } from '@nx-ddd/common/infrastructure/externals/openai/impl';
7
7
  import { AiConfig, Operator, Project, Spec, Google } from '@xxmachina/common/domain/models';
8
8
  import { GoogleConverter } from '@xxmachina/common/infra/converters/google';
9
- import { FirestoreRepository as FirestoreRepository$1 } from '@nx-ddd/firestore/repository';
9
+ import { FirestoreRepository as FirestoreRepository$1 } from '@nx-ddd/firestore';
10
10
  import * as _nx_ddd_notion from '@nx-ddd/notion';
11
11
  import { NotionRepository as NotionRepository$1 } from '@nx-ddd/notion';
12
12
  import { Contract, Invoice, Order } from '@xxmachina/common/invoice/domain';
@@ -1,16 +1,16 @@
1
1
  import * as _nx_ddd_firestore from '@nx-ddd/firestore';
2
+ import { FirestoreQueryV2 } from '@nx-ddd/firestore';
2
3
  import { Query, Resource } from '@xxmachina/common/domain/models';
3
- import { FirestoreQuery } from '@nx-ddd/firestore/query/v2';
4
4
  import * as i0 from '@angular/core';
5
5
 
6
- declare class QueryFirestoreQuery extends FirestoreQuery<Query> {
6
+ declare class QueryFirestoreQuery extends FirestoreQueryV2<Query> {
7
7
  readonly collectionPath = "projects/:projectId/queries/:id";
8
8
  protected converter: _nx_ddd_firestore.IFirestoreConverter<Query<any, any>>;
9
9
  static ɵfac: i0.ɵɵFactoryDeclaration<QueryFirestoreQuery, never>;
10
10
  static ɵprov: i0.ɵɵInjectableDeclaration<QueryFirestoreQuery>;
11
11
  }
12
12
 
13
- declare class ResourceFirestoreQuery extends FirestoreQuery<Resource> {
13
+ declare class ResourceFirestoreQuery extends FirestoreQueryV2<Resource> {
14
14
  readonly collectionPath = "projects/:projectId/resources/:id";
15
15
  protected converter: _nx_ddd_firestore.IFirestoreConverter<Resource>;
16
16
  static ɵfac: i0.ɵɵFactoryDeclaration<ResourceFirestoreQuery, never>;
@@ -1,8 +1,8 @@
1
1
  import { Google, Query, Resource } from '@xxmachina/common/domain/models';
2
2
  import { GoogleConverter } from '@xxmachina/common/infra/converters/google';
3
- import { FirestoreRepository as FirestoreRepository$1 } from '@nx-ddd/firestore/repository';
4
- import * as i0 from '@angular/core';
5
3
  import * as _nx_ddd_firestore from '@nx-ddd/firestore';
4
+ import { FirestoreRepository as FirestoreRepository$1 } from '@nx-ddd/firestore';
5
+ import * as i0 from '@angular/core';
6
6
 
7
7
  declare class GoogleRepository extends FirestoreRepository$1<Google> {
8
8
  readonly collectionPath = "users/:userId/links/:id";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xxmachina/common",
3
- "version": "19.2.0",
3
+ "version": "19.3.0",
4
4
  "license": "MIT",
5
5
  "main": "./index.js",
6
6
  "types": "./index.d.ts",
@@ -13,11 +13,11 @@
13
13
  "@nestjs/common": "10.2.8",
14
14
  "@nestjs/graphql": "^11.0.0",
15
15
  "@nestjs/passport": "^9.0.3",
16
- "@ng-atomic/common": "19.2.0",
17
- "@ng-atomic/components": "19.2.0",
18
- "@ng-atomic/core": "19.2.0",
19
- "@nx-ddd/common": "19.2.0",
20
- "@nx-ddd/core": "19.2.0",
16
+ "@ng-atomic/common": "19.3.0",
17
+ "@ng-atomic/components": "19.3.0",
18
+ "@ng-atomic/core": "19.3.0",
19
+ "@nx-ddd/common": "19.3.0",
20
+ "@nx-ddd/core": "19.3.0",
21
21
  "@tfarras/nestjs-firebase-auth": "^2.0.0",
22
22
  "apollo-angular": "^7.0.2",
23
23
  "class-transformer": "^0.5.1",
@@ -43,11 +43,11 @@
43
43
  "validate-azure-ad-token": "^2.2.0"
44
44
  },
45
45
  "optionalDependencies": {
46
- "@nx-ddd/any-func": "19.2.0",
47
- "@nx-ddd/firestore": "19.2.0",
48
- "@nx-ddd/google": "19.2.0",
49
- "@nx-ddd/hasura": "19.2.0",
50
- "@nx-ddd/notion": "19.2.0",
46
+ "@nx-ddd/any-func": "19.3.0",
47
+ "@nx-ddd/firestore": "19.3.0",
48
+ "@nx-ddd/google": "19.3.0",
49
+ "@nx-ddd/hasura": "19.3.0",
50
+ "@nx-ddd/notion": "19.3.0",
51
51
  "@notionhq/client": "^2.2.15"
52
52
  },
53
53
  "dependencies": {
@@ -4,6 +4,8 @@ import { DocumentNode } from 'graphql';
4
4
  import { GetHeaders, ApolloClientManagerService } from '@nx-ddd/hasura';
5
5
  import { Observable } from 'rxjs';
6
6
  import * as i0 from '@angular/core';
7
+ import { Provider } from '@angular/core';
8
+ import { FetchResult } from '@apollo/client/core';
7
9
 
8
10
  interface ExecutableGraphql {
9
11
  endpoint: string;
@@ -28,5 +30,68 @@ declare class GraphqlService {
28
30
  static ɵprov: i0.ɵɵInjectableDeclaration<GraphqlService>;
29
31
  }
30
32
 
31
- export { GraphqlService };
32
- export type { ExecutableGetSchemaGraphql, ExecutableGraphql };
33
+ interface ExecutableGraphqlWithSplitting extends ExecutableGraphql {
34
+ enableSplitting?: boolean;
35
+ }
36
+ /**
37
+ * GraphqlServiceを拡張して、subscription分割機能を追加
38
+ *
39
+ * GraphQL/Hasuraの制限「1つのsubscriptionには1つのトップレベルフィールドのみ」を回避し、
40
+ * 複数のフィールドを含むsubscriptionを自動的に分割して並列実行します。
41
+ */
42
+ declare class GraphqlEnhancedService extends GraphqlService {
43
+ private readonly splitter;
44
+ /**
45
+ * subscriptionクエリを実行
46
+ * デフォルトでsubscriptionは自動的に分割される
47
+ */
48
+ subscribe(graphql: ExecutableGraphqlWithSplitting): Observable<FetchResult<any>>;
49
+ /**
50
+ * subscriptionクエリを分割して並列実行し、結果を結合
51
+ */
52
+ private subscribeSplit;
53
+ /**
54
+ * クエリがsubscriptionかどうかを判定
55
+ */
56
+ private isSubscription;
57
+ /**
58
+ * クエリから使用されている変数を抽出
59
+ */
60
+ private extractUsedVariablesFromQuery;
61
+ /**
62
+ * 変数値から使用される変数のみをフィルタリング
63
+ */
64
+ private filterVariableValues;
65
+ /**
66
+ * GraphQLクエリから未使用の変数を削除
67
+ */
68
+ private removeUnusedVariables;
69
+ static ɵfac: i0.ɵɵFactoryDeclaration<GraphqlEnhancedService, never>;
70
+ static ɵprov: i0.ɵɵInjectableDeclaration<GraphqlEnhancedService>;
71
+ }
72
+
73
+ /**
74
+ * GraphqlServiceをGraphqlEnhancedServiceで置き換えるプロバイダー
75
+ *
76
+ * 使用方法:
77
+ * ```typescript
78
+ * export default <Routes>[
79
+ * {
80
+ * path: '',
81
+ * component: YourComponent,
82
+ * providers: [
83
+ * provideGraphqlEnhancedLocally()
84
+ * ]
85
+ * }
86
+ * ];
87
+ * ```
88
+ */
89
+ declare function provideGraphqlEnhancedLocally(): Provider[];
90
+ /**
91
+ * グローバルにGraphqlEnhancedServiceを提供
92
+ * app.config.tsで使用
93
+ */
94
+ declare function provideGraphqlEnhancedGlobally(): Provider[];
95
+
96
+ export { GraphqlEnhancedService, GraphqlService, provideGraphqlEnhancedGlobally, provideGraphqlEnhancedLocally };
97
+ export type { ExecutableGetSchemaGraphql, ExecutableGraphql, ExecutableGraphqlWithSplitting };