@shopify/remix-oxygen
Advanced tools
Comparing version 0.0.0-next-beb56c6-20230315164633 to 0.0.0-next-bf39d28-20250129224231
import { createCookieFactory, createCookieSessionStorageFactory, createSessionStorageFactory, createMemorySessionStorageFactory, createRequestHandler as createRequestHandler$1 } from '@remix-run/server-runtime'; | ||
export { MaxPartSizeExceededError, createSession, defer, isCookie, isSession, json, redirect, unstable_composeUploadHandlers, unstable_createMemoryUploadHandler, unstable_parseMultipartFormData } from '@remix-run/server-runtime'; | ||
export { MaxPartSizeExceededError, createSession, defer, isCookie, isSession, json, redirect, redirectDocument } from '@remix-run/server-runtime'; | ||
@@ -51,5 +51,44 @@ // src/implementations.ts | ||
var createMemorySessionStorage = createMemorySessionStorageFactory(createSessionStorage); | ||
// src/event-logger.ts | ||
var hasWarned = false; | ||
function createEventLogger(appLoadContext) { | ||
const context = appLoadContext || {}; | ||
const eventLoggerService = context?.env?.H2O_LOG_EVENT; | ||
if (typeof eventLoggerService?.fetch !== "function") return; | ||
return ({ | ||
url, | ||
endTime = Date.now(), | ||
waitUntil = context?.waitUntil, | ||
...rest | ||
}) => { | ||
const promise = Promise.resolve().then( | ||
() => eventLoggerService.fetch( | ||
new Request(url, { | ||
method: "POST", | ||
body: JSON.stringify({ | ||
endTime, | ||
...rest | ||
}) | ||
}) | ||
).catch((error) => { | ||
if (!hasWarned) { | ||
console.debug("Failed to log H2O event\n", error.stack); | ||
hasWarned = true; | ||
} | ||
}) | ||
); | ||
promise && waitUntil?.(promise); | ||
}; | ||
} | ||
// src/server.ts | ||
var originalErrorToString = Error.prototype.toString; | ||
Error.prototype.toString = function() { | ||
return this.stack || originalErrorToString.call(this); | ||
}; | ||
function createRequestHandler({ | ||
build, | ||
mode, | ||
poweredByHeader = true, | ||
getLoadContext | ||
@@ -59,11 +98,43 @@ }) { | ||
return async (request) => { | ||
return handleRequest( | ||
request, | ||
await getLoadContext?.(request) | ||
); | ||
const method = request.method; | ||
if ((method === "GET" || method === "HEAD") && request.body) { | ||
return new Response(`${method} requests cannot have a body`, { | ||
status: 400 | ||
}); | ||
} | ||
const url = new URL(request.url); | ||
if (url.pathname.includes("//")) { | ||
return new Response(null, { | ||
status: 301, | ||
headers: { | ||
location: url.pathname.replace(/\/+/g, "/") | ||
} | ||
}); | ||
} | ||
const context = getLoadContext ? await getLoadContext(request) : void 0; | ||
if (context) { | ||
globalThis.__H2O_LOG_EVENT ??= createEventLogger(context); | ||
} | ||
const startTime = Date.now(); | ||
const response = await handleRequest(request, context); | ||
if (poweredByHeader) { | ||
response.headers.append("powered-by", "Shopify, Hydrogen"); | ||
} | ||
{ | ||
globalThis.__H2O_LOG_EVENT?.({ | ||
eventType: "request", | ||
url: request.url, | ||
requestId: request.headers.get("request-id"), | ||
purpose: request.headers.get("purpose"), | ||
startTime, | ||
responseInit: { | ||
status: response.status, | ||
statusText: response.statusText, | ||
headers: Array.from(response.headers.entries()) | ||
} | ||
}); | ||
} | ||
return response; | ||
}; | ||
} | ||
function getBuyerIp(request) { | ||
return request.headers.get("oxygen-buyer-ip") ?? void 0; | ||
} | ||
function getStorefrontHeaders(request) { | ||
@@ -74,8 +145,9 @@ const headers = request.headers; | ||
buyerIp: headers.get("oxygen-buyer-ip"), | ||
cookie: headers.get("cookie") | ||
cookie: headers.get("cookie"), | ||
purpose: headers.get("purpose") | ||
}; | ||
} | ||
export { createCookie, createCookieSessionStorage, createMemorySessionStorage, createRequestHandler, createSessionStorage, getBuyerIp, getStorefrontHeaders }; | ||
export { createCookie, createCookieSessionStorage, createMemorySessionStorage, createRequestHandler, createSessionStorage, getStorefrontHeaders }; | ||
//# sourceMappingURL=out.js.map | ||
//# sourceMappingURL=index.js.map |
import * as _remix_run_server_runtime from '@remix-run/server-runtime'; | ||
import { ServerBuild } from '@remix-run/server-runtime'; | ||
export { ActionArgs, ActionFunction, AppData, AppLoadContext, Cookie, CookieOptions, CookieParseOptions, CookieSerializeOptions, CookieSignatureOptions, DataFunctionArgs, EntryContext, ErrorBoundaryComponent, HandleDataRequestFunction, HandleDocumentRequestFunction, HeadersFunction, HtmlLinkDescriptor, HtmlMetaDescriptor, LinkDescriptor, LinksFunction, LoaderArgs, LoaderFunction, MaxPartSizeExceededError, MemoryUploadHandlerFilterArgs, MemoryUploadHandlerOptions, MetaDescriptor, MetaFunction, PageLinkDescriptor, RequestHandler, RouteComponent, RouteHandle, SerializeFrom, ServerBuild, ServerEntryModule, Session, SessionData, SessionIdStorageStrategy, SessionStorage, SignFunction, TypedResponse, UnsignFunction, UploadHandler, UploadHandlerPart, V2_MetaFunction, createSession, defer, isCookie, isSession, json, redirect, unstable_composeUploadHandlers, unstable_createMemoryUploadHandler, unstable_parseMultipartFormData } from '@remix-run/server-runtime'; | ||
export { ActionFunction, ActionFunctionArgs, AppLoadContext, Cookie, CookieOptions, CookieParseOptions, CookieSerializeOptions, CookieSignatureOptions, DataFunctionArgs, EntryContext, ErrorResponse, HandleDataRequestFunction, HandleDocumentRequestFunction, HandleErrorFunction, HeadersArgs, HeadersFunction, HtmlLinkDescriptor, JsonFunction, LinkDescriptor, LinksFunction, LoaderFunction, LoaderFunctionArgs, MaxPartSizeExceededError, MemoryUploadHandlerFilterArgs, MemoryUploadHandlerOptions, ServerRuntimeMetaArgs as MetaArgs, ServerRuntimeMetaDescriptor as MetaDescriptor, ServerRuntimeMetaFunction as MetaFunction, PageLinkDescriptor, RequestHandler, SerializeFrom, ServerBuild, ServerEntryModule, Session, SessionData, SessionIdStorageStrategy, SessionStorage, SignFunction, TypedDeferredData, TypedResponse, UnsignFunction, UploadHandler, UploadHandlerPart, createSession, defer, isCookie, isSession, json, redirect, redirectDocument } from '@remix-run/server-runtime'; | ||
@@ -10,8 +10,8 @@ declare const createCookie: _remix_run_server_runtime.CreateCookieFunction; | ||
declare function createRequestHandler<Context = unknown>({ build, mode, getLoadContext, }: { | ||
declare function createRequestHandler<Context = unknown>({ build, mode, poweredByHeader, getLoadContext, }: { | ||
build: ServerBuild; | ||
mode?: string; | ||
poweredByHeader?: boolean; | ||
getLoadContext?: (request: Request) => Promise<Context> | Context; | ||
}): (request: Request) => Promise<Response>; | ||
declare function getBuyerIp(request: Request): string | undefined; | ||
type StorefrontHeaders = { | ||
@@ -21,5 +21,6 @@ requestGroupId: string | null; | ||
cookie: string | null; | ||
purpose: string | null; | ||
}; | ||
declare function getStorefrontHeaders(request: Request): StorefrontHeaders; | ||
export { createCookie, createCookieSessionStorage, createMemorySessionStorage, createRequestHandler, createSessionStorage, getBuyerIp, getStorefrontHeaders }; | ||
export { createCookie, createCookieSessionStorage, createMemorySessionStorage, createRequestHandler, createSessionStorage, getStorefrontHeaders }; |
import { createCookieFactory, createCookieSessionStorageFactory, createSessionStorageFactory, createMemorySessionStorageFactory, createRequestHandler } from '@remix-run/server-runtime'; | ||
export { MaxPartSizeExceededError, createSession, defer, isCookie, isSession, json, redirect, unstable_composeUploadHandlers, unstable_createMemoryUploadHandler, unstable_parseMultipartFormData } from '@remix-run/server-runtime'; | ||
export { MaxPartSizeExceededError, createSession, defer, isCookie, isSession, json, redirect, redirectDocument } from '@remix-run/server-runtime'; | ||
var s=new TextEncoder,c=async(e,t)=>{let o=await p(t,["sign"]),r=s.encode(e),n=await crypto.subtle.sign("HMAC",o,r),a=btoa(String.fromCharCode(...new Uint8Array(n))).replace(/=+$/,"");return e+"."+a},u=async(e,t)=>{let o=e.lastIndexOf("."),r=e.slice(0,o),n=e.slice(o+1),a=await p(t,["verify"]),l=s.encode(r),y=g(atob(n));return await crypto.subtle.verify("HMAC",a,y,l)?r:!1};async function p(e,t){return await crypto.subtle.importKey("raw",s.encode(e),{name:"HMAC",hash:"SHA-256"},!1,t)}function g(e){let t=new Uint8Array(e.length);for(let o=0;o<e.length;o++)t[o]=e.charCodeAt(o);return t}var i=createCookieFactory({sign:c,unsign:u}),f=createCookieSessionStorageFactory(i),d=createSessionStorageFactory(i),H=createMemorySessionStorageFactory(d);function F({build:e,mode:t,getLoadContext:o}){let r=createRequestHandler(e,t);return async n=>r(n,await o?.(n))}function A(e){return e.headers.get("oxygen-buyer-ip")??void 0}function M(e){let t=e.headers;return {requestGroupId:t.get("request-id"),buyerIp:t.get("oxygen-buyer-ip"),cookie:t.get("cookie")}} | ||
var c=new TextEncoder,l=async(e,t)=>{let r=await y(t,["sign"]),n=c.encode(e),s=await crypto.subtle.sign("HMAC",r,n),o=btoa(String.fromCharCode(...new Uint8Array(s))).replace(/=+$/,"");return e+"."+o},g=async(e,t)=>{let r=e.lastIndexOf("."),n=e.slice(0,r),s=e.slice(r+1),o=await y(t,["verify"]),a=c.encode(n),i=m(atob(s));return await crypto.subtle.verify("HMAC",o,i,a)?n:!1};async function y(e,t){return await crypto.subtle.importKey("raw",c.encode(e),{name:"HMAC",hash:"SHA-256"},!1,t)}function m(e){let t=new Uint8Array(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}var u=createCookieFactory({sign:l,unsign:g}),C=createCookieSessionStorageFactory(u),S=createSessionStorageFactory(u),k=createMemorySessionStorageFactory(S);var A=Error.prototype.toString;Error.prototype.toString=function(){return this.stack||A.call(this)};function E({build:e,mode:t,poweredByHeader:r=!0,getLoadContext:n}){let s=createRequestHandler(e,t);return async o=>{let a=o.method;if((a==="GET"||a==="HEAD")&&o.body)return new Response(`${a} requests cannot have a body`,{status:400});let i=new URL(o.url);if(i.pathname.includes("//"))return new Response(null,{status:301,headers:{location:i.pathname.replace(/\/+/g,"/")}});let p=n?await n(o):void 0,d=await s(o,p);return r&&d.headers.append("powered-by","Shopify, Hydrogen"),d}}function v(e){let t=e.headers;return {requestGroupId:t.get("request-id"),buyerIp:t.get("oxygen-buyer-ip"),cookie:t.get("cookie"),purpose:t.get("purpose")}} | ||
export { i as createCookie, f as createCookieSessionStorage, H as createMemorySessionStorage, F as createRequestHandler, d as createSessionStorage, A as getBuyerIp, M as getStorefrontHeaders }; | ||
export { u as createCookie, C as createCookieSessionStorage, k as createMemorySessionStorage, E as createRequestHandler, S as createSessionStorage, v as getStorefrontHeaders }; | ||
//# sourceMappingURL=out.js.map | ||
//# sourceMappingURL=index.js.map |
@@ -8,4 +8,4 @@ { | ||
"type": "module", | ||
"version": "0.0.0-next-beb56c6-20230315164633", | ||
"license": "SEE LICENSE IN LICENSE.md", | ||
"version": "0.0.0-next-bf39d28-20250129224231", | ||
"license": "MIT", | ||
"main": "dist/index.cjs", | ||
@@ -15,5 +15,10 @@ "module": "dist/production/index.js", | ||
"sideEffects": false, | ||
"repository": { | ||
"type": "git", | ||
"url": "git+https://github.com/Shopify/hydrogen.git", | ||
"directory": "packages/remix-oxygen" | ||
}, | ||
"scripts": { | ||
"build": "tsup --clean --config ../../tsup.config.ts", | ||
"dev": "tsup --watch --config ../../tsup.config.ts", | ||
"build": "tsup --clean", | ||
"dev": "tsup --watch", | ||
"prepack": "npm run build", | ||
@@ -44,11 +49,10 @@ "typecheck": "tsc --noEmit" | ||
], | ||
"dependencies": { | ||
"@remix-run/server-runtime": "1.14.0" | ||
}, | ||
"devDependencies": { | ||
"@shopify/oxygen-workers-types": "^3.17.2" | ||
"@remix-run/server-runtime": "^2.15.2", | ||
"@shopify/oxygen-workers-types": "^4.1.2" | ||
}, | ||
"peerDependencies": { | ||
"@shopify/oxygen-workers-types": "^3.17.2" | ||
"@remix-run/server-runtime": "^2.1.0", | ||
"@shopify/oxygen-workers-types": "^3.17.3 || ^4.1.2" | ||
} | ||
} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Misc. License Issues
License(Experimental) A package's licensing information has fine-grained problems.
Found 1 instance in 1 package
No repository
Supply chain riskPackage does not have a linked source code repository. Without this field, a package will have no reference to the location of the source code use to generate the package.
Found 1 instance in 1 package
63659
14
0
404
1
2
+ Added@remix-run/router@1.22.0(transitive)
+ Added@remix-run/server-runtime@2.15.3(transitive)
+ Added@shopify/oxygen-workers-types@4.1.6(transitive)
+ Added@types/cookie@0.6.0(transitive)
+ Addedcookie@0.6.0(transitive)
+ Addedturbo-stream@2.4.0(transitive)
- Removed@remix-run/server-runtime@1.14.0
- Removed@remix-run/router@1.3.3(transitive)
- Removed@remix-run/server-runtime@1.14.0(transitive)
- Removed@shopify/oxygen-workers-types@3.17.3(transitive)
- Removed@types/cookie@0.4.1(transitive)
- Removed@types/prop-types@15.7.14(transitive)
- Removed@types/react@18.3.18(transitive)
- Removedcookie@0.4.2(transitive)
- Removedcsstype@3.1.3(transitive)