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

@prisma/extension-accelerate

Package Overview
Dependencies
Maintainers
2
Versions
64
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@prisma/extension-accelerate - npm Package Compare versions

Comparing version 0.0.0-experimental-35892f1 to 0.0.0-experimental-3bafdd0

dist/cjs/entry.fetch.d.ts

4

dist/cjs/node-fetch.d.ts
/// <reference lib="dom" />
export type RequestOptions = {
export type FetchOptions = {
method?: string;

@@ -24,2 +24,2 @@ headers?: Record<string, string>;

*/
export declare function fetch(url: string, options?: RequestOptions): Promise<RequestResponse>;
export declare function fetch(url: string, options?: FetchOptions): Promise<RequestResponse>;
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
var desc = Object.getOwnPropertyDescriptor(m, k);
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
desc = { enumerable: true, get: function() { return m[k]; } };
}
Object.defineProperty(o, k2, desc);
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {

@@ -30,6 +7,9 @@ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");

};
var _FakeHeaders_headers;
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
var _NodeHeaders_headers;
Object.defineProperty(exports, "__esModule", { value: true });
exports.fetch = void 0;
const https = __importStar(require("https"));
const node_https_1 = __importDefault(require("node:https"));
/**

@@ -49,3 +29,3 @@ * Imitates `fetch` via `https` to only suit our needs, it does nothing more.

// we execute the https request and build a fetch response out of it
const request = https.request(url, httpsOptions, (response) => {
const request = node_https_1.default.request(url, httpsOptions, (response) => {
const { statusCode = 200, headers: { location }, } = response;

@@ -106,15 +86,15 @@ if (statusCode >= 301 && statusCode <= 399 && location) {

url: url,
headers: new FakeHeaders(headers),
headers: new NodeHeaders(headers),
};
}
class FakeHeaders {
class NodeHeaders {
constructor(init = {}) {
_FakeHeaders_headers.set(this, new Map());
_NodeHeaders_headers.set(this, new Map());
for (const [key, value] of Object.entries(init)) {
if (typeof value === "string") {
__classPrivateFieldGet(this, _FakeHeaders_headers, "f").set(key, value);
__classPrivateFieldGet(this, _NodeHeaders_headers, "f").set(key, value);
}
else if (Array.isArray(value)) {
for (const val of value) {
__classPrivateFieldGet(this, _FakeHeaders_headers, "f").set(key, val);
__classPrivateFieldGet(this, _NodeHeaders_headers, "f").set(key, val);
}

@@ -125,18 +105,18 @@ }

append(name, value) {
__classPrivateFieldGet(this, _FakeHeaders_headers, "f").set(name, value);
__classPrivateFieldGet(this, _NodeHeaders_headers, "f").set(name, value);
}
delete(name) {
__classPrivateFieldGet(this, _FakeHeaders_headers, "f").delete(name);
__classPrivateFieldGet(this, _NodeHeaders_headers, "f").delete(name);
}
get(name) {
return __classPrivateFieldGet(this, _FakeHeaders_headers, "f").get(name) ?? null;
return __classPrivateFieldGet(this, _NodeHeaders_headers, "f").get(name) ?? null;
}
has(name) {
return __classPrivateFieldGet(this, _FakeHeaders_headers, "f").has(name);
return __classPrivateFieldGet(this, _NodeHeaders_headers, "f").has(name);
}
set(name, value) {
__classPrivateFieldGet(this, _FakeHeaders_headers, "f").set(name, value);
__classPrivateFieldGet(this, _NodeHeaders_headers, "f").set(name, value);
}
forEach(callbackfn, thisArg) {
for (const [key, value] of __classPrivateFieldGet(this, _FakeHeaders_headers, "f")) {
for (const [key, value] of __classPrivateFieldGet(this, _NodeHeaders_headers, "f")) {
callbackfn.call(thisArg, value, key, this);

@@ -146,2 +126,2 @@ }

}
_FakeHeaders_headers = new WeakMap();
_NodeHeaders_headers = new WeakMap();
/// <reference lib="dom" />
export type RequestOptions = {
export type FetchOptions = {
method?: string;

@@ -24,2 +24,2 @@ headers?: Record<string, string>;

*/
export declare function fetch(url: string, options?: RequestOptions): Promise<RequestResponse>;
export declare function fetch(url: string, options?: FetchOptions): Promise<RequestResponse>;

@@ -1,2 +0,2 @@

import * as https from "https";
import https from "node:https";
/**

@@ -71,6 +71,6 @@ * Imitates `fetch` via `https` to only suit our needs, it does nothing more.

url: url,
headers: new FakeHeaders(headers),
headers: new NodeHeaders(headers),
};
}
class FakeHeaders {
class NodeHeaders {
#headers = new Map();

@@ -77,0 +77,0 @@ constructor(init = {}) {

{
"name": "@prisma/extension-accelerate",
"type": "module",
"version": "0.0.0-experimental-35892f1",
"version": "0.0.0-experimental-3bafdd0",
"description": "Prisma Client extension for Accelerate",
"sideEffects": false,
"exports": {
".": {
"import": "./dist/esm/index.js",
"require": "./dist/cjs/index.js"
}
"node": {
"import": "./dist/esm/entry.node.js",
"require": "./dist/cjs/entry.node.js"
},
"import": "./dist/esm/entry.fetch.js",
"require": "./dist/cjs/entry.fetch.js",
"default": "./dist/esm/entry.fetch.js"
},
"types": "./dist/cjs/index.d.ts",
"types": "./dist/cjs/entry.node.d.ts",
"scripts": {

@@ -26,12 +29,12 @@ "build": "./scripts/build.sh",

"devDependencies": {
"@prisma/client": "^5.0.0",
"@tsconfig/esm": "^1.0.4",
"@tsconfig/node14": "^1.0.3",
"@tsconfig/node18-strictest-esm": "^1.0.1",
"@typescript-eslint/eslint-plugin": "^5.61.0",
"@typescript-eslint/parser": "^5.61.0",
"@prisma/client": "^5.2.0",
"@tsconfig/node-lts": "^18.12.4",
"@tsconfig/node16": "^16.1.1",
"@tsconfig/strictest": "^2.0.1",
"@typescript-eslint/eslint-plugin": "^6.4.1",
"@typescript-eslint/parser": "^6.4.1",
"dotenv": "^16.3.1",
"eslint": "^8.44.0",
"prettier": "2.8.8",
"prisma": "^5.0.0",
"eslint": "^8.47.0",
"prettier": "^3.0.2",
"prisma": "^5.2.0",
"ts-node": "^10.9.1",

@@ -41,3 +44,3 @@ "typescript": "^5.1.6"

"peerDependencies": {
"@prisma/client": ">=5.0.0"
"@prisma/client": ">=4.16.1"
},

@@ -44,0 +47,0 @@ "engines": {

# Accelerate Prisma Client extension
Prisma Client extension to enable _Accelerate_.
This is the package for the [Prisma Client extension](https://www.prisma.io/docs/concepts/components/prisma-client/client-extensions) that enables usage of Prisma Accelerate.
[Prisma Accelerate](https://www.prisma.io/data-platform/accelerate) provides an external connection pool and global caching layer that you can use to speed up your database queries.
It is part of the [Prisma](https://www.prisma.io) ecosystem, alongside other tools such as:
- [Prisma ORM](https://github.com/prisma/prisma): Next-generation Node.js and TypeScript ORM, supporting PostgreSQL, MySQL, MariaDB, SQL Server, SQLite, CockroachDB, and MongoDB.
- [Prisma Pulse](https://www.prisma.io/data-platform/pulse): Real-time database events with type-safe subscriptions.
Prisma is leading Data DX, a philosophy that promotes simplicity in data-driven application development. Learn more on the [Data DX manifesto](https://www.datadx.io/).
## Getting started with Accelerate
### Resources
You can explore Accelerate with the following resources:
- [Get started](https://www.prisma.io/docs/data-platform/accelerate/getting-started)
- [Documentation](https://www.prisma.io/docs/data-platform/accelerate/what-is-accelerate)
- [Prisma Data Platform](https://console.prisma.io/login)
- [Accelerate Speed Test](https://accelerate-speed-test.prisma.io/)
### Using Accelerate
#### 1. Enable Accelerate
Log into [Prisma Data Platform](https://console.prisma.io/login) and enable Accelerate for your project.
#### 2. Add Accelerate to your application
Replace the database connection string with the Accelerate connection string you generated in Prisma Data Platform (assuming you store your database connection string in the `DATABASE_URL` in the `.env` file):
```bash
DATABASE_URL="prisma://accelerate.prisma-data.net/?api_key=__API_KEY__"
```
To be able to seamlessly continue to use Prisma Migrate, you can set the `directUrl` property in your `datasource`:
```prisma
datasource db {
provider = "postgresql"
url = env("DATABASE_URL")
directUrl = env("DIRECT_DATABASE_URL")
}
```
And then add the URL that connects directly to your database as the value for `DIRECT_DATABASE_URL` :
```prisma
DATABASE_URL="prisma://accelerate.prisma-data.net/?api_key=__API_KEY__"
DIRECT_DATABASE_URL="postgresql://USER:PASSWORD@HOST:PORT/DATABASE"
```
Finally, extend your Prisma Client instance with the Accelerate extension to enable Accelerate’s connection pool:
```ts
import { PrismaClient } from '@prisma/client/edge'
import { withAccelerate } from '@prisma/extension-accelerate'
const prisma = new PrismaClient().$extends(withAccelerate())
```
#### 3. Add caching to your Accelerate queries
You can optionally configure caching on a per-query level using the `ttl` (Time-To-Live) and `swl` (Stale-While-Revalidate) options:
```ts
await prisma.user.findMany({
cacheStrategy: {
ttl: 3_600,
swr: 500
},
});
```
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