UNPKG

auth-vir

Version:

Auth made easy and secure via JWT cookies, CSRF tokens, and password hashing helpers.

1,137 lines (1,047 loc) 40.5 kB
import {type Branded} from '@augment-vir/common'; export type UserId = Branded<string, 'model-User-field-id'>; // @ts-nocheck import {type UtcIsoString} from 'date-vir'; /* !!! This is code generated by Prisma. Do not edit directly. !!! */ /* eslint-disable */ // biome-ignore-all lint: generated file /* * This file exports the `User` model and its related types. * * 🟢 You can import this file directly. */ import type * as runtime from "@prisma/client/runtime/client" import type * as $Enums from "../enums.js" import type * as Prisma from "../internal/prismaNamespace.js" /** * Model User * */ export type UserModel = runtime.Types.Result.DefaultSelection<Prisma.$UserPayload> export type AggregateUser = { _count: UserCountAggregateOutputType | null _min: UserMinAggregateOutputType | null _max: UserMaxAggregateOutputType | null } export type UserMinAggregateOutputType = { id: UserId | null createdAt: UtcIsoString | null updatedAt: UtcIsoString | null name: string | null } export type UserMaxAggregateOutputType = { id: UserId | null createdAt: UtcIsoString | null updatedAt: UtcIsoString | null name: string | null } export type UserCountAggregateOutputType = { id: number createdAt: number updatedAt: number name: number _all: number } export type UserMinAggregateInputType = { id?: true | runtime.Types.Skip createdAt?: true | runtime.Types.Skip updatedAt?: true | runtime.Types.Skip name?: true | runtime.Types.Skip } export type UserMaxAggregateInputType = { id?: true | runtime.Types.Skip createdAt?: true | runtime.Types.Skip updatedAt?: true | runtime.Types.Skip name?: true | runtime.Types.Skip } export type UserCountAggregateInputType = { id?: true | runtime.Types.Skip createdAt?: true | runtime.Types.Skip updatedAt?: true | runtime.Types.Skip name?: true | runtime.Types.Skip _all?: true | runtime.Types.Skip } export type UserAggregateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Filter which User to aggregate. */ where?: Prisma.UserWhereInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs} * * Determine the order of Users to fetch. */ orderBy?: Prisma.UserOrderByWithRelationInput | Prisma.UserOrderByWithRelationInput[] | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs} * * Sets the start position */ cursor?: Prisma.UserWhereUniqueInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Take `±n` Users from the position of the cursor. */ take?: number | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Skip the first `n` Users. */ skip?: number | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs} * * Count returned Users **/ _count?: true | UserCountAggregateInputType /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs} * * Select which fields to find the minimum value **/ _min?: UserMinAggregateInputType /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs} * * Select which fields to find the maximum value **/ _max?: UserMaxAggregateInputType } export type GetUserAggregateType<T extends UserAggregateArgs> = { [P in keyof T & keyof AggregateUser]: P extends '_count' | 'count' ? T[P] extends true ? number : Prisma.GetScalarType<T[P], AggregateUser[P]> : Prisma.GetScalarType<T[P], AggregateUser[P]> } export type UserGroupByArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { where?: Prisma.UserWhereInput | runtime.Types.Skip orderBy?: Prisma.UserOrderByWithAggregationInput | Prisma.UserOrderByWithAggregationInput[] | runtime.Types.Skip by: Prisma.UserScalarFieldEnum[] | Prisma.UserScalarFieldEnum having?: Prisma.UserScalarWhereWithAggregatesInput | runtime.Types.Skip take?: number | runtime.Types.Skip skip?: number | runtime.Types.Skip _count?: UserCountAggregateInputType | true _min?: UserMinAggregateInputType _max?: UserMaxAggregateInputType } export type UserGroupByOutputType = { id: UserId createdAt: UtcIsoString updatedAt: UtcIsoString name: string _count: UserCountAggregateOutputType | null _min: UserMinAggregateOutputType | null _max: UserMaxAggregateOutputType | null } type GetUserGroupByPayload<T extends UserGroupByArgs> = Prisma.PrismaPromise< Array< Prisma.PickEnumerable<UserGroupByOutputType, T['by']> & { [P in ((keyof T) & (keyof UserGroupByOutputType))]: P extends '_count' ? T[P] extends boolean ? number : Prisma.GetScalarType<T[P], UserGroupByOutputType[P]> : Prisma.GetScalarType<T[P], UserGroupByOutputType[P]> } > > export type UserWhereInput = { AND?: Prisma.UserWhereInput | Prisma.UserWhereInput[] | runtime.Types.Skip OR?: Prisma.UserWhereInput[] | runtime.Types.Skip NOT?: Prisma.UserWhereInput | Prisma.UserWhereInput[] | runtime.Types.Skip id?: Prisma.StringFilter<"User", UserId> | UserId | runtime.Types.Skip createdAt?: Prisma.DateTimeFilter<"User"> | UtcIsoString | runtime.Types.Skip updatedAt?: Prisma.DateTimeFilter<"User"> | UtcIsoString | runtime.Types.Skip name?: Prisma.StringFilter<"User"> | string | runtime.Types.Skip } export type UserOrderByWithRelationInput = { id?: Prisma.SortOrder | runtime.Types.Skip createdAt?: Prisma.SortOrder | runtime.Types.Skip updatedAt?: Prisma.SortOrder | runtime.Types.Skip name?: Prisma.SortOrder | runtime.Types.Skip } export type UserWhereUniqueInput = Prisma.AtLeast<{ id?: UserId | runtime.Types.Skip AND?: Prisma.UserWhereInput | Prisma.UserWhereInput[] | runtime.Types.Skip OR?: Prisma.UserWhereInput[] | runtime.Types.Skip NOT?: Prisma.UserWhereInput | Prisma.UserWhereInput[] | runtime.Types.Skip createdAt?: Prisma.DateTimeFilter<"User"> | UtcIsoString | runtime.Types.Skip updatedAt?: Prisma.DateTimeFilter<"User"> | UtcIsoString | runtime.Types.Skip name?: Prisma.StringFilter<"User"> | string | runtime.Types.Skip }, "id"> export type UserOrderByWithAggregationInput = { id?: Prisma.SortOrder | runtime.Types.Skip createdAt?: Prisma.SortOrder | runtime.Types.Skip updatedAt?: Prisma.SortOrder | runtime.Types.Skip name?: Prisma.SortOrder | runtime.Types.Skip _count?: Prisma.UserCountOrderByAggregateInput | runtime.Types.Skip _max?: Prisma.UserMaxOrderByAggregateInput | runtime.Types.Skip _min?: Prisma.UserMinOrderByAggregateInput | runtime.Types.Skip } export type UserScalarWhereWithAggregatesInput = { AND?: Prisma.UserScalarWhereWithAggregatesInput | Prisma.UserScalarWhereWithAggregatesInput[] | runtime.Types.Skip OR?: Prisma.UserScalarWhereWithAggregatesInput[] | runtime.Types.Skip NOT?: Prisma.UserScalarWhereWithAggregatesInput | Prisma.UserScalarWhereWithAggregatesInput[] | runtime.Types.Skip id?: Prisma.StringWithAggregatesFilter<"User", UserId> | UserId | runtime.Types.Skip createdAt?: Prisma.DateTimeWithAggregatesFilter<"User"> | UtcIsoString | runtime.Types.Skip updatedAt?: Prisma.DateTimeWithAggregatesFilter<"User"> | UtcIsoString | runtime.Types.Skip name?: Prisma.StringWithAggregatesFilter<"User"> | string | runtime.Types.Skip } export type UserCreateInput = { id?: UserId | runtime.Types.Skip createdAt?: UtcIsoString | runtime.Types.Skip updatedAt?: UtcIsoString | runtime.Types.Skip name: string } export type UserUncheckedCreateInput = { id?: UserId | runtime.Types.Skip createdAt?: UtcIsoString | runtime.Types.Skip updatedAt?: UtcIsoString | runtime.Types.Skip name: string } export type UserUpdateInput = { id?: Prisma.StringFieldUpdateOperationsInput<UserId> | UserId | runtime.Types.Skip createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip name?: Prisma.StringFieldUpdateOperationsInput | string | runtime.Types.Skip } export type UserUncheckedUpdateInput = { id?: Prisma.StringFieldUpdateOperationsInput<UserId> | UserId | runtime.Types.Skip createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip name?: Prisma.StringFieldUpdateOperationsInput | string | runtime.Types.Skip } export type UserCreateManyInput = { id?: UserId | runtime.Types.Skip createdAt?: UtcIsoString | runtime.Types.Skip updatedAt?: UtcIsoString | runtime.Types.Skip name: string } export type UserUpdateManyMutationInput = { id?: Prisma.StringFieldUpdateOperationsInput<UserId> | UserId | runtime.Types.Skip createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip name?: Prisma.StringFieldUpdateOperationsInput | string | runtime.Types.Skip } export type UserUncheckedUpdateManyInput = { id?: Prisma.StringFieldUpdateOperationsInput<UserId> | UserId | runtime.Types.Skip createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | UtcIsoString | runtime.Types.Skip name?: Prisma.StringFieldUpdateOperationsInput | string | runtime.Types.Skip } export type UserCountOrderByAggregateInput = { id?: Prisma.SortOrder | runtime.Types.Skip createdAt?: Prisma.SortOrder | runtime.Types.Skip updatedAt?: Prisma.SortOrder | runtime.Types.Skip name?: Prisma.SortOrder | runtime.Types.Skip } export type UserMaxOrderByAggregateInput = { id?: Prisma.SortOrder | runtime.Types.Skip createdAt?: Prisma.SortOrder | runtime.Types.Skip updatedAt?: Prisma.SortOrder | runtime.Types.Skip name?: Prisma.SortOrder | runtime.Types.Skip } export type UserMinOrderByAggregateInput = { id?: Prisma.SortOrder | runtime.Types.Skip createdAt?: Prisma.SortOrder | runtime.Types.Skip updatedAt?: Prisma.SortOrder | runtime.Types.Skip name?: Prisma.SortOrder | runtime.Types.Skip } export type DateTimeFieldUpdateOperationsInput = { set?: UtcIsoString | runtime.Types.Skip } export type UserSelect<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{ id?: boolean | runtime.Types.Skip createdAt?: boolean | runtime.Types.Skip updatedAt?: boolean | runtime.Types.Skip name?: boolean | runtime.Types.Skip }, ExtArgs["result"]["user"]> export type UserSelectCreateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{ id?: boolean | runtime.Types.Skip createdAt?: boolean | runtime.Types.Skip updatedAt?: boolean | runtime.Types.Skip name?: boolean | runtime.Types.Skip }, ExtArgs["result"]["user"]> export type UserSelectUpdateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{ id?: boolean | runtime.Types.Skip createdAt?: boolean | runtime.Types.Skip updatedAt?: boolean | runtime.Types.Skip name?: boolean | runtime.Types.Skip }, ExtArgs["result"]["user"]> export type UserSelectScalar = { id?: boolean | runtime.Types.Skip createdAt?: boolean | runtime.Types.Skip updatedAt?: boolean | runtime.Types.Skip name?: boolean | runtime.Types.Skip } export type UserOmit<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetOmit<"id" | "createdAt" | "updatedAt" | "name", ExtArgs["result"]["user"], runtime.Types.Skip> export type $UserPayload<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { name: "User" objects: {} scalars: runtime.Types.Extensions.GetPayloadResult<{ id: UserId createdAt: UtcIsoString updatedAt: UtcIsoString name: string }, ExtArgs["result"]["user"]> composites: {} } export type UserGetPayload<S extends boolean | null | undefined | UserDefaultArgs> = runtime.Types.Result.GetResult<Prisma.$UserPayload, S> export type UserCountArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = Omit<UserFindManyArgs, 'select' | 'include' | 'distinct' | 'omit' | 'relationLoadStrategy'> & { select?: UserCountAggregateInputType | true } export interface UserDelegate<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs, GlobalOmitOptions = {}> { [K: symbol]: { types: Prisma.TypeMap<ExtArgs>['model']['User'], meta: { name: 'User' } } /** * Find zero or one User that matches the filter. * @param {UserFindUniqueArgs} args - Arguments to find a User * @example * // Get one User * const user = await prisma.user.findUnique({ * where: { * // ... provide filter here * } * }) */ findUnique<T extends UserFindUniqueArgs>(args: Prisma.SelectSubset<T, UserFindUniqueArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "findUnique", GlobalOmitOptions> | null, null, ExtArgs, GlobalOmitOptions> /** * Find one User that matches the filter or throw an error with `error.code='P2025'` * if no matches were found. * @param {UserFindUniqueOrThrowArgs} args - Arguments to find a User * @example * // Get one User * const user = await prisma.user.findUniqueOrThrow({ * where: { * // ... provide filter here * } * }) */ findUniqueOrThrow<T extends UserFindUniqueOrThrowArgs>(args: Prisma.SelectSubset<T, UserFindUniqueOrThrowArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "findUniqueOrThrow", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions> /** * Find the first User that matches the filter. * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * @param {UserFindFirstArgs} args - Arguments to find a User * @example * // Get one User * const user = await prisma.user.findFirst({ * where: { * // ... provide filter here * } * }) */ findFirst<T extends UserFindFirstArgs>(args?: Prisma.SelectSubset<T, UserFindFirstArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "findFirst", GlobalOmitOptions> | null, null, ExtArgs, GlobalOmitOptions> /** * Find the first User that matches the filter or * throw `PrismaKnownClientError` with `P2025` code if no matches were found. * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * @param {UserFindFirstOrThrowArgs} args - Arguments to find a User * @example * // Get one User * const user = await prisma.user.findFirstOrThrow({ * where: { * // ... provide filter here * } * }) */ findFirstOrThrow<T extends UserFindFirstOrThrowArgs>(args?: Prisma.SelectSubset<T, UserFindFirstOrThrowArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "findFirstOrThrow", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions> /** * Find zero or more Users that matches the filter. * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * @param {UserFindManyArgs} args - Arguments to filter and select certain fields only. * @example * // Get all Users * const users = await prisma.user.findMany() * * // Get first 10 Users * const users = await prisma.user.findMany({ take: 10 }) * * // Only select the `id` * const userWithIdOnly = await prisma.user.findMany({ select: { id: true } }) * */ findMany<T extends UserFindManyArgs>(args?: Prisma.SelectSubset<T, UserFindManyArgs<ExtArgs>>): Prisma.PrismaPromise<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "findMany", GlobalOmitOptions>> /** * Create a User. * @param {UserCreateArgs} args - Arguments to create a User. * @example * // Create one User * const User = await prisma.user.create({ * data: { * // ... data to create a User * } * }) * */ create<T extends UserCreateArgs>(args: Prisma.SelectSubset<T, UserCreateArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "create", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions> /** * Create many Users. * @param {UserCreateManyArgs} args - Arguments to create many Users. * @example * // Create many Users * const user = await prisma.user.createMany({ * data: [ * // ... provide data here * ] * }) * */ createMany<T extends UserCreateManyArgs>(args?: Prisma.SelectSubset<T, UserCreateManyArgs<ExtArgs>>): Prisma.PrismaPromise<Prisma.BatchPayload> /** * Create many Users and returns the data saved in the database. * @param {UserCreateManyAndReturnArgs} args - Arguments to create many Users. * @example * // Create many Users * const user = await prisma.user.createManyAndReturn({ * data: [ * // ... provide data here * ] * }) * * // Create many Users and only return the `id` * const userWithIdOnly = await prisma.user.createManyAndReturn({ * select: { id: true }, * data: [ * // ... provide data here * ] * }) * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * */ createManyAndReturn<T extends UserCreateManyAndReturnArgs>(args?: Prisma.SelectSubset<T, UserCreateManyAndReturnArgs<ExtArgs>>): Prisma.PrismaPromise<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "createManyAndReturn", GlobalOmitOptions>> /** * Delete a User. * @param {UserDeleteArgs} args - Arguments to delete one User. * @example * // Delete one User * const User = await prisma.user.delete({ * where: { * // ... filter to delete one User * } * }) * */ delete<T extends UserDeleteArgs>(args: Prisma.SelectSubset<T, UserDeleteArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "delete", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions> /** * Update one User. * @param {UserUpdateArgs} args - Arguments to update one User. * @example * // Update one User * const user = await prisma.user.update({ * where: { * // ... provide filter here * }, * data: { * // ... provide data here * } * }) * */ update<T extends UserUpdateArgs>(args: Prisma.SelectSubset<T, UserUpdateArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "update", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions> /** * Delete zero or more Users. * @param {UserDeleteManyArgs} args - Arguments to filter Users to delete. * @example * // Delete a few Users * const { count } = await prisma.user.deleteMany({ * where: { * // ... provide filter here * } * }) * */ deleteMany<T extends UserDeleteManyArgs>(args?: Prisma.SelectSubset<T, UserDeleteManyArgs<ExtArgs>>): Prisma.PrismaPromise<Prisma.BatchPayload> /** * Update zero or more Users. * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * @param {UserUpdateManyArgs} args - Arguments to update one or more rows. * @example * // Update many Users * const user = await prisma.user.updateMany({ * where: { * // ... provide filter here * }, * data: { * // ... provide data here * } * }) * */ updateMany<T extends UserUpdateManyArgs>(args: Prisma.SelectSubset<T, UserUpdateManyArgs<ExtArgs>>): Prisma.PrismaPromise<Prisma.BatchPayload> /** * Update zero or more Users and returns the data updated in the database. * @param {UserUpdateManyAndReturnArgs} args - Arguments to update many Users. * @example * // Update many Users * const user = await prisma.user.updateManyAndReturn({ * where: { * // ... provide filter here * }, * data: [ * // ... provide data here * ] * }) * * // Update zero or more Users and only return the `id` * const userWithIdOnly = await prisma.user.updateManyAndReturn({ * select: { id: true }, * where: { * // ... provide filter here * }, * data: [ * // ... provide data here * ] * }) * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * */ updateManyAndReturn<T extends UserUpdateManyAndReturnArgs>(args: Prisma.SelectSubset<T, UserUpdateManyAndReturnArgs<ExtArgs>>): Prisma.PrismaPromise<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "updateManyAndReturn", GlobalOmitOptions>> /** * Create or update one User. * @param {UserUpsertArgs} args - Arguments to update or create a User. * @example * // Update or create a User * const user = await prisma.user.upsert({ * create: { * // ... data to create a User * }, * update: { * // ... in case it already exists, update * }, * where: { * // ... the filter for the User we want to update * } * }) */ upsert<T extends UserUpsertArgs>(args: Prisma.SelectSubset<T, UserUpsertArgs<ExtArgs>>): Prisma.Prisma__UserClient<runtime.Types.Result.GetResult<Prisma.$UserPayload<ExtArgs>, T, "upsert", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions> /** * Count the number of Users. * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * @param {UserCountArgs} args - Arguments to filter Users to count. * @example * // Count the number of Users * const count = await prisma.user.count({ * where: { * // ... the filter for the Users we want to count * } * }) **/ count<T extends UserCountArgs>( args?: Prisma.Subset<T, UserCountArgs>, ): Prisma.PrismaPromise< T extends runtime.Types.Utils.Record<'select', any> ? T['select'] extends true ? number : Prisma.GetScalarType<T['select'], UserCountAggregateOutputType> : number > /** * Allows you to perform aggregations operations on a User. * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * @param {UserAggregateArgs} args - Select which aggregations you would like to apply and on what fields. * @example * // Ordered by age ascending * // Where email contains prisma.io * // Limited to the 10 users * const aggregations = await prisma.user.aggregate({ * _avg: { * age: true, * }, * where: { * email: { * contains: "prisma.io", * }, * }, * orderBy: { * age: "asc", * }, * take: 10, * }) **/ aggregate<T extends UserAggregateArgs>(args: Prisma.Subset<T, UserAggregateArgs>): Prisma.PrismaPromise<GetUserAggregateType<T>> /** * Group by User. * Note, that providing `undefined` is treated as the value not being there. * Read more here: https://pris.ly/d/null-undefined * @param {UserGroupByArgs} args - Group by arguments. * @example * // Group by city, order by createdAt, get count * const result = await prisma.user.groupBy({ * by: ['city', 'createdAt'], * orderBy: { * createdAt: true * }, * _count: { * _all: true * }, * }) * **/ groupBy< T extends UserGroupByArgs, HasSelectOrTake extends Prisma.Or< Prisma.Extends<'skip', Prisma.Keys<T>>, Prisma.Extends<'take', Prisma.Keys<T>> >, OrderByArg extends Prisma.True extends HasSelectOrTake ? { orderBy: UserGroupByArgs['orderBy'] } : { orderBy?: UserGroupByArgs['orderBy'] }, OrderFields extends Prisma.ExcludeUnderscoreKeys<Prisma.Keys<Prisma.MaybeTupleToUnion<T['orderBy']>>>, ByFields extends Prisma.MaybeTupleToUnion<T['by']>, ByValid extends Prisma.Has<ByFields, OrderFields>, HavingFields extends Prisma.GetHavingFields<T['having']>, HavingValid extends Prisma.Has<ByFields, HavingFields>, ByEmpty extends T['by'] extends never[] ? Prisma.True : Prisma.False, InputErrors extends ByEmpty extends Prisma.True ? `Error: "by" must not be empty.` : HavingValid extends Prisma.False ? { [P in HavingFields]: P extends ByFields ? never : P extends string ? `Error: Field "${P}" used in "having" needs to be provided in "by".` : [ Error, 'Field ', P, ` in "having" needs to be provided in "by"`, ] }[HavingFields] : 'take' extends Prisma.Keys<T> ? 'orderBy' extends Prisma.Keys<T> ? ByValid extends Prisma.True ? {} : { [P in OrderFields]: P extends ByFields ? never : `Error: Field "${P}" in "orderBy" needs to be provided in "by"` }[OrderFields] : 'Error: If you provide "take", you also need to provide "orderBy"' : 'skip' extends Prisma.Keys<T> ? 'orderBy' extends Prisma.Keys<T> ? ByValid extends Prisma.True ? {} : { [P in OrderFields]: P extends ByFields ? never : `Error: Field "${P}" in "orderBy" needs to be provided in "by"` }[OrderFields] : 'Error: If you provide "skip", you also need to provide "orderBy"' : ByValid extends Prisma.True ? {} : { [P in OrderFields]: P extends ByFields ? never : `Error: Field "${P}" in "orderBy" needs to be provided in "by"` }[OrderFields] >(args: Prisma.SubsetIntersection<T, UserGroupByArgs, OrderByArg> & InputErrors): {} extends InputErrors ? GetUserGroupByPayload<T> : Prisma.PrismaPromise<InputErrors> /** * Fields of the User model */ readonly fields: UserFieldRefs; } /** * The delegate class that acts as a "Promise-like" for User. * Why is this prefixed with `Prisma__`? * Because we want to prevent naming conflicts as mentioned in * https://github.com/prisma/prisma-client-js/issues/707 */ export interface Prisma__UserClient<T, Null = never, ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs, GlobalOmitOptions = {}> extends Prisma.PrismaPromise<T> { readonly [Symbol.toStringTag]: "PrismaPromise" /** * Attaches callbacks for the resolution and/or rejection of the Promise. * @param onfulfilled The callback to execute when the Promise is resolved. * @param onrejected The callback to execute when the Promise is rejected. * @returns A Promise for the completion of which ever callback is executed. */ then<TResult1 = T, TResult2 = never>(onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | undefined | null, onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | undefined | null): runtime.Types.Utils.JsPromise<TResult1 | TResult2> /** * Attaches a callback for only the rejection of the Promise. * @param onrejected The callback to execute when the Promise is rejected. * @returns A Promise for the completion of the callback. */ catch<TResult = never>(onrejected?: ((reason: any) => TResult | PromiseLike<TResult>) | undefined | null): runtime.Types.Utils.JsPromise<T | TResult> /** * Attaches a callback that is invoked when the Promise is settled (fulfilled or rejected). The * resolved value cannot be modified from the callback. * @param onfinally The callback to execute when the Promise is settled (fulfilled or rejected). * @returns A Promise for the completion of the callback. */ finally(onfinally?: (() => void) | undefined | null): runtime.Types.Utils.JsPromise<T> } /** * Fields of the User model */ export interface UserFieldRefs { readonly id: Prisma.FieldRef<"User", 'String'> readonly createdAt: Prisma.FieldRef<"User", 'DateTime'> readonly updatedAt: Prisma.FieldRef<"User", 'DateTime'> readonly name: Prisma.FieldRef<"User", 'String'> } // Custom InputTypes /** * User findUnique */ export type UserFindUniqueArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * Filter, which User to fetch. */ where: Prisma.UserWhereUniqueInput relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User findUniqueOrThrow */ export type UserFindUniqueOrThrowArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * Filter, which User to fetch. */ where: Prisma.UserWhereUniqueInput relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User findFirst */ export type UserFindFirstArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * Filter, which User to fetch. */ where?: Prisma.UserWhereInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs} * * Determine the order of Users to fetch. */ orderBy?: Prisma.UserOrderByWithRelationInput | Prisma.UserOrderByWithRelationInput[] | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs} * * Sets the position for searching for Users. */ cursor?: Prisma.UserWhereUniqueInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Take `±n` Users from the position of the cursor. */ take?: number | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Skip the first `n` Users. */ skip?: number | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/distinct Distinct Docs} * * Filter by unique combinations of Users. */ distinct?: Prisma.UserScalarFieldEnum | Prisma.UserScalarFieldEnum[] | runtime.Types.Skip relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User findFirstOrThrow */ export type UserFindFirstOrThrowArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * Filter, which User to fetch. */ where?: Prisma.UserWhereInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs} * * Determine the order of Users to fetch. */ orderBy?: Prisma.UserOrderByWithRelationInput | Prisma.UserOrderByWithRelationInput[] | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs} * * Sets the position for searching for Users. */ cursor?: Prisma.UserWhereUniqueInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Take `±n` Users from the position of the cursor. */ take?: number | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Skip the first `n` Users. */ skip?: number | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/distinct Distinct Docs} * * Filter by unique combinations of Users. */ distinct?: Prisma.UserScalarFieldEnum | Prisma.UserScalarFieldEnum[] | runtime.Types.Skip relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User findMany */ export type UserFindManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * Filter, which Users to fetch. */ where?: Prisma.UserWhereInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs} * * Determine the order of Users to fetch. */ orderBy?: Prisma.UserOrderByWithRelationInput | Prisma.UserOrderByWithRelationInput[] | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs} * * Sets the position for listing Users. */ cursor?: Prisma.UserWhereUniqueInput | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Take `±n` Users from the position of the cursor. */ take?: number | runtime.Types.Skip /** * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs} * * Skip the first `n` Users. */ skip?: number | runtime.Types.Skip distinct?: Prisma.UserScalarFieldEnum | Prisma.UserScalarFieldEnum[] | runtime.Types.Skip relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User create */ export type UserCreateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * The data needed to create a User. */ data: Prisma.XOR<Prisma.UserCreateInput, Prisma.UserUncheckedCreateInput> relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User createMany */ export type UserCreateManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * The data used to create many Users. */ data: Prisma.UserCreateManyInput | Prisma.UserCreateManyInput[] skipDuplicates?: boolean | runtime.Types.Skip } /** * User createManyAndReturn */ export type UserCreateManyAndReturnArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelectCreateManyAndReturn<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * The data used to create many Users. */ data: Prisma.UserCreateManyInput | Prisma.UserCreateManyInput[] skipDuplicates?: boolean | runtime.Types.Skip } /** * User update */ export type UserUpdateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * The data needed to update a User. */ data: Prisma.XOR<Prisma.UserUpdateInput, Prisma.UserUncheckedUpdateInput> /** * Choose, which User to update. */ where: Prisma.UserWhereUniqueInput relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User updateMany */ export type UserUpdateManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * The data used to update Users. */ data: Prisma.XOR<Prisma.UserUpdateManyMutationInput, Prisma.UserUncheckedUpdateManyInput> /** * Filter which Users to update */ where?: Prisma.UserWhereInput | runtime.Types.Skip /** * Limit how many Users to update. */ limit?: number | runtime.Types.Skip } /** * User updateManyAndReturn */ export type UserUpdateManyAndReturnArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelectUpdateManyAndReturn<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * The data used to update Users. */ data: Prisma.XOR<Prisma.UserUpdateManyMutationInput, Prisma.UserUncheckedUpdateManyInput> /** * Filter which Users to update */ where?: Prisma.UserWhereInput | runtime.Types.Skip /** * Limit how many Users to update. */ limit?: number | runtime.Types.Skip } /** * User upsert */ export type UserUpsertArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * The filter to search for the User to update in case it exists. */ where: Prisma.UserWhereUniqueInput /** * In case the User found by the `where` argument doesn't exist, create a new User with this data. */ create: Prisma.XOR<Prisma.UserCreateInput, Prisma.UserUncheckedCreateInput> /** * In case the User was found with the provided `where` argument, update it with this data. */ update: Prisma.XOR<Prisma.UserUpdateInput, Prisma.UserUncheckedUpdateInput> relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User delete */ export type UserDeleteArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null /** * Filter which User to delete. */ where: Prisma.UserWhereUniqueInput relationLoadStrategy?: Prisma.RelationLoadStrategy | runtime.Types.Skip } /** * User deleteMany */ export type UserDeleteManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Filter which Users to delete */ where?: Prisma.UserWhereInput | runtime.Types.Skip /** * Limit how many Users to delete. */ limit?: number | runtime.Types.Skip } /** * User without action */ export type UserDefaultArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { /** * Select specific fields to fetch from the User */ select?: Prisma.UserSelect<ExtArgs> | null /** * Omit specific fields from the User */ omit?: Prisma.UserOmit<ExtArgs> | null }