Runtime API Reference
This document provides references for runtime APIs exported from the @zenstackhq/runtime
package.
enhance
Description
Creates an enhanced wrapper for a PrismaClient
. The return value has the same APIs as the original PrismaClient
.
Signature
function enhance<DbClient extends object>(
prisma: DbClient,
context?: EnhancementContext,
options?: EnhancementOptions
): DbClient;
Parameter prisma
The PrismaClient instance to enhance.
Parameter context
The context to for evaluating access policies with the following typing.
type EnhancementContext = {
user?: Record<string, unknown>
};
Field | Description |
---|---|
user | The user object that provides value for the auth() function call in access policies. If provided. Its shape should be consistent with the User model in your ZModel, with all fields optional except for id field(s). Pass undefined to represent an anonymous user, and the auth() function call will evaluate to null in that case. |
Parameter options
Options with the following typing.
type TransactionIsolationLevel =
| 'ReadUncommitted'
| 'ReadCommitted'
| 'RepeatableRead'
| 'Snapshot'
| 'Serializable';
type SimpleEncryption = {
encryptionKey: Uint8Array;
decryptionKeys?: Uint8Array[];
}
type CustomEncryption = {
encrypt: (model: string, field: FieldInfo, plain: string) => Promise<string>;
decrypt: (model: string, field: FieldInfo, cipher: string) => Promise<string>;
};
type EnhancementOptions = {
kinds?: EnhancementKind[];
logPrismaQuery?: boolean;
errorTransformer?: ErrorTransformer;
transactionMaxWait?: number;
transactionTimeout?: number;
transactionIsolationLevel?: TransactionIsolationLevel;
encryption?: SimpleEncryption | CustomEncryption;
};
Field | Description | Default |
---|---|---|
kinds | The kinds of enhancements to apply. By default all enhancements are applied. See the next section for more details. | All enhancement kinds |
logPrismaQuery | Whether to log queries sent to Prisma client. Log will be emitted with "info" level, so please make sure you turn that level on when creating Prisma client | false |
errorTransformer | A function for transforming error thrown by the enhanced PrismaClient into a custom one. | |
transactionMaxWait | The maxWait option (in ms) passed to prisma.$transaction() call for transactions initiated by ZenStack. | Database default |
transactionTimeout | The timeout option (in ms) passed to prisma.$transaction() call for transactions initiated by ZenStack. | Database default |
transactionIsolationLevel | The isolationLevel option passed to prisma.$transaction() call for transactions initiated by ZenStack. | Database default |
encryption | Field encryption settings. Only required when using the field encryption feature. |
Enhancement Kinds
Here are the kinds of enhancements available:
-
policy
Enforces model-level and field-level access policies defined with
@@allow
,@@deny
,@allow
, and@deny
. -
validation
Validates create and update input data against rules defined with data validation attributes.
-
delegate
Support for modeling polymorphic relations with delegated types pattern.
-
password
Automatically hashes fields marked with the
@password
attribute usingbcryptjs
before saving to the database. -
omit
Automatically omits fields marked with the
@omit
attribute from read results. -
encryption
Transparently encrypt and decrypt fields marked with the
@encrypted
attribute. See this guide for more details.
Example
const session = getSession();
const enhancedClient = enhance(prisma,
{ user: session.user },
{ kinds: ['policy', 'password']}
);