
/* !!! This is code generated by Prisma. Do not edit directly. !!! */
/* eslint-disable */
// biome-ignore-all lint: generated file
// @ts-nocheck 
/*
 * This file exports the `Revenue` 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"
import type * as Prisma from "../internal/prismaNamespace"

/**
 * Model Revenue
 * 
 */
export type RevenueModel = runtime.Types.Result.DefaultSelection<Prisma.$RevenuePayload>

export type AggregateRevenue = {
  _count: RevenueCountAggregateOutputType | null
  _avg: RevenueAvgAggregateOutputType | null
  _sum: RevenueSumAggregateOutputType | null
  _min: RevenueMinAggregateOutputType | null
  _max: RevenueMaxAggregateOutputType | null
}

export type RevenueAvgAggregateOutputType = {
  revenue: runtime.Decimal | null
}

export type RevenueSumAggregateOutputType = {
  revenue: runtime.Decimal | null
}

export type RevenueMinAggregateOutputType = {
  id: string | null
  websiteId: string | null
  sessionId: string | null
  eventId: string | null
  eventName: string | null
  currency: string | null
  revenue: runtime.Decimal | null
  createdAt: Date | null
}

export type RevenueMaxAggregateOutputType = {
  id: string | null
  websiteId: string | null
  sessionId: string | null
  eventId: string | null
  eventName: string | null
  currency: string | null
  revenue: runtime.Decimal | null
  createdAt: Date | null
}

export type RevenueCountAggregateOutputType = {
  id: number
  websiteId: number
  sessionId: number
  eventId: number
  eventName: number
  currency: number
  revenue: number
  createdAt: number
  _all: number
}


export type RevenueAvgAggregateInputType = {
  revenue?: true
}

export type RevenueSumAggregateInputType = {
  revenue?: true
}

export type RevenueMinAggregateInputType = {
  id?: true
  websiteId?: true
  sessionId?: true
  eventId?: true
  eventName?: true
  currency?: true
  revenue?: true
  createdAt?: true
}

export type RevenueMaxAggregateInputType = {
  id?: true
  websiteId?: true
  sessionId?: true
  eventId?: true
  eventName?: true
  currency?: true
  revenue?: true
  createdAt?: true
}

export type RevenueCountAggregateInputType = {
  id?: true
  websiteId?: true
  sessionId?: true
  eventId?: true
  eventName?: true
  currency?: true
  revenue?: true
  createdAt?: true
  _all?: true
}

