@financial-times/cp-content-pipeline-schema 0.3.5 → 0.4.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/CHANGELOG.md +22 -0
- package/lib/concept.js +2 -2
- package/lib/concept.js.map +1 -1
- package/lib/content.js +2 -0
- package/lib/content.js.map +1 -1
- package/lib/datasources/base.d.ts +9 -0
- package/lib/datasources/base.js +2 -0
- package/lib/datasources/base.js.map +1 -0
- package/lib/datasources/capi.d.ts +4 -2
- package/lib/datasources/capi.js +11 -8
- package/lib/datasources/capi.js.map +1 -1
- package/lib/datasources/index.d.ts +3 -2
- package/lib/datasources/index.js +5 -5
- package/lib/datasources/index.js.map +1 -1
- package/lib/datasources/instrumented.d.ts +9 -4
- package/lib/datasources/instrumented.js +22 -12
- package/lib/datasources/instrumented.js.map +1 -1
- package/lib/datasources/url-management.d.ts +6 -6
- package/lib/datasources/url-management.js +4 -8
- package/lib/datasources/url-management.js.map +1 -1
- package/lib/datasources/url-management.test.js +12 -12
- package/lib/datasources/url-management.test.js.map +1 -1
- package/lib/index.d.ts +4 -4
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/lib/model/CapiResponse.d.ts +1 -1
- package/lib/model/CapiResponse.js +3 -6
- package/lib/model/CapiResponse.js.map +1 -1
- package/lib/types/cache.d.ts +10 -0
- package/lib/types/cache.js +4 -0
- package/lib/types/cache.js.map +1 -0
- package/package.json +4 -3
- package/src/concept.ts +2 -2
- package/src/content.ts +2 -0
- package/src/datasources/base.ts +11 -0
- package/src/datasources/capi.ts +16 -10
- package/src/datasources/index.ts +7 -6
- package/src/datasources/instrumented.ts +47 -21
- package/src/datasources/url-management.test.ts +14 -12
- package/src/datasources/url-management.ts +7 -11
- package/src/index.ts +3 -3
- package/src/model/CapiResponse.ts +3 -8
- package/src/types/cache.ts +17 -0
- package/tsconfig.tsbuildinfo +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,27 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [0.4.1](https://github.com/Financial-Times/cp-content-pipeline/compare/cp-content-pipeline-schema-v0.4.0...cp-content-pipeline-schema-v0.4.1) (2022-11-10)
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
### Bug Fixes
|
|
7
|
+
|
|
8
|
+
* add missing colon to url management cache prefix ([1e613e2](https://github.com/Financial-Times/cp-content-pipeline/commit/1e613e216f97ce16129e7a1b3142aaab7195c9ab))
|
|
9
|
+
* ensure correct cache prefixes for data sources ([95cb3f9](https://github.com/Financial-Times/cp-content-pipeline/commit/95cb3f994c1738406683a6b8a8374a7cce7780a4))
|
|
10
|
+
|
|
11
|
+
## [0.4.0](https://github.com/Financial-Times/cp-content-pipeline/compare/cp-content-pipeline-schema-v0.3.5...cp-content-pipeline-schema-v0.4.0) (2022-11-09)
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
### ⚠ BREAKING CHANGES
|
|
15
|
+
|
|
16
|
+
* This will change the output of concept types that are already in use. For example within teasers
|
|
17
|
+
|
|
18
|
+
### Features
|
|
19
|
+
|
|
20
|
+
* add a cache prefix per datasource ([0722f55](https://github.com/Financial-Times/cp-content-pipeline/commit/0722f55a55c9899fbe2819dcc5121f900d6359b7))
|
|
21
|
+
* migrate to Apollo Server v4 ([47fcd69](https://github.com/Financial-Times/cp-content-pipeline/commit/47fcd6964b4db235fcb2023ce0b72253a8a8dd88))
|
|
22
|
+
* return annotations as part of the article query ([151d59c](https://github.com/Financial-Times/cp-content-pipeline/commit/151d59c5b27cd062a467eca77941a1612ba2320a))
|
|
23
|
+
* return only the uuid for concept ID properties ([7eea0a0](https://github.com/Financial-Times/cp-content-pipeline/commit/7eea0a00c67a92b52fbb5cdf2cc572f0642f3c89))
|
|
24
|
+
|
|
3
25
|
## [0.3.5](https://github.com/Financial-Times/cp-content-pipeline/compare/cp-content-pipeline-schema-v0.3.4...cp-content-pipeline-schema-v0.3.5) (2022-11-01)
|
|
4
26
|
|
|
5
27
|
|
package/lib/concept.js
CHANGED
|
@@ -3,7 +3,7 @@ export const typeDef = gql `
|
|
|
3
3
|
type Concept {
|
|
4
4
|
apiUrl: String!
|
|
5
5
|
directType: String
|
|
6
|
-
id:
|
|
6
|
+
id: ID!
|
|
7
7
|
predicate: String!
|
|
8
8
|
prefLabel: String!
|
|
9
9
|
type: String!
|
|
@@ -15,7 +15,7 @@ export const resolvers = {
|
|
|
15
15
|
Concept: {
|
|
16
16
|
apiUrl: (parent) => parent.apiUrl(),
|
|
17
17
|
directType: (parent) => parent.directType(),
|
|
18
|
-
id: (parent) => parent.
|
|
18
|
+
id: (parent) => parent.uuid(),
|
|
19
19
|
predicate: (parent) => parent.predicate(),
|
|
20
20
|
prefLabel: (parent) => parent.prefLabel(),
|
|
21
21
|
type: (parent) => parent.type(),
|
package/lib/concept.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"concept.js","sourceRoot":"","sources":["../src/concept.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AAIjC,MAAM,CAAC,MAAM,OAAO,GAAG,GAAG,CAAA;;;;;;;;;;;CAWzB,CAAA;AAED,MAAM,CAAC,MAAM,SAAS,GAA6C;IACjE,OAAO,EAAE;QACP,MAAM,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE;QAC5C,UAAU,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE;QACpD,EAAE,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,
|
|
1
|
+
{"version":3,"file":"concept.js","sourceRoot":"","sources":["../src/concept.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AAIjC,MAAM,CAAC,MAAM,OAAO,GAAG,GAAG,CAAA;;;;;;;;;;;CAWzB,CAAA;AAED,MAAM,CAAC,MAAM,SAAS,GAA6C;IACjE,OAAO,EAAE;QACP,MAAM,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,EAAE;QAC5C,UAAU,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE;QACpD,EAAE,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE;QACtC,SAAS,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE;QAClD,SAAS,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE;QAClD,IAAI,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE;QACxC,KAAK,EAAE,CAAC,MAAe,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE;QAC1C,GAAG,EAAE,KAAK,EAAE,MAAe,EAAE,IAAkB,EAAE,OAAO,EAAE,EAAE,CAC1D,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;KACnB;CACF,CAAA"}
|
package/lib/content.js
CHANGED
|
@@ -17,6 +17,7 @@ const contentFields = `
|
|
|
17
17
|
altStandfirst: AltStandfirst
|
|
18
18
|
byline: StructuredContent
|
|
19
19
|
teaser: Teaser
|
|
20
|
+
annotations: [Concept]
|
|
20
21
|
`;
|
|
21
22
|
export const typeDef = [
|
|
22
23
|
gql `
|
|
@@ -81,6 +82,7 @@ export const resolvers = {
|
|
|
81
82
|
altTitle: (parent) => parent.alternativeTitle(),
|
|
82
83
|
altStandfirst: (parent) => parent.alternativeStandfirst(),
|
|
83
84
|
publishedDate: (parent) => parent.publishedDate(),
|
|
85
|
+
annotations: (parent) => parent.annotations(),
|
|
84
86
|
},
|
|
85
87
|
LiveBlogPackage: {
|
|
86
88
|
liveBlogPosts: (parent) => parent.liveBlogPosts(),
|
package/lib/content.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content.js","sourceRoot":"","sources":["../src/content.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AAIjC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,MAAM,aAAa,GAAG
|
|
1
|
+
{"version":3,"file":"content.js","sourceRoot":"","sources":["../src/content.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AAIjC,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAA;AAE1C,MAAM,aAAa,GAAG;;;;;;;;;;;;;;;;;CAiBrB,CAAA;AACD,MAAM,CAAC,MAAM,OAAO,GAAG;IACrB,GAAG,CAAA;;QAEG,aAAa;;;;;;;;;;QAUb,aAAa;;;;QAIb,aAAa;;;;;;QAMb,aAAa;;;;QAIb,aAAa;;;;QAIb,aAAa;;;;QAIb,aAAa;;GAElB;CACF,CAAA;AAED,MAAM,CAAC,MAAM,SAAS,GAA6C;IACjE,OAAO,EAAE;QACP,aAAa,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE;QACtD,IAAI,CAAC,MAAoB;YACvB,OAAO;gBACL,MAAM,EAAE,SAAS;gBACjB,KAAK,EAAE,MAAM,CAAC,OAAO,EAAE;gBACvB,cAAc,EAAE,MAAM;aACvB,CAAA;QACH,CAAC;QACD,MAAM,EAAE,CAAC,MAAoB,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,CAC9C,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;QAC7B,MAAM,CAAC,MAAoB;YACzB,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,CAAA;YAClC,IAAI,CAAC,UAAU;gBAAE,OAAO,IAAI,CAAA;YAC5B,MAAM,gBAAgB,GAAG,MAAM,CAAC,mBAAmB,EAAE,CAAA;YACrD,OAAO,IAAI,MAAM,CAAC,UAAU,EAAE,gBAAgB,CAAC,CAAC,eAAe,EAAE,CAAA;QACnE,CAAC;QACD,GAAG,EAAE,CAAC,MAAoB,EAAE,IAA2B,EAAE,EAAE,CACzD,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,EAAE;QACrD,IAAI,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,EAAE;QAC7C,SAAS,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,SAAS,EAAE;QACvD,QAAQ,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,gBAAgB,EAAE;QAC7D,aAAa,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,qBAAqB,EAAE;QACvE,aAAa,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,EAAE;QAC/D,WAAW,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,WAAW,EAAE;KAC5D;IAED,eAAe,EAAE;QACf,aAAa,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,aAAa,EAAE;QAC/D,QAAQ,EAAE,CAAC,MAAoB,EAAE,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE;KACtD;CACF,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { KeyValueCache } from '@apollo/utils.keyvaluecache';
|
|
2
|
+
import { QueryContext } from '../index.js';
|
|
3
|
+
export interface BaseDataSource {
|
|
4
|
+
context: QueryContext;
|
|
5
|
+
}
|
|
6
|
+
export declare type BaseDataSourceOptions = {
|
|
7
|
+
cache: KeyValueCache;
|
|
8
|
+
context: QueryContext;
|
|
9
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.js","sourceRoot":"","sources":["../../src/datasources/base.ts"],"names":[],"mappings":""}
|
|
@@ -1,13 +1,15 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { WillSendRequestOptions } from '@apollo/datasource-rest';
|
|
2
2
|
import { CapiResponse } from '../model/CapiResponse.js';
|
|
3
3
|
import { InstrumentedRESTDataSource } from './instrumented.js';
|
|
4
4
|
import { CapiPerson } from '../types/internal-content.js';
|
|
5
|
+
import { CacheOptions } from '@apollo/datasource-rest/dist/RESTDataSource.js';
|
|
5
6
|
export declare class CapiDataSource extends InstrumentedRESTDataSource {
|
|
6
7
|
baseURL: string;
|
|
7
8
|
capiKey: string;
|
|
8
9
|
articleCacheTTL: number;
|
|
9
10
|
peopleCacheTTL: number;
|
|
10
|
-
willSendRequest(request:
|
|
11
|
+
willSendRequest(request: WillSendRequestOptions): void;
|
|
12
|
+
protected cacheOptionsFor(url: string): CacheOptions | undefined;
|
|
11
13
|
getContent(uuid: string): Promise<CapiResponse>;
|
|
12
14
|
getPerson(uuid: string): Promise<CapiPerson>;
|
|
13
15
|
}
|
package/lib/datasources/capi.js
CHANGED
|
@@ -13,18 +13,21 @@ export class CapiDataSource extends InstrumentedRESTDataSource {
|
|
|
13
13
|
: 600; // 10 minutes
|
|
14
14
|
}
|
|
15
15
|
willSendRequest(request) {
|
|
16
|
-
|
|
17
|
-
|
|
16
|
+
request.headers['x-api-key'] = this.capiKey;
|
|
17
|
+
}
|
|
18
|
+
cacheOptionsFor(url) {
|
|
19
|
+
if (url.startsWith('internalcontent/')) {
|
|
20
|
+
return { ttl: this.articleCacheTTL };
|
|
21
|
+
}
|
|
22
|
+
else if (url.startsWith('people/')) {
|
|
23
|
+
return { ttl: this.peopleCacheTTL };
|
|
24
|
+
}
|
|
18
25
|
}
|
|
19
26
|
async getContent(uuid) {
|
|
20
|
-
return this.get(`internalcontent/${uuid}
|
|
21
|
-
cacheOptions: { ttl: this.articleCacheTTL },
|
|
22
|
-
}).then((response) => new CapiResponse(response, this.context));
|
|
27
|
+
return this.get(`internalcontent/${uuid}`).then((response) => new CapiResponse(response, this.context));
|
|
23
28
|
}
|
|
24
29
|
async getPerson(uuid) {
|
|
25
|
-
return this.get(`people/${uuid}
|
|
26
|
-
cacheOptions: { ttl: this.peopleCacheTTL },
|
|
27
|
-
});
|
|
30
|
+
return this.get(`people/${uuid}`);
|
|
28
31
|
}
|
|
29
32
|
}
|
|
30
33
|
//# sourceMappingURL=capi.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"capi.js","sourceRoot":"","sources":["../../src/datasources/capi.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAA;
|
|
1
|
+
{"version":3,"file":"capi.js","sourceRoot":"","sources":["../../src/datasources/capi.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACvD,OAAO,EAAE,0BAA0B,EAAE,MAAM,mBAAmB,CAAA;AAI9D,MAAM,OAAO,cAAe,SAAQ,0BAA0B;IAA9D;;QACE,YAAO,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,uBAAuB,CAAA;QACzD,YAAO,GAAG,OAAO,CAAC,GAAG,CAAC,YAAY,IAAI,EAAE,CAAA;QACxC,oBAAe,GAAG,OAAO,CAAC,GAAG,CAAC,iBAAiB;YAC7C,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC;YACzC,CAAC,CAAC,EAAE,CAAA,CAAC,aAAa;QACpB,mBAAc,GAAG,OAAO,CAAC,GAAG,CAAC,gBAAgB;YAC3C,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC;YACxC,CAAC,CAAC,GAAG,CAAA,CAAC,aAAa;IAuBvB,CAAC;IArBU,eAAe,CAAC,OAA+B;QACtD,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,GAAG,IAAI,CAAC,OAAO,CAAA;IAC7C,CAAC;IAES,eAAe,CAAC,GAAW;QACnC,IAAI,GAAG,CAAC,UAAU,CAAC,kBAAkB,CAAC,EAAE;YACtC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,eAAe,EAAE,CAAA;SACrC;aAAM,IAAI,GAAG,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;YACpC,OAAO,EAAE,GAAG,EAAE,IAAI,CAAC,cAAc,EAAE,CAAA;SACpC;IACH,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,IAAY;QAC3B,OAAO,IAAI,CAAC,GAAG,CAAC,mBAAmB,IAAI,EAAE,CAAC,CAAC,IAAI,CAC7C,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,YAAY,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,CACvD,CAAA;IACH,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,IAAY;QAC1B,OAAO,IAAI,CAAC,GAAG,CAAC,UAAU,IAAI,EAAE,CAAC,CAAA;IACnC,CAAC;CACF"}
|
|
@@ -1,11 +1,12 @@
|
|
|
1
|
+
import { BaseDataSourceOptions } from './base.js';
|
|
1
2
|
import { CapiDataSource } from './capi.js';
|
|
2
3
|
import { OrigamiImageDataSource } from './origami-image.js';
|
|
3
4
|
import { TwitterDataSource } from './twitter.js';
|
|
4
5
|
import { URLManagementDataSource } from './url-management.js';
|
|
5
|
-
export declare const
|
|
6
|
+
export declare const initDataSources: (options: BaseDataSourceOptions) => {
|
|
6
7
|
capi: CapiDataSource;
|
|
7
8
|
origami: OrigamiImageDataSource;
|
|
8
9
|
vanityUrls: URLManagementDataSource;
|
|
9
10
|
twitter: TwitterDataSource;
|
|
10
11
|
};
|
|
11
|
-
export declare type DataSources = ReturnType<typeof
|
|
12
|
+
export declare type DataSources = ReturnType<typeof initDataSources>;
|
package/lib/datasources/index.js
CHANGED
|
@@ -2,10 +2,10 @@ import { CapiDataSource } from './capi.js';
|
|
|
2
2
|
import { OrigamiImageDataSource } from './origami-image.js';
|
|
3
3
|
import { TwitterDataSource } from './twitter.js';
|
|
4
4
|
import { URLManagementDataSource } from './url-management.js';
|
|
5
|
-
export const
|
|
6
|
-
capi: new CapiDataSource(),
|
|
7
|
-
origami: new OrigamiImageDataSource(),
|
|
8
|
-
vanityUrls: new URLManagementDataSource(),
|
|
9
|
-
twitter: new TwitterDataSource(),
|
|
5
|
+
export const initDataSources = (options) => ({
|
|
6
|
+
capi: new CapiDataSource(options),
|
|
7
|
+
origami: new OrigamiImageDataSource(options),
|
|
8
|
+
vanityUrls: new URLManagementDataSource(options),
|
|
9
|
+
twitter: new TwitterDataSource(options),
|
|
10
10
|
});
|
|
11
11
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/datasources/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/datasources/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,cAAc,EAAE,MAAM,WAAW,CAAA;AAC1C,OAAO,EAAE,sBAAsB,EAAE,MAAM,oBAAoB,CAAA;AAC3D,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAA;AAChD,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAA;AAE7D,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,OAA8B,EAAE,EAAE,CAAC,CAAC;IAClE,IAAI,EAAE,IAAI,cAAc,CAAC,OAAO,CAAC;IACjC,OAAO,EAAE,IAAI,sBAAsB,CAAC,OAAO,CAAC;IAC5C,UAAU,EAAE,IAAI,uBAAuB,CAAC,OAAO,CAAC;IAChD,OAAO,EAAE,IAAI,iBAAiB,CAAC,OAAO,CAAC;CACxC,CAAC,CAAA"}
|
|
@@ -1,8 +1,13 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { WillSendRequestOptions, RESTDataSource, RequestOptions } from '@apollo/datasource-rest';
|
|
2
|
+
import type { FetcherResponse } from '@apollo/utils.fetcher';
|
|
2
3
|
import { QueryContext } from '../index.js';
|
|
3
|
-
|
|
4
|
+
import { BaseDataSource, BaseDataSourceOptions } from './base.js';
|
|
5
|
+
export declare class InstrumentedRESTDataSource extends RESTDataSource implements BaseDataSource {
|
|
4
6
|
startTime?: bigint;
|
|
5
7
|
includeHeadersInLogs: string[];
|
|
6
|
-
|
|
7
|
-
|
|
8
|
+
context: QueryContext;
|
|
9
|
+
constructor({ cache, context }: BaseDataSourceOptions);
|
|
10
|
+
get cachePrefix(): string;
|
|
11
|
+
trace<TResult>(url: URL, request: WillSendRequestOptions, fn: () => Promise<TResult>): Promise<TResult>;
|
|
12
|
+
didReceiveResponse<TResult>(response: FetcherResponse, request: RequestOptions): Promise<TResult>;
|
|
8
13
|
}
|
|
@@ -1,10 +1,24 @@
|
|
|
1
|
-
import { RESTDataSource, } from 'apollo
|
|
1
|
+
import { RESTDataSource, } from '@apollo/datasource-rest';
|
|
2
|
+
import { PrefixingKeyValueCache } from '@apollo/utils.keyvaluecache';
|
|
3
|
+
import { isContextableCache } from '../types/cache.js';
|
|
2
4
|
export class InstrumentedRESTDataSource extends RESTDataSource {
|
|
3
|
-
constructor() {
|
|
4
|
-
|
|
5
|
+
constructor({ cache, context }) {
|
|
6
|
+
const wrappedCache = new PrefixingKeyValueCache(isContextableCache(cache) ? cache.withContext(context) : cache, 'placeholder_prefix_if_you_see_this_in_redis_something_is_very_wrong:' // can't use `this` yet to get our prefix
|
|
7
|
+
);
|
|
8
|
+
super({
|
|
9
|
+
cache: wrappedCache,
|
|
10
|
+
});
|
|
5
11
|
this.includeHeadersInLogs = [];
|
|
12
|
+
// okay _now_ we can use `this`
|
|
13
|
+
// also that's a private property so use the [] escape hatch
|
|
14
|
+
// sorry
|
|
15
|
+
wrappedCache['prefix'] = this.cachePrefix + ':';
|
|
16
|
+
this.context = context;
|
|
17
|
+
}
|
|
18
|
+
get cachePrefix() {
|
|
19
|
+
return this.constructor.name.replace(/DataSource$/, '').toLowerCase();
|
|
6
20
|
}
|
|
7
|
-
|
|
21
|
+
async trace(url, request, fn) {
|
|
8
22
|
var _a;
|
|
9
23
|
this.startTime = process.hrtime.bigint();
|
|
10
24
|
(_a = this.context.metrics) === null || _a === void 0 ? void 0 : _a.count(`graphql.datasource.${this.constructor.name}.request.count`, 1);
|
|
@@ -13,19 +27,15 @@ export class InstrumentedRESTDataSource extends RESTDataSource {
|
|
|
13
27
|
datasource: this.constructor.name,
|
|
14
28
|
request: {
|
|
15
29
|
id: this.context.requestId,
|
|
16
|
-
url:
|
|
30
|
+
url: url.href,
|
|
17
31
|
method: request.method,
|
|
18
|
-
headers: request.headers
|
|
19
|
-
? Object.fromEntries(this.includeHeadersInLogs.map((header) => [
|
|
20
|
-
header,
|
|
21
|
-
request.headers.get(header),
|
|
22
|
-
]))
|
|
23
|
-
: {},
|
|
32
|
+
headers: request.headers,
|
|
24
33
|
},
|
|
25
34
|
});
|
|
26
35
|
if (this.context.requestId) {
|
|
27
|
-
request.headers
|
|
36
|
+
request.headers['x-request-id'] = this.context.requestId;
|
|
28
37
|
}
|
|
38
|
+
return fn();
|
|
29
39
|
}
|
|
30
40
|
async didReceiveResponse(response, request) {
|
|
31
41
|
var _a, _b;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"instrumented.js","sourceRoot":"","sources":["../../src/datasources/instrumented.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"instrumented.js","sourceRoot":"","sources":["../../src/datasources/instrumented.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,cAAc,GAEf,MAAM,yBAAyB,CAAA;AAEhC,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAA;AAGpE,OAAO,EAAE,kBAAkB,EAAE,MAAM,mBAAmB,CAAA;AAGtD,MAAM,OAAO,0BACX,SAAQ,cAAc;IAOtB,YAAY,EAAE,KAAK,EAAE,OAAO,EAAyB;QACnD,MAAM,YAAY,GAAG,IAAI,sBAAsB,CAC7C,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,EAC9D,sEAAsE,CAAC,yCAAyC;SACjH,CAAA;QAED,KAAK,CAAC;YACJ,KAAK,EAAE,YAAY;SACpB,CAAC,CAAA;QAXJ,yBAAoB,GAAa,EAAE,CAAA;QAajC,+BAA+B;QAC/B,4DAA4D;QAC5D,QAAQ;QACR,YAAY,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,WAAW,GAAG,GAAG,CAAA;QAC/C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IACxB,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC,WAAW,EAAE,CAAA;IACvE,CAAC;IAEQ,KAAK,CAAC,KAAK,CAClB,GAAQ,EACR,OAA+B,EAC/B,EAA0B;;QAE1B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,CAAA;QAExC,MAAA,IAAI,CAAC,OAAO,CAAC,OAAO,0CAAE,KAAK,CACzB,sBAAsB,IAAI,CAAC,WAAW,CAAC,IAAI,gBAAgB,EAC3D,CAAC,CACF,CAAA;QACD,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC;YACvB,KAAK,EAAE,oBAAoB;YAC3B,UAAU,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI;YACjC,OAAO,EAAE;gBACP,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,SAAS;gBAC1B,GAAG,EAAE,GAAG,CAAC,IAAI;gBACb,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,OAAO,EAAE,OAAO,CAAC,OAAO;aACJ;SACvB,CAAC,CAAA;QAEF,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YAC1B,OAAO,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAA;SACzD;QAED,OAAO,EAAE,EAAE,CAAA;IACb,CAAC;IAED,KAAK,CAAC,kBAAkB,CACtB,QAAyB,EACzB,OAAuB;;QAEvB,wGAAwG;QACxG,oEAAoE;QACpE,MAAM,QAAQ,GAAG,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAU,CAAC,GAAG,MAAM,CAAC,GAAG,CAAC,CAAA;QAE1E,MAAA,IAAI,CAAC,OAAO,CAAC,OAAO,0CAAE,KAAK,CACzB,sBAAsB,IAAI,CAAC,WAAW,CAAC,IAAI,aAAa,QAAQ,CAAC,MAAM,QAAQ,EAC/E,CAAC,CACF,CAAA;QACD,MAAA,IAAI,CAAC,OAAO,CAAC,OAAO,0CAAE,KAAK,CACzB,sBAAsB,IAAI,CAAC,WAAW,CAAC,IAAI,aAAa,QAAQ,CAAC,MAAM,OAAO,EAC9E,MAAM,CAAC,QAAQ,CAAC,CACjB,CAAA;QAED,OAAO,KAAK,CAAC,kBAAkB,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;IACpD,CAAC;CACF"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { KeyValueCache } from 'apollo-server-caching';
|
|
1
|
+
import { KeyValueCache } from '@apollo/utils.keyvaluecache';
|
|
3
2
|
import { QueryContext } from '../index.js';
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
cache: KeyValueCache;
|
|
3
|
+
import { BaseDataSource, BaseDataSourceOptions } from './base.js';
|
|
4
|
+
export declare class URLManagementDataSource implements BaseDataSource {
|
|
7
5
|
memoizedResults: Map<string, Promise<string>>;
|
|
6
|
+
cache: KeyValueCache;
|
|
7
|
+
context: QueryContext;
|
|
8
8
|
static clientInitialised: boolean;
|
|
9
|
-
|
|
9
|
+
constructor({ context, cache }: BaseDataSourceOptions);
|
|
10
10
|
get(fromURL: string, ttl?: number): Promise<string>;
|
|
11
11
|
}
|
|
@@ -1,14 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { InMemoryLRUCache, PrefixingKeyValueCache, } from 'apollo-server-caching';
|
|
1
|
+
import { PrefixingKeyValueCache, } from '@apollo/utils.keyvaluecache';
|
|
3
2
|
import * as nUrlManagementApiReadClient from '@financial-times/n-url-management-api-read-client';
|
|
4
|
-
const CACHE_PREFIX = 'nurlmgmtapi';
|
|
3
|
+
const CACHE_PREFIX = 'nurlmgmtapi:';
|
|
5
4
|
const DEFAULT_TTL_IN_SECONDS = 60 * 60; // one hour
|
|
6
|
-
export class URLManagementDataSource
|
|
7
|
-
constructor() {
|
|
8
|
-
super(...arguments);
|
|
5
|
+
export class URLManagementDataSource {
|
|
6
|
+
constructor({ context, cache }) {
|
|
9
7
|
this.memoizedResults = new Map();
|
|
10
|
-
}
|
|
11
|
-
initialize({ context, cache = new InMemoryLRUCache(), }) {
|
|
12
8
|
if (!URLManagementDataSource.clientInitialised) {
|
|
13
9
|
nUrlManagementApiReadClient.init({ metrics: context.metrics });
|
|
14
10
|
URLManagementDataSource.clientInitialised = true;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"url-management.js","sourceRoot":"","sources":["../../src/datasources/url-management.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"url-management.js","sourceRoot":"","sources":["../../src/datasources/url-management.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,sBAAsB,GACvB,MAAM,6BAA6B,CAAA;AAEpC,OAAO,KAAK,2BAA2B,MAAM,mDAAmD,CAAA;AAKhG,MAAM,YAAY,GAAG,cAAc,CAAA;AACnC,MAAM,sBAAsB,GAAG,EAAE,GAAG,EAAE,CAAA,CAAC,WAAW;AAElD,MAAM,OAAO,uBAAuB;IAOlC,YAAY,EAAE,OAAO,EAAE,KAAK,EAAyB;QANrD,oBAAe,GAAG,IAAI,GAAG,EAA2B,CAAA;QAOlD,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,EAAE;YAC9C,2BAA2B,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAA;YAC9D,uBAAuB,CAAC,iBAAiB,GAAG,IAAI,CAAA;SACjD;QAED,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,IAAI,CAAC,KAAK,GAAG,IAAI,sBAAsB,CAAC,KAAK,EAAE,YAAY,CAAC,CAAA;IAC9D,CAAC;IAED,KAAK,CAAC,GAAG,CACP,OAAe,EACf,MAAc,sBAAsB;QAEpC,MAAM,SAAS,GAAG,KAAK,IAAqB,EAAE;YAC5C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YAC/C,IAAI,SAAS,EAAE;gBACb,OAAO,SAAS,CAAA;aACjB;YAED,MAAM,YAAY,GAChB,MAAM,2BAA2B,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;YAChD,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,EAAE,YAAY,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,CAAC,CAAA;YAC1D,OAAO,YAAY,CAAC,KAAK,CAAA;QAC3B,CAAC,CAAA;QAED,IAAI,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,OAAO,CAAC,CAAA;QAE/C,IAAI,OAAO,EAAE;YACX,OAAO,OAAO,CAAA;SACf;QAED,OAAO,GAAG,SAAS,EAAE,CAAA;QACrB,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;QAE1C,OAAO,OAAO,CAAA;IAChB,CAAC;;AAtCM,yCAAiB,GAAG,KAAK,CAAA"}
|
|
@@ -7,7 +7,7 @@ jest.unstable_mockModule('@financial-times/n-url-management-api-read-client', ()
|
|
|
7
7
|
const urlmgmtimport = await import('./url-management.js');
|
|
8
8
|
const URLManagementDataSource = urlmgmtimport.URLManagementDataSource;
|
|
9
9
|
const nUrlManagementApiReadClient = await import('@financial-times/n-url-management-api-read-client');
|
|
10
|
-
import { InMemoryLRUCache } from 'apollo
|
|
10
|
+
import { InMemoryLRUCache } from '@apollo/utils.keyvaluecache';
|
|
11
11
|
import { jest } from '@jest/globals';
|
|
12
12
|
const getMock = nUrlManagementApiReadClient.get;
|
|
13
13
|
const context = {};
|
|
@@ -16,12 +16,12 @@ describe('URL management data source', () => {
|
|
|
16
16
|
jest.resetAllMocks();
|
|
17
17
|
});
|
|
18
18
|
it('only initialises the client library once', async () => {
|
|
19
|
-
new URLManagementDataSource(
|
|
19
|
+
new URLManagementDataSource({
|
|
20
20
|
context,
|
|
21
21
|
cache: new InMemoryLRUCache(),
|
|
22
22
|
});
|
|
23
23
|
expect(nUrlManagementApiReadClient.init).toHaveBeenCalledTimes(1);
|
|
24
|
-
new URLManagementDataSource(
|
|
24
|
+
new URLManagementDataSource({
|
|
25
25
|
context,
|
|
26
26
|
cache: new InMemoryLRUCache(),
|
|
27
27
|
});
|
|
@@ -31,34 +31,34 @@ describe('URL management data source', () => {
|
|
|
31
31
|
getMock.mockResolvedValue({
|
|
32
32
|
toURL: 'vanity.url',
|
|
33
33
|
});
|
|
34
|
-
const dataSource = new URLManagementDataSource(
|
|
35
|
-
|
|
34
|
+
const dataSource = new URLManagementDataSource({
|
|
35
|
+
context,
|
|
36
|
+
cache: new InMemoryLRUCache(),
|
|
37
|
+
});
|
|
36
38
|
const vanity = await dataSource.get('original.url');
|
|
37
39
|
expect(vanity).toEqual('vanity.url');
|
|
38
40
|
expect(nUrlManagementApiReadClient.get).toHaveBeenCalled();
|
|
39
41
|
});
|
|
40
42
|
it('gets subsequent requests from the cache', async () => {
|
|
41
43
|
getMock.mockImplementation((fromUrl) => Promise.resolve({ toURL: `${fromUrl}.vanity` }));
|
|
42
|
-
const dataSource = new URLManagementDataSource();
|
|
43
44
|
const cache = new InMemoryLRUCache();
|
|
44
|
-
dataSource
|
|
45
|
+
const dataSource = new URLManagementDataSource({ context, cache });
|
|
45
46
|
const firstRequest = await dataSource.get('original.url');
|
|
46
47
|
expect(firstRequest).toEqual('original.url.vanity');
|
|
47
|
-
expect(
|
|
48
|
+
expect(cache['cache'].calculatedSize).toEqual(19); // string length of original.url.vanity
|
|
48
49
|
const secondRequest = await dataSource.get('original.url');
|
|
49
50
|
expect(secondRequest).toEqual('original.url.vanity');
|
|
50
51
|
expect(nUrlManagementApiReadClient.get).toHaveBeenCalledTimes(1);
|
|
51
|
-
expect(
|
|
52
|
+
expect(cache['cache'].calculatedSize).toEqual(19);
|
|
52
53
|
const differentRequest = await dataSource.get('different.url');
|
|
53
54
|
expect(differentRequest).toEqual('different.url.vanity');
|
|
54
55
|
expect(nUrlManagementApiReadClient.get).toHaveBeenCalledTimes(2);
|
|
55
|
-
expect(
|
|
56
|
+
expect(cache['cache'].calculatedSize).toEqual(39);
|
|
56
57
|
});
|
|
57
58
|
it('memoizes requests made in the same query', async () => {
|
|
58
59
|
getMock.mockImplementation((fromUrl) => Promise.resolve({ toURL: `${fromUrl}.vanity` }));
|
|
59
|
-
const dataSource = new URLManagementDataSource();
|
|
60
60
|
const cache = new InMemoryLRUCache();
|
|
61
|
-
dataSource
|
|
61
|
+
const dataSource = new URLManagementDataSource({ context, cache });
|
|
62
62
|
const firstRequest = dataSource.get('original.url');
|
|
63
63
|
const secondRequest = dataSource.get('original.url');
|
|
64
64
|
const differentRequest = dataSource.get('different.url');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"url-management.test.js","sourceRoot":"","sources":["../../src/datasources/url-management.test.ts"],"names":[],"mappings":"AAAA,6DAA6D;AAC7D,oDAAoD;AAEpD,IAAI,CAAC,mBAAmB,CACtB,mDAAmD,EACnD,GAAG,EAAE,CAAC,CAAC;IACL,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE;IACd,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE;CAChB,CAAC,CACH,CAAA;AAED,MAAM,aAAa,GAAG,MAAM,MAAM,CAAC,qBAAqB,CAAC,CAAA;AAEzD,MAAM,uBAAuB,GAAG,aAAa,CAAC,uBAAuB,CAAA;AACrE,MAAM,2BAA2B,GAAG,MAAM,MAAM,CAC9C,mDAAmD,CACpD,CAAA;AAED,OAAO,EAAE,gBAAgB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"url-management.test.js","sourceRoot":"","sources":["../../src/datasources/url-management.test.ts"],"names":[],"mappings":"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"}
|
package/lib/index.d.ts
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import type { IResolvers } from '@graphql-tools/utils';
|
|
2
|
-
import {
|
|
2
|
+
import { initDataSources, DataSources } from './datasources/index.js';
|
|
3
3
|
import type { Metrics } from 'next-metrics';
|
|
4
4
|
import type { Logger } from '@dotcom-reliability-kit/logger';
|
|
5
|
-
export
|
|
5
|
+
export interface QueryContext {
|
|
6
6
|
metrics: Metrics;
|
|
7
7
|
dataSources: DataSources;
|
|
8
8
|
systemCode: string;
|
|
9
9
|
requestId?: string;
|
|
10
10
|
logger: Logger;
|
|
11
|
-
}
|
|
11
|
+
}
|
|
12
12
|
export declare const resolvers: IResolvers<unknown, Pick<QueryContext, 'dataSources'>>;
|
|
13
13
|
export declare const typeDefs: (import("graphql").DocumentNode | import("graphql").DocumentNode[])[];
|
|
14
|
-
export {
|
|
14
|
+
export { initDataSources, DataSources };
|
package/lib/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { gql } from 'graphql-tag';
|
|
2
|
-
import {
|
|
2
|
+
import { initDataSources } from './datasources/index.js';
|
|
3
3
|
import { typeDef as Content, resolvers as contentResolvers } from './content.js';
|
|
4
4
|
import { typeDef as Concept, resolvers as conceptResolvers } from './concept.js';
|
|
5
5
|
import { typeDef as Picture, resolvers as pictureResolvers } from './picture.js';
|
|
@@ -51,5 +51,5 @@ export const typeDefs = [
|
|
|
51
51
|
Tag,
|
|
52
52
|
coreTypeDefs,
|
|
53
53
|
];
|
|
54
|
-
export {
|
|
54
|
+
export { initDataSources };
|
|
55
55
|
//# sourceMappingURL=index.js.map
|
package/lib/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AAEjC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAE,MAAM,aAAa,CAAA;AAEjC,OAAO,EAAE,eAAe,EAAe,MAAM,wBAAwB,CAAA;AAErE,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAChF,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAChF,OAAO,EAAE,OAAO,IAAI,OAAO,EAAE,SAAS,IAAI,gBAAgB,EAAE,MAAM,cAAc,CAAA;AAChF,OAAO,EAAE,OAAO,IAAI,KAAK,EAAE,SAAS,IAAI,cAAc,EAAE,MAAM,YAAY,CAAA;AAC1E,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,SAAS,IAAI,eAAe,EAAE,MAAM,aAAa,CAAA;AAC7E,OAAO,EACL,OAAO,IAAI,QAAQ,EACnB,SAAS,IAAI,iBAAiB,GAC/B,MAAM,eAAe,CAAA;AACtB,OAAO,EACL,OAAO,IAAI,WAAW,EACtB,SAAS,IAAI,oBAAoB,GAClC,MAAM,aAAa,CAAA;AACpB,OAAO,EACL,OAAO,IAAI,GAAG,EACd,eAAe,IAAI,SAAS,EAC5B,SAAS,IAAI,YAAY,GAC1B,MAAM,iBAAiB,CAAA;AAIxB,MAAM,YAAY,GAAG,GAAG,CAAA;;;;;;;CAOvB,CAAA;AAUD,MAAM,CAAC,MAAM,SAAS,GAGlB;IACF,KAAK,EAAE;QACL,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,IAAI,EAAE,OAAO;YACjC,OAAO,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QACvD,CAAC;QACD,eAAe,CAAC,CAAC,EAAE,EAAE,OAAO,EAAE;YAC5B,OAAO,OAAO,CAAA;QAChB,CAAC;KACF;IAED,SAAS,EAAE;QACT,aAAa,CAAC,GAAsC;YAClD,OAAO,GAAG,CAAC,WAAW,CAAC,IAAI,CAAA;QAC7B,CAAC;KACF;IAED,GAAG,gBAAgB;IACnB,GAAG,gBAAgB;IACnB,GAAG,gBAAgB;IACnB,GAAG,cAAc;IACjB,GAAG,YAAY;IACf,GAAG,eAAe;IAClB,GAAG,iBAAiB;IACpB,GAAG,oBAAoB;CACxB,CAAA;AAED,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB,OAAO;IACP,OAAO;IACP,OAAO;IACP,KAAK;IACL,MAAM;IACN,QAAQ;IACR,WAAW;IACX,SAAS;IACT,GAAG;IACH,YAAY;CACb,CAAA;AAED,OAAO,EAAE,eAAe,EAAe,CAAA"}
|
|
@@ -29,7 +29,7 @@ export declare class CapiResponse {
|
|
|
29
29
|
alternativeStandfirst(): string | undefined;
|
|
30
30
|
overrideTitle(title: string): CapiResponse;
|
|
31
31
|
teaserMetadata(field: MetaFields): string | Concept | undefined;
|
|
32
|
-
teaser(
|
|
32
|
+
teaser(): CapiResponse;
|
|
33
33
|
isEditorsChoice(): boolean;
|
|
34
34
|
isExclusive(): boolean;
|
|
35
35
|
isScoop(): boolean;
|
|
@@ -94,11 +94,8 @@ export class CapiResponse {
|
|
|
94
94
|
return new Concept(metaField, this.context);
|
|
95
95
|
}
|
|
96
96
|
}
|
|
97
|
-
teaser(
|
|
98
|
-
const clone =
|
|
99
|
-
if (title) {
|
|
100
|
-
clone.title = title;
|
|
101
|
-
}
|
|
97
|
+
teaser() {
|
|
98
|
+
const clone = cloneDeep(this.capiData);
|
|
102
99
|
return new CapiResponse(clone, this.context);
|
|
103
100
|
}
|
|
104
101
|
isEditorsChoice() {
|
|
@@ -137,7 +134,7 @@ export class CapiResponse {
|
|
|
137
134
|
}
|
|
138
135
|
}
|
|
139
136
|
rawCapiData() {
|
|
140
|
-
return
|
|
137
|
+
return cloneDeep(this.capiData);
|
|
141
138
|
}
|
|
142
139
|
getAuthorUrlMapping() {
|
|
143
140
|
const authorAnnotations = this.getAuthors();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CapiResponse.js","sourceRoot":"","sources":["../../src/model/CapiResponse.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"CapiResponse.js","sourceRoot":"","sources":["../../src/model/CapiResponse.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { KeyValueCache } from '@apollo/utils.keyvaluecache';
|
|
2
|
+
import { QueryContext } from '../index.js';
|
|
3
|
+
interface CacheWithContext<TContext extends QueryContext> extends KeyValueCache {
|
|
4
|
+
context?: TContext;
|
|
5
|
+
}
|
|
6
|
+
interface ContextableCache<TContext extends QueryContext> {
|
|
7
|
+
withContext(context: TContext): CacheWithContext<TContext>;
|
|
8
|
+
}
|
|
9
|
+
export declare function isContextableCache<TContext extends QueryContext>(cache: any): cache is ContextableCache<TContext>;
|
|
10
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../src/types/cache.ts"],"names":[],"mappings":"AAYA,MAAM,UAAU,kBAAkB,CAChC,KAAU;IAEV,OAAO,aAAa,IAAI,KAAK,CAAA;AAC/B,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@financial-times/cp-content-pipeline-schema",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.4.1",
|
|
4
4
|
"description": "",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"type": "module",
|
|
@@ -19,14 +19,14 @@
|
|
|
19
19
|
},
|
|
20
20
|
"homepage": "https://github.com/Financial-Times/cp-content-pipeline#readme",
|
|
21
21
|
"dependencies": {
|
|
22
|
+
"@apollo/datasource-rest": "^4.3.2",
|
|
23
|
+
"@apollo/utils.keyvaluecache": "^1.0.1",
|
|
22
24
|
"@dotcom-reliability-kit/serialize-request": "^1.0.4",
|
|
23
25
|
"@financial-times/n-concept-ids": "^1.21.0",
|
|
24
26
|
"@financial-times/n-display-metadata": "^1.1.1",
|
|
25
27
|
"@financial-times/n-url-management-api-read-client": "^7.0.0",
|
|
26
28
|
"@graphql-tools/utils": "^8.12.0",
|
|
27
29
|
"@types/clone-deep": "^4.0.1",
|
|
28
|
-
"apollo-datasource-rest": "^3.6.1",
|
|
29
|
-
"apollo-server-caching": "^3.3.0",
|
|
30
30
|
"clone-deep": "^4.0.1",
|
|
31
31
|
"graphql": "^16.6.0",
|
|
32
32
|
"graphql-tag": "^2.12.6",
|
|
@@ -39,6 +39,7 @@
|
|
|
39
39
|
"unist-util-visit": "^4.1.1"
|
|
40
40
|
},
|
|
41
41
|
"devDependencies": {
|
|
42
|
+
"@apollo/utils.fetcher": "^1.1.1",
|
|
42
43
|
"@dotcom-reliability-kit/logger": "^0.1.0",
|
|
43
44
|
"@dotcom-tool-kit/npm": "^2.0.9",
|
|
44
45
|
"@types/graphql": "^14.5.0",
|
package/src/concept.ts
CHANGED
|
@@ -7,7 +7,7 @@ export const typeDef = gql`
|
|
|
7
7
|
type Concept {
|
|
8
8
|
apiUrl: String!
|
|
9
9
|
directType: String
|
|
10
|
-
id:
|
|
10
|
+
id: ID!
|
|
11
11
|
predicate: String!
|
|
12
12
|
prefLabel: String!
|
|
13
13
|
type: String!
|
|
@@ -20,7 +20,7 @@ export const resolvers: IResolvers<Concept, QueryContext, never> = {
|
|
|
20
20
|
Concept: {
|
|
21
21
|
apiUrl: (parent: Concept) => parent.apiUrl(),
|
|
22
22
|
directType: (parent: Concept) => parent.directType(),
|
|
23
|
-
id: (parent: Concept) => parent.
|
|
23
|
+
id: (parent: Concept) => parent.uuid(),
|
|
24
24
|
predicate: (parent: Concept) => parent.predicate(),
|
|
25
25
|
prefLabel: (parent: Concept) => parent.prefLabel(),
|
|
26
26
|
type: (parent: Concept) => parent.type(),
|