@sitecore-jss/sitecore-jss-nextjs 22.8.0-canary.4 → 22.8.0-canary.6

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.
@@ -26,7 +26,7 @@ class PersonalizeMiddleware extends middleware_1.MiddlewareBase {
26
26
  constructor(config) {
27
27
  super(config);
28
28
  this.config = config;
29
- this.handler = (req, res, options) => __awaiter(this, void 0, void 0, function* () {
29
+ this.processPersonalizationRequest = (req, res, options) => __awaiter(this, void 0, void 0, function* () {
30
30
  const pathname = req.nextUrl.pathname;
31
31
  const language = this.getLanguage(req);
32
32
  const hostname = this.getHostHeader(req) || this.defaultHostname;
@@ -52,7 +52,7 @@ class PersonalizeMiddleware extends middleware_1.MiddlewareBase {
52
52
  }
53
53
  const site = this.getSite(req, response);
54
54
  // Get personalization info from Experience Edge
55
- const personalizeInfo = yield this.personalizeService.getPersonalizeInfo(pathname, language, site.name);
55
+ const personalizeInfo = yield this.getPersonalizeInfo(pathname, language, site.name);
56
56
  if (!personalizeInfo) {
57
57
  // Likely an invalid route / language
58
58
  sitecore_jss_1.debug.personalize('skipped (personalize info not found)');
@@ -69,6 +69,7 @@ class PersonalizeMiddleware extends middleware_1.MiddlewareBase {
69
69
  // Disable preflight caching to force revalidation on client-side navigation (personalization WILL be influenced).
70
70
  // Note the reason we don't move this any earlier in the middleware is that we would then be sacrificing performance for non-personalized pages.
71
71
  response.headers.set('x-middleware-cache', 'no-cache');
72
+ response.headers.set('Cache-Control', 'no-store, must-revalidate');
72
73
  return response;
73
74
  }
74
75
  yield this.initPersonalizeServer({
@@ -127,7 +128,7 @@ class PersonalizeMiddleware extends middleware_1.MiddlewareBase {
127
128
  getHandler() {
128
129
  return (req, res, options) => __awaiter(this, void 0, void 0, function* () {
129
130
  try {
130
- return yield this.handler(req, res, options);
131
+ return yield this.processPersonalizationRequest(req, res, options);
131
132
  }
132
133
  catch (error) {
133
134
  console.log('Personalize middleware failed:');
@@ -229,5 +230,10 @@ class PersonalizeMiddleware extends middleware_1.MiddlewareBase {
229
230
  return results;
230
231
  }, results);
231
232
  }
233
+ getPersonalizeInfo(pathname, language, siteName) {
234
+ return __awaiter(this, void 0, void 0, function* () {
235
+ return this.personalizeService.getPersonalizeInfo(pathname, language, siteName);
236
+ });
237
+ }
232
238
  }
233
239
  exports.PersonalizeMiddleware = PersonalizeMiddleware;
@@ -23,7 +23,7 @@ export class PersonalizeMiddleware extends MiddlewareBase {
23
23
  constructor(config) {
24
24
  super(config);
25
25
  this.config = config;
26
- this.handler = (req, res, options) => __awaiter(this, void 0, void 0, function* () {
26
+ this.processPersonalizationRequest = (req, res, options) => __awaiter(this, void 0, void 0, function* () {
27
27
  const pathname = req.nextUrl.pathname;
28
28
  const language = this.getLanguage(req);
29
29
  const hostname = this.getHostHeader(req) || this.defaultHostname;
@@ -49,7 +49,7 @@ export class PersonalizeMiddleware extends MiddlewareBase {
49
49
  }
50
50
  const site = this.getSite(req, response);
51
51
  // Get personalization info from Experience Edge
52
- const personalizeInfo = yield this.personalizeService.getPersonalizeInfo(pathname, language, site.name);
52
+ const personalizeInfo = yield this.getPersonalizeInfo(pathname, language, site.name);
53
53
  if (!personalizeInfo) {
54
54
  // Likely an invalid route / language
55
55
  debug.personalize('skipped (personalize info not found)');
@@ -66,6 +66,7 @@ export class PersonalizeMiddleware extends MiddlewareBase {
66
66
  // Disable preflight caching to force revalidation on client-side navigation (personalization WILL be influenced).
67
67
  // Note the reason we don't move this any earlier in the middleware is that we would then be sacrificing performance for non-personalized pages.
68
68
  response.headers.set('x-middleware-cache', 'no-cache');
69
+ response.headers.set('Cache-Control', 'no-store, must-revalidate');
69
70
  return response;
70
71
  }
71
72
  yield this.initPersonalizeServer({
@@ -124,7 +125,7 @@ export class PersonalizeMiddleware extends MiddlewareBase {
124
125
  getHandler() {
125
126
  return (req, res, options) => __awaiter(this, void 0, void 0, function* () {
126
127
  try {
127
- return yield this.handler(req, res, options);
128
+ return yield this.processPersonalizationRequest(req, res, options);
128
129
  }
129
130
  catch (error) {
130
131
  console.log('Personalize middleware failed:');
@@ -226,4 +227,9 @@ export class PersonalizeMiddleware extends MiddlewareBase {
226
227
  return results;
227
228
  }, results);
228
229
  }
230
+ getPersonalizeInfo(pathname, language, siteName) {
231
+ return __awaiter(this, void 0, void 0, function* () {
232
+ return this.personalizeService.getPersonalizeInfo(pathname, language, siteName);
233
+ });
234
+ }
229
235
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sitecore-jss/sitecore-jss-nextjs",
3
- "version": "22.8.0-canary.4",
3
+ "version": "22.8.0-canary.6",
4
4
  "main": "dist/cjs/index.js",
5
5
  "module": "dist/esm/index.js",
6
6
  "sideEffects": false,
@@ -72,16 +72,16 @@
72
72
  "react-dom": "^19.1.0"
73
73
  },
74
74
  "dependencies": {
75
- "@sitecore-jss/sitecore-jss": "22.8.0-canary.4",
76
- "@sitecore-jss/sitecore-jss-dev-tools": "22.8.0-canary.4",
77
- "@sitecore-jss/sitecore-jss-react": "22.8.0-canary.4",
75
+ "@sitecore-jss/sitecore-jss": "22.8.0-canary.6",
76
+ "@sitecore-jss/sitecore-jss-dev-tools": "22.8.0-canary.6",
77
+ "@sitecore-jss/sitecore-jss-react": "22.8.0-canary.6",
78
78
  "@vercel/kv": "^0.2.1",
79
79
  "regex-parser": "^2.2.11",
80
80
  "sync-disk-cache": "^2.1.0"
81
81
  },
82
82
  "description": "",
83
83
  "types": "types/index.d.ts",
84
- "gitHead": "4bafb2e560ac0742ead12179574fe4080f4e8c77",
84
+ "gitHead": "d279587daea000158ff275a1229b690281153f54",
85
85
  "files": [
86
86
  "dist",
87
87
  "types",
@@ -115,6 +115,7 @@ export declare class PersonalizeMiddleware extends MiddlewareBase {
115
115
  * @returns An array of personalize executions
116
116
  */
117
117
  protected getPersonalizeExecutions(personalizeInfo: PersonalizeInfo, language: string): PersonalizeExecution[];
118
- private handler;
118
+ protected processPersonalizationRequest: (req: NextRequest, res?: NextResponse, options?: PersonalizeOptions) => Promise<NextResponse>;
119
+ protected getPersonalizeInfo(pathname: string, language: string, siteName: string): Promise<PersonalizeInfo | undefined>;
119
120
  }
120
121
  export {};