export type RevenueAggregateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Filter which Revenue to aggregate.
   */
  where?: Prisma.RevenueWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of Revenues to fetch.
   */
  orderBy?: Prisma.RevenueOrderByWithRelationInput | Prisma.RevenueOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the start position
   */
  cursor?: Prisma.RevenueWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` Revenues from the position of the cursor.
   */
  take?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Skip the first `n` Revenues.
   */
  skip?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Count returned Revenues
  **/
  _count?: true | RevenueCountAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to average
  **/
  _avg?: RevenueAvgAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to sum
  **/
  _sum?: RevenueSumAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to find the minimum value
  **/
  _min?: RevenueMinAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to find the maximum value
  **/
  _max?: RevenueMaxAggregateInputType
}

export type GetRevenueAggregateType<T extends RevenueAggregateArgs> = {
      [P in keyof T & keyof AggregateRevenue]: P extends '_count' | 'count'
    ? T[P] extends true
      ? number
      : Prisma.GetScalarType<T[P], AggregateRevenue[P]>
    : Prisma.GetScalarType<T[P], AggregateRevenue[P]>
}




export type RevenueGroupByArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  where?: Prisma.RevenueWhereInput
  orderBy?: Prisma.RevenueOrderByWithAggregationInput | Prisma.RevenueOrderByWithAggregationInput[]
  by: Prisma.RevenueScalarFieldEnum[] | Prisma.RevenueScalarFieldEnum
  having?: Prisma.RevenueScalarWhereWithAggregatesInput
  take?: number
  skip?: number
  _count?: RevenueCountAggregateInputType | true
  _avg?: RevenueAvgAggregateInputType
  _sum?: RevenueSumAggregateInputType
  _min?: RevenueMinAggregateInputType
  _max?: RevenueMaxAggregateInputType
}

export type RevenueGroupByOutputType = {
  id: string
  websiteId: string
  sessionId: string
  eventId: string
  eventName: string
  currency: string
  revenue: runtime.Decimal | null
  createdAt: Date | null
  _count: RevenueCountAggregateOutputType | null
  _avg: RevenueAvgAggregateOutputType | null
  _sum: RevenueSumAggregateOutputType | null
  _min: RevenueMinAggregateOutputType | null
  _max: RevenueMaxAggregateOutputType | null
}

export type GetRevenueGroupByPayload<T extends RevenueGroupByArgs> = Prisma.PrismaPromise<
  Array<
    Prisma.PickEnumerable<RevenueGroupByOutputType, T['by']> &
      {
        [P in ((keyof T) & (keyof RevenueGroupByOutputType))]: P extends '_count'
          ? T[P] extends boolean
            ? number
            : Prisma.GetScalarType<T[P], RevenueGroupByOutputType[P]>
          : Prisma.GetScalarType<T[P], RevenueGroupByOutputType[P]>
      }
    >
  >



export type RevenueWhereInput = {
  AND?: Prisma.RevenueWhereInput | Prisma.RevenueWhereInput[]
  OR?: Prisma.RevenueWhereInput[]
  NOT?: Prisma.RevenueWhereInput | Prisma.RevenueWhereInput[]
  id?: Prisma.UuidFilter<"Revenue"> | string
  websiteId?: Prisma.UuidFilter<"Revenue"> | string
  sessionId?: Prisma.UuidFilter<"Revenue"> | string
  eventId?: Prisma.UuidFilter<"Revenue"> | string
  eventName?: Prisma.StringFilter<"Revenue"> | string
  currency?: Prisma.StringFilter<"Revenue"> | string
  revenue?: Prisma.DecimalNullableFilter<"Revenue"> | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.DateTimeNullableFilter<"Revenue"> | Date | string | null
  website?: Prisma.XOR<Prisma.WebsiteScalarRelationFilter, Prisma.WebsiteWhereInput>
  session?: Prisma.XOR<Prisma.SessionScalarRelationFilter, Prisma.SessionWhereInput>
}

export type RevenueOrderByWithRelationInput = {
  id?: Prisma.SortOrder
  websiteId?: Prisma.SortOrder
  sessionId?: Prisma.SortOrder
  eventId?: Prisma.SortOrder
  eventName?: Prisma.SortOrder
  currency?: Prisma.SortOrder
  revenue?: Prisma.SortOrderInput | Prisma.SortOrder
  createdAt?: Prisma.SortOrderInput | Prisma.SortOrder
  website?: Prisma.WebsiteOrderByWithRelationInput
  session?: Prisma.SessionOrderByWithRelationInput
}

export type RevenueWhereUniqueInput = Prisma.AtLeast<{
  id?: string
  AND?: Prisma.RevenueWhereInput | Prisma.RevenueWhereInput[]
  OR?: Prisma.RevenueWhereInput[]
  NOT?: Prisma.RevenueWhereInput | Prisma.RevenueWhereInput[]
  websiteId?: Prisma.UuidFilter<"Revenue"> | string
  sessionId?: Prisma.UuidFilter<"Revenue"> | string
  eventId?: Prisma.UuidFilter<"Revenue"> | string
  eventName?: Prisma.StringFilter<"Revenue"> | string
  currency?: Prisma.StringFilter<"Revenue"> | string
  revenue?: Prisma.DecimalNullableFilter<"Revenue"> | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.DateTimeNullableFilter<"Revenue"> | Date | string | null
  website?: Prisma.XOR<Prisma.WebsiteScalarRelationFilter, Prisma.WebsiteWhereInput>
  session?: Prisma.XOR<Prisma.SessionScalarRelationFilter, Prisma.SessionWhereInput>
}, "id">

export type RevenueOrderByWithAggregationInput = {
  id?: Prisma.SortOrder
  websiteId?: Prisma.SortOrder
  sessionId?: Prisma.SortOrder
  eventId?: Prisma.SortOrder
  eventName?: Prisma.SortOrder
  currency?: Prisma.SortOrder
  revenue?: Prisma.SortOrderInput | Prisma.SortOrder
  createdAt?: Prisma.SortOrderInput | Prisma.SortOrder
  _count?: Prisma.RevenueCountOrderByAggregateInput
  _avg?: Prisma.RevenueAvgOrderByAggregateInput
  _max?: Prisma.RevenueMaxOrderByAggregateInput
  _min?: Prisma.RevenueMinOrderByAggregateInput
  _sum?: Prisma.RevenueSumOrderByAggregateInput
}

export type RevenueScalarWhereWithAggregatesInput = {
  AND?: Prisma.RevenueScalarWhereWithAggregatesInput | Prisma.RevenueScalarWhereWithAggregatesInput[]
  OR?: Prisma.RevenueScalarWhereWithAggregatesInput[]
  NOT?: Prisma.RevenueScalarWhereWithAggregatesInput | Prisma.RevenueScalarWhereWithAggregatesInput[]
  id?: Prisma.UuidWithAggregatesFilter<"Revenue"> | string
  websiteId?: Prisma.UuidWithAggregatesFilter<"Revenue"> | string
  sessionId?: Prisma.UuidWithAggregatesFilter<"Revenue"> | string
  eventId?: Prisma.UuidWithAggregatesFilter<"Revenue"> | string
  eventName?: Prisma.StringWithAggregatesFilter<"Revenue"> | string
  currency?: Prisma.StringWithAggregatesFilter<"Revenue"> | string
  revenue?: Prisma.DecimalNullableWithAggregatesFilter<"Revenue"> | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.DateTimeNullableWithAggregatesFilter<"Revenue"> | Date | string | null
}

export type RevenueCreateInput = {
  id: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
  website: Prisma.WebsiteCreateNestedOneWithoutRevenueInput
  session: Prisma.SessionCreateNestedOneWithoutRevenueInput
}

export type RevenueUncheckedCreateInput = {
  id: string
  websiteId: string
  sessionId: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
}

export type RevenueUpdateInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
  website?: Prisma.WebsiteUpdateOneRequiredWithoutRevenueNestedInput
  session?: Prisma.SessionUpdateOneRequiredWithoutRevenueNestedInput
}

export type RevenueUncheckedUpdateInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  websiteId?: Prisma.StringFieldUpdateOperationsInput | string
  sessionId?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
}

export type RevenueCreateManyInput = {
  id: string
  websiteId: string
  sessionId: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
}

export type RevenueUpdateManyMutationInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
}

export type RevenueUncheckedUpdateManyInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  websiteId?: Prisma.StringFieldUpdateOperationsInput | string
  sessionId?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
}

export type RevenueListRelationFilter = {
  every?: Prisma.RevenueWhereInput
  some?: Prisma.RevenueWhereInput
  none?: Prisma.RevenueWhereInput
}

export type RevenueOrderByRelationAggregateInput = {
  _count?: Prisma.SortOrder
}

export type RevenueCountOrderByAggregateInput = {
  id?: Prisma.SortOrder
  websiteId?: Prisma.SortOrder
  sessionId?: Prisma.SortOrder
  eventId?: Prisma.SortOrder
  eventName?: Prisma.SortOrder
  currency?: Prisma.SortOrder
  revenue?: Prisma.SortOrder
  createdAt?: Prisma.SortOrder
}

export type RevenueAvgOrderByAggregateInput = {
  revenue?: Prisma.SortOrder
}

export type RevenueMaxOrderByAggregateInput = {
  id?: Prisma.SortOrder
  websiteId?: Prisma.SortOrder
  sessionId?: Prisma.SortOrder
  eventId?: Prisma.SortOrder
  eventName?: Prisma.SortOrder
  currency?: Prisma.SortOrder
  revenue?: Prisma.SortOrder
  createdAt?: Prisma.SortOrder
}

export type RevenueMinOrderByAggregateInput = {
  id?: Prisma.SortOrder
  websiteId?: Prisma.SortOrder
  sessionId?: Prisma.SortOrder
  eventId?: Prisma.SortOrder
  eventName?: Prisma.SortOrder
  currency?: Prisma.SortOrder
  revenue?: Prisma.SortOrder
  createdAt?: Prisma.SortOrder
}

export type RevenueSumOrderByAggregateInput = {
  revenue?: Prisma.SortOrder
}

export type RevenueCreateNestedManyWithoutSessionInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutSessionInput, Prisma.RevenueUncheckedCreateWithoutSessionInput> | Prisma.RevenueCreateWithoutSessionInput[] | Prisma.RevenueUncheckedCreateWithoutSessionInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutSessionInput | Prisma.RevenueCreateOrConnectWithoutSessionInput[]
  createMany?: Prisma.RevenueCreateManySessionInputEnvelope
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
}

export type RevenueUncheckedCreateNestedManyWithoutSessionInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutSessionInput, Prisma.RevenueUncheckedCreateWithoutSessionInput> | Prisma.RevenueCreateWithoutSessionInput[] | Prisma.RevenueUncheckedCreateWithoutSessionInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutSessionInput | Prisma.RevenueCreateOrConnectWithoutSessionInput[]
  createMany?: Prisma.RevenueCreateManySessionInputEnvelope
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
}

export type RevenueUpdateManyWithoutSessionNestedInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutSessionInput, Prisma.RevenueUncheckedCreateWithoutSessionInput> | Prisma.RevenueCreateWithoutSessionInput[] | Prisma.RevenueUncheckedCreateWithoutSessionInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutSessionInput | Prisma.RevenueCreateOrConnectWithoutSessionInput[]
  upsert?: Prisma.RevenueUpsertWithWhereUniqueWithoutSessionInput | Prisma.RevenueUpsertWithWhereUniqueWithoutSessionInput[]
  createMany?: Prisma.RevenueCreateManySessionInputEnvelope
  set?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  disconnect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  delete?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  update?: Prisma.RevenueUpdateWithWhereUniqueWithoutSessionInput | Prisma.RevenueUpdateWithWhereUniqueWithoutSessionInput[]
  updateMany?: Prisma.RevenueUpdateManyWithWhereWithoutSessionInput | Prisma.RevenueUpdateManyWithWhereWithoutSessionInput[]
  deleteMany?: Prisma.RevenueScalarWhereInput | Prisma.RevenueScalarWhereInput[]
}

export type RevenueUncheckedUpdateManyWithoutSessionNestedInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutSessionInput, Prisma.RevenueUncheckedCreateWithoutSessionInput> | Prisma.RevenueCreateWithoutSessionInput[] | Prisma.RevenueUncheckedCreateWithoutSessionInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutSessionInput | Prisma.RevenueCreateOrConnectWithoutSessionInput[]
  upsert?: Prisma.RevenueUpsertWithWhereUniqueWithoutSessionInput | Prisma.RevenueUpsertWithWhereUniqueWithoutSessionInput[]
  createMany?: Prisma.RevenueCreateManySessionInputEnvelope
  set?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  disconnect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  delete?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  update?: Prisma.RevenueUpdateWithWhereUniqueWithoutSessionInput | Prisma.RevenueUpdateWithWhereUniqueWithoutSessionInput[]
  updateMany?: Prisma.RevenueUpdateManyWithWhereWithoutSessionInput | Prisma.RevenueUpdateManyWithWhereWithoutSessionInput[]
  deleteMany?: Prisma.RevenueScalarWhereInput | Prisma.RevenueScalarWhereInput[]
}

export type RevenueCreateNestedManyWithoutWebsiteInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutWebsiteInput, Prisma.RevenueUncheckedCreateWithoutWebsiteInput> | Prisma.RevenueCreateWithoutWebsiteInput[] | Prisma.RevenueUncheckedCreateWithoutWebsiteInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutWebsiteInput | Prisma.RevenueCreateOrConnectWithoutWebsiteInput[]
  createMany?: Prisma.RevenueCreateManyWebsiteInputEnvelope
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
}

export type RevenueUncheckedCreateNestedManyWithoutWebsiteInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutWebsiteInput, Prisma.RevenueUncheckedCreateWithoutWebsiteInput> | Prisma.RevenueCreateWithoutWebsiteInput[] | Prisma.RevenueUncheckedCreateWithoutWebsiteInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutWebsiteInput | Prisma.RevenueCreateOrConnectWithoutWebsiteInput[]
  createMany?: Prisma.RevenueCreateManyWebsiteInputEnvelope
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
}

export type RevenueUpdateManyWithoutWebsiteNestedInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutWebsiteInput, Prisma.RevenueUncheckedCreateWithoutWebsiteInput> | Prisma.RevenueCreateWithoutWebsiteInput[] | Prisma.RevenueUncheckedCreateWithoutWebsiteInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutWebsiteInput | Prisma.RevenueCreateOrConnectWithoutWebsiteInput[]
  upsert?: Prisma.RevenueUpsertWithWhereUniqueWithoutWebsiteInput | Prisma.RevenueUpsertWithWhereUniqueWithoutWebsiteInput[]
  createMany?: Prisma.RevenueCreateManyWebsiteInputEnvelope
  set?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  disconnect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  delete?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  update?: Prisma.RevenueUpdateWithWhereUniqueWithoutWebsiteInput | Prisma.RevenueUpdateWithWhereUniqueWithoutWebsiteInput[]
  updateMany?: Prisma.RevenueUpdateManyWithWhereWithoutWebsiteInput | Prisma.RevenueUpdateManyWithWhereWithoutWebsiteInput[]
  deleteMany?: Prisma.RevenueScalarWhereInput | Prisma.RevenueScalarWhereInput[]
}

export type RevenueUncheckedUpdateManyWithoutWebsiteNestedInput = {
  create?: Prisma.XOR<Prisma.RevenueCreateWithoutWebsiteInput, Prisma.RevenueUncheckedCreateWithoutWebsiteInput> | Prisma.RevenueCreateWithoutWebsiteInput[] | Prisma.RevenueUncheckedCreateWithoutWebsiteInput[]
  connectOrCreate?: Prisma.RevenueCreateOrConnectWithoutWebsiteInput | Prisma.RevenueCreateOrConnectWithoutWebsiteInput[]
  upsert?: Prisma.RevenueUpsertWithWhereUniqueWithoutWebsiteInput | Prisma.RevenueUpsertWithWhereUniqueWithoutWebsiteInput[]
  createMany?: Prisma.RevenueCreateManyWebsiteInputEnvelope
  set?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  disconnect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  delete?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  connect?: Prisma.RevenueWhereUniqueInput | Prisma.RevenueWhereUniqueInput[]
  update?: Prisma.RevenueUpdateWithWhereUniqueWithoutWebsiteInput | Prisma.RevenueUpdateWithWhereUniqueWithoutWebsiteInput[]
  updateMany?: Prisma.RevenueUpdateManyWithWhereWithoutWebsiteInput | Prisma.RevenueUpdateManyWithWhereWithoutWebsiteInput[]
  deleteMany?: Prisma.RevenueScalarWhereInput | Prisma.RevenueScalarWhereInput[]
}

export type RevenueCreateWithoutSessionInput = {
  id: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
  website: Prisma.WebsiteCreateNestedOneWithoutRevenueInput
}

export type RevenueUncheckedCreateWithoutSessionInput = {
  id: string
  websiteId: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
}

export type RevenueCreateOrConnectWithoutSessionInput = {
  where: Prisma.RevenueWhereUniqueInput
  create: Prisma.XOR<Prisma.RevenueCreateWithoutSessionInput, Prisma.RevenueUncheckedCreateWithoutSessionInput>
}

export type RevenueCreateManySessionInputEnvelope = {
  data: Prisma.RevenueCreateManySessionInput | Prisma.RevenueCreateManySessionInput[]
  skipDuplicates?: boolean
}

export type RevenueUpsertWithWhereUniqueWithoutSessionInput = {
  where: Prisma.RevenueWhereUniqueInput
  update: Prisma.XOR<Prisma.RevenueUpdateWithoutSessionInput, Prisma.RevenueUncheckedUpdateWithoutSessionInput>
  create: Prisma.XOR<Prisma.RevenueCreateWithoutSessionInput, Prisma.RevenueUncheckedCreateWithoutSessionInput>
}

export type RevenueUpdateWithWhereUniqueWithoutSessionInput = {
  where: Prisma.RevenueWhereUniqueInput
  data: Prisma.XOR<Prisma.RevenueUpdateWithoutSessionInput, Prisma.RevenueUncheckedUpdateWithoutSessionInput>
}

export type RevenueUpdateManyWithWhereWithoutSessionInput = {
  where: Prisma.RevenueScalarWhereInput
  data: Prisma.XOR<Prisma.RevenueUpdateManyMutationInput, Prisma.RevenueUncheckedUpdateManyWithoutSessionInput>
}

export type RevenueScalarWhereInput = {
  AND?: Prisma.RevenueScalarWhereInput | Prisma.RevenueScalarWhereInput[]
  OR?: Prisma.RevenueScalarWhereInput[]
  NOT?: Prisma.RevenueScalarWhereInput | Prisma.RevenueScalarWhereInput[]
  id?: Prisma.UuidFilter<"Revenue"> | string
  websiteId?: Prisma.UuidFilter<"Revenue"> | string
  sessionId?: Prisma.UuidFilter<"Revenue"> | string
  eventId?: Prisma.UuidFilter<"Revenue"> | string
  eventName?: Prisma.StringFilter<"Revenue"> | string
  currency?: Prisma.StringFilter<"Revenue"> | string
  revenue?: Prisma.DecimalNullableFilter<"Revenue"> | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.DateTimeNullableFilter<"Revenue"> | Date | string | null
}

export type RevenueCreateWithoutWebsiteInput = {
  id: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
  session: Prisma.SessionCreateNestedOneWithoutRevenueInput
}

export type RevenueUncheckedCreateWithoutWebsiteInput = {
  id: string
  sessionId: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
}

export type RevenueCreateOrConnectWithoutWebsiteInput = {
  where: Prisma.RevenueWhereUniqueInput
  create: Prisma.XOR<Prisma.RevenueCreateWithoutWebsiteInput, Prisma.RevenueUncheckedCreateWithoutWebsiteInput>
}

export type RevenueCreateManyWebsiteInputEnvelope = {
  data: Prisma.RevenueCreateManyWebsiteInput | Prisma.RevenueCreateManyWebsiteInput[]
  skipDuplicates?: boolean
}

export type RevenueUpsertWithWhereUniqueWithoutWebsiteInput = {
  where: Prisma.RevenueWhereUniqueInput
  update: Prisma.XOR<Prisma.RevenueUpdateWithoutWebsiteInput, Prisma.RevenueUncheckedUpdateWithoutWebsiteInput>
  create: Prisma.XOR<Prisma.RevenueCreateWithoutWebsiteInput, Prisma.RevenueUncheckedCreateWithoutWebsiteInput>
}

export type RevenueUpdateWithWhereUniqueWithoutWebsiteInput = {
  where: Prisma.RevenueWhereUniqueInput
  data: Prisma.XOR<Prisma.RevenueUpdateWithoutWebsiteInput, Prisma.RevenueUncheckedUpdateWithoutWebsiteInput>
}

export type RevenueUpdateManyWithWhereWithoutWebsiteInput = {
  where: Prisma.RevenueScalarWhereInput
  data: Prisma.XOR<Prisma.RevenueUpdateManyMutationInput, Prisma.RevenueUncheckedUpdateManyWithoutWebsiteInput>
}

export type RevenueCreateManySessionInput = {
  id: string
  websiteId: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
}

export type RevenueUpdateWithoutSessionInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
  website?: Prisma.WebsiteUpdateOneRequiredWithoutRevenueNestedInput
}

export type RevenueUncheckedUpdateWithoutSessionInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  websiteId?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
}

export type RevenueUncheckedUpdateManyWithoutSessionInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  websiteId?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
}

export type RevenueCreateManyWebsiteInput = {
  id: string
  sessionId: string
  eventId: string
  eventName: string
  currency: string
  revenue?: runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Date | string | null
}

export type RevenueUpdateWithoutWebsiteInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
  session?: Prisma.SessionUpdateOneRequiredWithoutRevenueNestedInput
}

export type RevenueUncheckedUpdateWithoutWebsiteInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  sessionId?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
}

export type RevenueUncheckedUpdateManyWithoutWebsiteInput = {
  id?: Prisma.StringFieldUpdateOperationsInput | string
  sessionId?: Prisma.StringFieldUpdateOperationsInput | string
  eventId?: Prisma.StringFieldUpdateOperationsInput | string
  eventName?: Prisma.StringFieldUpdateOperationsInput | string
  currency?: Prisma.StringFieldUpdateOperationsInput | string
  revenue?: Prisma.NullableDecimalFieldUpdateOperationsInput | runtime.Decimal | runtime.DecimalJsLike | number | string | null
  createdAt?: Prisma.NullableDateTimeFieldUpdateOperationsInput | Date | string | null
}



export type RevenueSelect<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{
  id?: boolean
  websiteId?: boolean
  sessionId?: boolean
  eventId?: boolean
  eventName?: boolean
  currency?: boolean
  revenue?: boolean
  createdAt?: boolean
  website?: boolean | Prisma.WebsiteDefaultArgs<ExtArgs>
  session?: boolean | Prisma.SessionDefaultArgs<ExtArgs>
}, ExtArgs["result"]["revenue"]>

export type RevenueSelectCreateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{
  id?: boolean
  websiteId?: boolean
  sessionId?: boolean
  eventId?: boolean
  eventName?: boolean
  currency?: boolean
  revenue?: boolean
  createdAt?: boolean
  website?: boolean | Prisma.WebsiteDefaultArgs<ExtArgs>
  session?: boolean | Prisma.SessionDefaultArgs<ExtArgs>
}, ExtArgs["result"]["revenue"]>

export type RevenueSelectUpdateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{
  id?: boolean
  websiteId?: boolean
  sessionId?: boolean
  eventId?: boolean
  eventName?: boolean
  currency?: boolean
  revenue?: boolean
  createdAt?: boolean
  website?: boolean | Prisma.WebsiteDefaultArgs<ExtArgs>
  session?: boolean | Prisma.SessionDefaultArgs<ExtArgs>
}, ExtArgs["result"]["revenue"]>

export type RevenueSelectScalar = {
  id?: boolean
  websiteId?: boolean
  sessionId?: boolean
  eventId?: boolean
  eventName?: boolean
  currency?: boolean
  revenue?: boolean
  createdAt?: boolean
}

export type RevenueOmit<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetOmit<"id" | "websiteId" | "sessionId" | "eventId" | "eventName" | "currency" | "revenue" | "createdAt", ExtArgs["result"]["revenue"]>
export type RevenueInclude<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  website?: boolean | Prisma.WebsiteDefaultArgs<ExtArgs>
  session?: boolean | Prisma.SessionDefaultArgs<ExtArgs>
}
export type RevenueIncludeCreateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  website?: boolean | Prisma.WebsiteDefaultArgs<ExtArgs>
  session?: boolean | Prisma.SessionDefaultArgs<ExtArgs>
}
export type RevenueIncludeUpdateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  website?: boolean | Prisma.WebsiteDefaultArgs<ExtArgs>
  session?: boolean | Prisma.SessionDefaultArgs<ExtArgs>
}

export type $RevenuePayload<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  name: "Revenue"
  objects: {
    website: Prisma.$WebsitePayload<ExtArgs>
    session: Prisma.$SessionPayload<ExtArgs>
  }
  scalars: runtime.Types.Extensions.GetPayloadResult<{
    id: string
    websiteId: string
    sessionId: string
    eventId: string
    eventName: string
    currency: string
    revenue: runtime.Decimal | null
    createdAt: Date | null
  }, ExtArgs["result"]["revenue"]>
  composites: {}
}

export type RevenueGetPayload<S extends boolean | null | undefined | RevenueDefaultArgs> = runtime.Types.Result.GetResult<Prisma.$RevenuePayload, S>

export type RevenueCountArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> =
  Omit<RevenueFindManyArgs, 'select' | 'include' | 'distinct' | 'omit'> & {
    select?: RevenueCountAggregateInputType | true
  }

export interface RevenueDelegate<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs, GlobalOmitOptions = {}> {
  [K: symbol]: { types: Prisma.TypeMap<ExtArgs>['model']['Revenue'], meta: { name: 'Revenue' } }
  /**
   * Find zero or one Revenue that matches the filter.
   * @param {RevenueFindUniqueArgs} args - Arguments to find a Revenue
   * @example
   * // Get one Revenue
   * const revenue = await prisma.revenue.findUnique({
   *   where: {
   *     // ... provide filter here
   *   }
   * })
   */
  findUnique<T extends RevenueFindUniqueArgs>(args: Prisma.SelectSubset<T, RevenueFindUniqueArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "findUnique", GlobalOmitOptions> | null, null, ExtArgs, GlobalOmitOptions>

  /**
   * Find one Revenue that matches the filter or throw an error with `error.code='P2025'`
   * if no matches were found.
   * @param {RevenueFindUniqueOrThrowArgs} args - Arguments to find a Revenue
   * @example
   * // Get one Revenue
   * const revenue = await prisma.revenue.findUniqueOrThrow({
   *   where: {
   *     // ... provide filter here
   *   }
   * })
   */
  findUniqueOrThrow<T extends RevenueFindUniqueOrThrowArgs>(args: Prisma.SelectSubset<T, RevenueFindUniqueOrThrowArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "findUniqueOrThrow", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions>

  /**
   * Find the first Revenue 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 {RevenueFindFirstArgs} args - Arguments to find a Revenue
   * @example
   * // Get one Revenue
   * const revenue = await prisma.revenue.findFirst({
   *   where: {
   *     // ... provide filter here
   *   }
   * })
   */
  findFirst<T extends RevenueFindFirstArgs>(args?: Prisma.SelectSubset<T, RevenueFindFirstArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "findFirst", GlobalOmitOptions> | null, null, ExtArgs, GlobalOmitOptions>

  /**
   * Find the first Revenue 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 {RevenueFindFirstOrThrowArgs} args - Arguments to find a Revenue
   * @example
   * // Get one Revenue
   * const revenue = await prisma.revenue.findFirstOrThrow({
   *   where: {
   *     // ... provide filter here
   *   }
   * })
   */
  findFirstOrThrow<T extends RevenueFindFirstOrThrowArgs>(args?: Prisma.SelectSubset<T, RevenueFindFirstOrThrowArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "findFirstOrThrow", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions>

  /**
   * Find zero or more Revenues 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 {RevenueFindManyArgs} args - Arguments to filter and select certain fields only.
   * @example
   * // Get all Revenues
   * const revenues = await prisma.revenue.findMany()
   * 
   * // Get first 10 Revenues
   * const revenues = await prisma.revenue.findMany({ take: 10 })
   * 
   * // Only select the `id`
   * const revenueWithIdOnly = await prisma.revenue.findMany({ select: { id: true } })
   * 
   */
  findMany<T extends RevenueFindManyArgs>(args?: Prisma.SelectSubset<T, RevenueFindManyArgs<ExtArgs>>): Prisma.PrismaPromise<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "findMany", GlobalOmitOptions>>

  /**
   * Create a Revenue.
   * @param {RevenueCreateArgs} args - Arguments to create a Revenue.
   * @example
   * // Create one Revenue
   * const Revenue = await prisma.revenue.create({
   *   data: {
   *     // ... data to create a Revenue
   *   }
   * })
   * 
   */
  create<T extends RevenueCreateArgs>(args: Prisma.SelectSubset<T, RevenueCreateArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "create", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions>

  /**
   * Create many Revenues.
   * @param {RevenueCreateManyArgs} args - Arguments to create many Revenues.
   * @example
   * // Create many Revenues
   * const revenue = await prisma.revenue.createMany({
   *   data: [
   *     // ... provide data here
   *   ]
   * })
   *     
   */
  createMany<T extends RevenueCreateManyArgs>(args?: Prisma.SelectSubset<T, RevenueCreateManyArgs<ExtArgs>>): Prisma.PrismaPromise<Prisma.BatchPayload>

  /**
   * Create many Revenues and returns the data saved in the database.
   * @param {RevenueCreateManyAndReturnArgs} args - Arguments to create many Revenues.
   * @example
   * // Create many Revenues
   * const revenue = await prisma.revenue.createManyAndReturn({
   *   data: [
   *     // ... provide data here
   *   ]
   * })
   * 
   * // Create many Revenues and only return the `id`
   * const revenueWithIdOnly = await prisma.revenue.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 RevenueCreateManyAndReturnArgs>(args?: Prisma.SelectSubset<T, RevenueCreateManyAndReturnArgs<ExtArgs>>): Prisma.PrismaPromise<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "createManyAndReturn", GlobalOmitOptions>>

  /**
   * Delete a Revenue.
   * @param {RevenueDeleteArgs} args - Arguments to delete one Revenue.
   * @example
   * // Delete one Revenue
   * const Revenue = await prisma.revenue.delete({
   *   where: {
   *     // ... filter to delete one Revenue
   *   }
   * })
   * 
   */
  delete<T extends RevenueDeleteArgs>(args: Prisma.SelectSubset<T, RevenueDeleteArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "delete", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions>

  /**
   * Update one Revenue.
   * @param {RevenueUpdateArgs} args - Arguments to update one Revenue.
   * @example
   * // Update one Revenue
   * const revenue = await prisma.revenue.update({
   *   where: {
   *     // ... provide filter here
   *   },
   *   data: {
   *     // ... provide data here
   *   }
   * })
   * 
   */
  update<T extends RevenueUpdateArgs>(args: Prisma.SelectSubset<T, RevenueUpdateArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "update", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions>

  /**
   * Delete zero or more Revenues.
   * @param {RevenueDeleteManyArgs} args - Arguments to filter Revenues to delete.
   * @example
   * // Delete a few Revenues
   * const { count } = await prisma.revenue.deleteMany({
   *   where: {
   *     // ... provide filter here
   *   }
   * })
   * 
   */
  deleteMany<T extends RevenueDeleteManyArgs>(args?: Prisma.SelectSubset<T, RevenueDeleteManyArgs<ExtArgs>>): Prisma.PrismaPromise<Prisma.BatchPayload>

  /**
   * Update zero or more Revenues.
   * Note, that providing `undefined` is treated as the value not being there.
   * Read more here: https://pris.ly/d/null-undefined
   * @param {RevenueUpdateManyArgs} args - Arguments to update one or more rows.
   * @example
   * // Update many Revenues
   * const revenue = await prisma.revenue.updateMany({
   *   where: {
   *     // ... provide filter here
   *   },
   *   data: {
   *     // ... provide data here
   *   }
   * })
   * 
   */
  updateMany<T extends RevenueUpdateManyArgs>(args: Prisma.SelectSubset<T, RevenueUpdateManyArgs<ExtArgs>>): Prisma.PrismaPromise<Prisma.BatchPayload>

  /**
   * Update zero or more Revenues and returns the data updated in the database.
   * @param {RevenueUpdateManyAndReturnArgs} args - Arguments to update many Revenues.
   * @example
   * // Update many Revenues
   * const revenue = await prisma.revenue.updateManyAndReturn({
   *   where: {
   *     // ... provide filter here
   *   },
   *   data: [
   *     // ... provide data here
   *   ]
   * })
   * 
   * // Update zero or more Revenues and only return the `id`
   * const revenueWithIdOnly = await prisma.revenue.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 RevenueUpdateManyAndReturnArgs>(args: Prisma.SelectSubset<T, RevenueUpdateManyAndReturnArgs<ExtArgs>>): Prisma.PrismaPromise<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "updateManyAndReturn", GlobalOmitOptions>>

  /**
   * Create or update one Revenue.
   * @param {RevenueUpsertArgs} args - Arguments to update or create a Revenue.
   * @example
   * // Update or create a Revenue
   * const revenue = await prisma.revenue.upsert({
   *   create: {
   *     // ... data to create a Revenue
   *   },
   *   update: {
   *     // ... in case it already exists, update
   *   },
   *   where: {
   *     // ... the filter for the Revenue we want to update
   *   }
   * })
   */
  upsert<T extends RevenueUpsertArgs>(args: Prisma.SelectSubset<T, RevenueUpsertArgs<ExtArgs>>): Prisma.Prisma__RevenueClient<runtime.Types.Result.GetResult<Prisma.$RevenuePayload<ExtArgs>, T, "upsert", GlobalOmitOptions>, never, ExtArgs, GlobalOmitOptions>


  /**
   * Count the number of Revenues.
   * Note, that providing `undefined` is treated as the value not being there.
   * Read more here: https://pris.ly/d/null-undefined
   * @param {RevenueCountArgs} args - Arguments to filter Revenues to count.
   * @example
   * // Count the number of Revenues
   * const count = await prisma.revenue.count({
   *   where: {
   *     // ... the filter for the Revenues we want to count
   *   }
   * })
  **/
  count<T extends RevenueCountArgs>(
    args?: Prisma.Subset<T, RevenueCountArgs>,
  ): Prisma.PrismaPromise<
    T extends runtime.Types.Utils.Record<'select', any>
      ? T['select'] extends true
        ? number
        : Prisma.GetScalarType<T['select'], RevenueCountAggregateOutputType>
      : number
  >

  /**
   * Allows you to perform aggregations operations on a Revenue.
   * Note, that providing `undefined` is treated as the value not being there.
   * Read more here: https://pris.ly/d/null-undefined
   * @param {RevenueAggregateArgs} 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 RevenueAggregateArgs>(args: Prisma.Subset<T, RevenueAggregateArgs>): Prisma.PrismaPromise<GetRevenueAggregateType<T>>

  /**
   * Group by Revenue.
   * Note, that providing `undefined` is treated as the value not being there.
   * Read more here: https://pris.ly/d/null-undefined
   * @param {RevenueGroupByArgs} 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 RevenueGroupByArgs,
    HasSelectOrTake extends Prisma.Or<
      Prisma.Extends<'skip', Prisma.Keys<T>>,
      Prisma.Extends<'take', Prisma.Keys<T>>
    >,
    OrderByArg extends Prisma.True extends HasSelectOrTake
      ? { orderBy: RevenueGroupByArgs['orderBy'] }
      : { orderBy?: RevenueGroupByArgs['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, RevenueGroupByArgs, OrderByArg> & InputErrors): {} extends InputErrors ? GetRevenueGroupByPayload<T> : Prisma.PrismaPromise<InputErrors>
/**
 * Fields of the Revenue model
 */
readonly fields: RevenueFieldRefs;
}

/**
 * The delegate class that acts as a "Promise-like" for Revenue.
 * 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__RevenueClient<T, Null = never, ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs, GlobalOmitOptions = {}> extends Prisma.PrismaPromise<T> {
  readonly [Symbol.toStringTag]: "PrismaPromise"
  website<T extends Prisma.WebsiteDefaultArgs<ExtArgs> = {}>(args?: Prisma.Subset<T, Prisma.WebsiteDefaultArgs<ExtArgs>>): Prisma.Prisma__WebsiteClient<runtime.Types.Result.GetResult<Prisma.$WebsitePayload<ExtArgs>, T, "findUniqueOrThrow", GlobalOmitOptions> | Null, Null, ExtArgs, GlobalOmitOptions>
  session<T extends Prisma.SessionDefaultArgs<ExtArgs> = {}>(args?: Prisma.Subset<T, Prisma.SessionDefaultArgs<ExtArgs>>): Prisma.Prisma__SessionClient<runtime.Types.Result.GetResult<Prisma.$SessionPayload<ExtArgs>, T, "findUniqueOrThrow", GlobalOmitOptions> | Null, Null, ExtArgs, GlobalOmitOptions>
  /**
   * 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 Revenue model
 */
export interface RevenueFieldRefs {
  readonly id: Prisma.FieldRef<"Revenue", 'String'>
  readonly websiteId: Prisma.FieldRef<"Revenue", 'String'>
  readonly sessionId: Prisma.FieldRef<"Revenue", 'String'>
  readonly eventId: Prisma.FieldRef<"Revenue", 'String'>
  readonly eventName: Prisma.FieldRef<"Revenue", 'String'>
  readonly currency: Prisma.FieldRef<"Revenue", 'String'>
  readonly revenue: Prisma.FieldRef<"Revenue", 'Decimal'>
  readonly createdAt: Prisma.FieldRef<"Revenue", 'DateTime'>
}
    

// Custom InputTypes
/**
 * Revenue findUnique
 */
export type RevenueFindUniqueArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * Filter, which Revenue to fetch.
   */
  where: Prisma.RevenueWhereUniqueInput
}

/**
 * Revenue findUniqueOrThrow
 */
export type RevenueFindUniqueOrThrowArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * Filter, which Revenue to fetch.
   */
  where: Prisma.RevenueWhereUniqueInput
}

/**
 * Revenue findFirst
 */
export type RevenueFindFirstArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * Filter, which Revenue to fetch.
   */
  where?: Prisma.RevenueWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of Revenues to fetch.
   */
  orderBy?: Prisma.RevenueOrderByWithRelationInput | Prisma.RevenueOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the position for searching for Revenues.
   */
  cursor?: Prisma.RevenueWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` Revenues from the position of the cursor.
   */
  take?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Skip the first `n` Revenues.
   */
  skip?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/distinct Distinct Docs}
   * 
   * Filter by unique combinations of Revenues.
   */
  distinct?: Prisma.RevenueScalarFieldEnum | Prisma.RevenueScalarFieldEnum[]
}

/**
 * Revenue findFirstOrThrow
 */
export type RevenueFindFirstOrThrowArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * Filter, which Revenue to fetch.
   */
  where?: Prisma.RevenueWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of Revenues to fetch.
   */
  orderBy?: Prisma.RevenueOrderByWithRelationInput | Prisma.RevenueOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the position for searching for Revenues.
   */
  cursor?: Prisma.RevenueWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` Revenues from the position of the cursor.
   */
  take?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Skip the first `n` Revenues.
   */
  skip?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/distinct Distinct Docs}
   * 
   * Filter by unique combinations of Revenues.
   */
  distinct?: Prisma.RevenueScalarFieldEnum | Prisma.RevenueScalarFieldEnum[]
}

/**
 * Revenue findMany
 */
export type RevenueFindManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * Filter, which Revenues to fetch.
   */
  where?: Prisma.RevenueWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of Revenues to fetch.
   */
  orderBy?: Prisma.RevenueOrderByWithRelationInput | Prisma.RevenueOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the position for listing Revenues.
   */
  cursor?: Prisma.RevenueWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` Revenues from the position of the cursor.
   */
  take?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Skip the first `n` Revenues.
   */
  skip?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/distinct Distinct Docs}
   * 
   * Filter by unique combinations of Revenues.
   */
  distinct?: Prisma.RevenueScalarFieldEnum | Prisma.RevenueScalarFieldEnum[]
}

/**
 * Revenue create
 */
export type RevenueCreateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * The data needed to create a Revenue.
   */
  data: Prisma.XOR<Prisma.RevenueCreateInput, Prisma.RevenueUncheckedCreateInput>
}

/**
 * Revenue createMany
 */
export type RevenueCreateManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * The data used to create many Revenues.
   */
  data: Prisma.RevenueCreateManyInput | Prisma.RevenueCreateManyInput[]
  skipDuplicates?: boolean
}

/**
 * Revenue createManyAndReturn
 */
export type RevenueCreateManyAndReturnArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelectCreateManyAndReturn<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * The data used to create many Revenues.
   */
  data: Prisma.RevenueCreateManyInput | Prisma.RevenueCreateManyInput[]
  skipDuplicates?: boolean
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueIncludeCreateManyAndReturn<ExtArgs> | null
}

/**
 * Revenue update
 */
export type RevenueUpdateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * The data needed to update a Revenue.
   */
  data: Prisma.XOR<Prisma.RevenueUpdateInput, Prisma.RevenueUncheckedUpdateInput>
  /**
   * Choose, which Revenue to update.
   */
  where: Prisma.RevenueWhereUniqueInput
}

/**
 * Revenue updateMany
 */
export type RevenueUpdateManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * The data used to update Revenues.
   */
  data: Prisma.XOR<Prisma.RevenueUpdateManyMutationInput, Prisma.RevenueUncheckedUpdateManyInput>
  /**
   * Filter which Revenues to update
   */
  where?: Prisma.RevenueWhereInput
  /**
   * Limit how many Revenues to update.
   */
  limit?: number
}

/**
 * Revenue updateManyAndReturn
 */
export type RevenueUpdateManyAndReturnArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelectUpdateManyAndReturn<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * The data used to update Revenues.
   */
  data: Prisma.XOR<Prisma.RevenueUpdateManyMutationInput, Prisma.RevenueUncheckedUpdateManyInput>
  /**
   * Filter which Revenues to update
   */
  where?: Prisma.RevenueWhereInput
  /**
   * Limit how many Revenues to update.
   */
  limit?: number
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueIncludeUpdateManyAndReturn<ExtArgs> | null
}

/**
 * Revenue upsert
 */
export type RevenueUpsertArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * The filter to search for the Revenue to update in case it exists.
   */
  where: Prisma.RevenueWhereUniqueInput
  /**
   * In case the Revenue found by the `where` argument doesn't exist, create a new Revenue with this data.
   */
  create: Prisma.XOR<Prisma.RevenueCreateInput, Prisma.RevenueUncheckedCreateInput>
  /**
   * In case the Revenue was found with the provided `where` argument, update it with this data.
   */
  update: Prisma.XOR<Prisma.RevenueUpdateInput, Prisma.RevenueUncheckedUpdateInput>
}

/**
 * Revenue delete
 */
export type RevenueDeleteArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
  /**
   * Filter which Revenue to delete.
   */
  where: Prisma.RevenueWhereUniqueInput
}

/**
 * Revenue deleteMany
 */
export type RevenueDeleteManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Filter which Revenues to delete
   */
  where?: Prisma.RevenueWhereInput
  /**
   * Limit how many Revenues to delete.
   */
  limit?: number
}

/**
 * Revenue without action
 */
export type RevenueDefaultArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the Revenue
   */
  select?: Prisma.RevenueSelect<ExtArgs> | null
  /**
   * Omit specific fields from the Revenue
   */
  omit?: Prisma.RevenueOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.RevenueInclude<ExtArgs> | null
}
