auth-vir
Version:
Auth made easy and secure via JWT cookies, CSRF tokens, and password hashing helpers.
981 lines (980 loc) • 41.6 kB
TypeScript
import { type Branded } from '@augment-vir/common';
export type UserId = Branded<string, 'model-User-field-id'>;
import { type UtcIsoString } from 'date-vir';
import type * as runtime from "@prisma/client/runtime/client";
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'>;
}
/**
* 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;
};
export {};