Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@shopify/remix-oxygen

Package Overview
Dependencies
Maintainers
0
Versions
808
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@shopify/remix-oxygen - npm Package Compare versions

Comparing version 0.0.0-next-c85b8b5-20230905125849 to 0.0.0-next-c8d1306-20241101205022

87

dist/development/index.js
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,2 +51,40 @@ // 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({

@@ -60,15 +98,43 @@ build,

return async (request) => {
const response = await 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) {

@@ -79,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

6

dist/production/index.d.ts
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_ServerRuntimeMetaDescriptor as V2_HtmlMetaDescriptor, V2_ServerRuntimeMetaArgs as V2_MetaArgs, V2_ServerRuntimeMetaDescriptor as V2_MetaDescriptor, V2_ServerRuntimeMetaFunction as 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';

@@ -16,3 +16,2 @@ declare const createCookie: _remix_run_server_runtime.CreateCookieFunction;

}): (request: Request) => Promise<Response>;
declare function getBuyerIp(request: Request): string | undefined;
type StorefrontHeaders = {

@@ -22,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 i=new TextEncoder,u=async(e,t)=>{let r=await d(t,["sign"]),o=i.encode(e),a=await crypto.subtle.sign("HMAC",r,o),n=btoa(String.fromCharCode(...new Uint8Array(a))).replace(/=+$/,"");return e+"."+n},p=async(e,t)=>{let r=e.lastIndexOf("."),o=e.slice(0,r),a=e.slice(r+1),n=await d(t,["verify"]),s=i.encode(o),y=g(atob(a));return await crypto.subtle.verify("HMAC",n,y,s)?o:!1};async function d(e,t){return await crypto.subtle.importKey("raw",i.encode(e),{name:"HMAC",hash:"SHA-256"},!1,t)}function g(e){let t=new Uint8Array(e.length);for(let r=0;r<e.length;r++)t[r]=e.charCodeAt(r);return t}var c=createCookieFactory({sign:u,unsign:p}),f=createCookieSessionStorageFactory(c),l=createSessionStorageFactory(c),H=createMemorySessionStorageFactory(l);function F({build:e,mode:t,poweredByHeader:r=!0,getLoadContext:o}){let a=createRequestHandler(e,t);return async n=>{let s=await a(n,await o?.(n));return r&&s.headers.append("powered-by","Shopify, Hydrogen"),s}}function M(e){return e.headers.get("oxygen-buyer-ip")??void 0}function A(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 { c as createCookie, f as createCookieSessionStorage, H as createMemorySessionStorage, F as createRequestHandler, l as createSessionStorage, M as getBuyerIp, A 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,3 +8,3 @@ {

"type": "module",
"version": "0.0.0-next-c85b8b5-20230905125849",
"version": "0.0.0-next-c8d1306-20241101205022",
"license": "MIT",

@@ -43,11 +43,10 @@ "main": "dist/index.cjs",

],
"dependencies": {
"@remix-run/server-runtime": "1.19.1"
},
"devDependencies": {
"@shopify/oxygen-workers-types": "^3.17.3"
"@remix-run/server-runtime": "^2.13.1",
"@shopify/oxygen-workers-types": "^4.1.2"
},
"peerDependencies": {
"@shopify/oxygen-workers-types": "^3.17.3"
"@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

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc