
/* !!! This is code generated by Prisma. Do not edit directly. !!! */
/* eslint-disable */
// biome-ignore-all lint: generated file
// @ts-nocheck 
/*
 * This file exports the `MonitorRule` model and its related types.
 *
 * 🟢 You can import this file directly.
 */
import type * as runtime from "@prisma/client/runtime/library"
import type * as $Enums from "../enums"
import type * as Prisma from "../internal/prismaNamespace"

/**
 * Model MonitorRule
 * 
 */
export type MonitorRuleModel = runtime.Types.Result.DefaultSelection<Prisma.$MonitorRulePayload>

export type AggregateMonitorRule = {
  _count: MonitorRuleCountAggregateOutputType | null
  _avg: MonitorRuleAvgAggregateOutputType | null
  _sum: MonitorRuleSumAggregateOutputType | null
  _min: MonitorRuleMinAggregateOutputType | null
  _max: MonitorRuleMaxAggregateOutputType | null
}

export type MonitorRuleAvgAggregateOutputType = {
  id: number | null
  itemId: number | null
  offsetDays: number | null
  offsetHours: number | null
  repeatInterval: number | null
  maxTimes: number | null
  createdBy: number | null
  updatedBy: number | null
}

export type MonitorRuleSumAggregateOutputType = {
  id: number | null
  itemId: number | null
  offsetDays: number | null
  offsetHours: number | null
  repeatInterval: number | null
  maxTimes: number | null
  createdBy: number | null
  updatedBy: number | null
}

export type MonitorRuleMinAggregateOutputType = {
  id: number | null
  itemId: number | null
  ruleName: string | null
  triggerType: $Enums.MonitorTriggerType | null
  offsetDays: number | null
  offsetHours: number | null
  repeatType: $Enums.MonitorRepeatType | null
  repeatInterval: number | null
  remindTime: string | null
  maxTimes: number | null
  channelSms: boolean | null
  channelSystem: boolean | null
  stopWhenDone: boolean | null
  contentTpl: string | null
  isEnabled: boolean | null
  createdBy: number | null
  createdAt: Date | null
  updatedBy: number | null
  updatedAt: Date | null
}

export type MonitorRuleMaxAggregateOutputType = {
  id: number | null
  itemId: number | null
  ruleName: string | null
  triggerType: $Enums.MonitorTriggerType | null
  offsetDays: number | null
  offsetHours: number | null
  repeatType: $Enums.MonitorRepeatType | null
  repeatInterval: number | null
  remindTime: string | null
  maxTimes: number | null
  channelSms: boolean | null
  channelSystem: boolean | null
  stopWhenDone: boolean | null
  contentTpl: string | null
  isEnabled: boolean | null
  createdBy: number | null
  createdAt: Date | null
  updatedBy: number | null
  updatedAt: Date | null
}

export type MonitorRuleCountAggregateOutputType = {
  id: number
  itemId: number
  ruleName: number
  triggerType: number
  offsetDays: number
  offsetHours: number
  repeatType: number
  repeatInterval: number
  remindTime: number
  maxTimes: number
  channelSms: number
  channelSystem: number
  stopWhenDone: number
  contentTpl: number
  isEnabled: number
  createdBy: number
  createdAt: number
  updatedBy: number
  updatedAt: number
  _all: number
}


export type MonitorRuleAvgAggregateInputType = {
  id?: true
  itemId?: true
  offsetDays?: true
  offsetHours?: true
  repeatInterval?: true
  maxTimes?: true
  createdBy?: true
  updatedBy?: true
}

export type MonitorRuleSumAggregateInputType = {
  id?: true
  itemId?: true
  offsetDays?: true
  offsetHours?: true
  repeatInterval?: true
  maxTimes?: true
  createdBy?: true
  updatedBy?: true
}

export type MonitorRuleMinAggregateInputType = {
  id?: true
  itemId?: true
  ruleName?: true
  triggerType?: true
  offsetDays?: true
  offsetHours?: true
  repeatType?: true
  repeatInterval?: true
  remindTime?: true
  maxTimes?: true
  channelSms?: true
  channelSystem?: true
  stopWhenDone?: true
  contentTpl?: true
  isEnabled?: true
  createdBy?: true
  createdAt?: true
  updatedBy?: true
  updatedAt?: true
}

export type MonitorRuleMaxAggregateInputType = {
  id?: true
  itemId?: true
  ruleName?: true
  triggerType?: true
  offsetDays?: true
  offsetHours?: true
  repeatType?: true
  repeatInterval?: true
  remindTime?: true
  maxTimes?: true
  channelSms?: true
  channelSystem?: true
  stopWhenDone?: true
  contentTpl?: true
  isEnabled?: true
  createdBy?: true
  createdAt?: true
  updatedBy?: true
  updatedAt?: true
}

export type MonitorRuleCountAggregateInputType = {
  id?: true
  itemId?: true
  ruleName?: true
  triggerType?: true
  offsetDays?: true
  offsetHours?: true
  repeatType?: true
  repeatInterval?: true
  remindTime?: true
  maxTimes?: true
  channelSms?: true
  channelSystem?: true
  stopWhenDone?: true
  contentTpl?: true
  isEnabled?: true
  createdBy?: true
  createdAt?: true
  updatedBy?: true
  updatedAt?: true
  _all?: true
}

export type MonitorRuleAggregateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Filter which MonitorRule to aggregate.
   */
  where?: Prisma.MonitorRuleWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of MonitorRules to fetch.
   */
  orderBy?: Prisma.MonitorRuleOrderByWithRelationInput | Prisma.MonitorRuleOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the start position
   */
  cursor?: Prisma.MonitorRuleWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` MonitorRules 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` MonitorRules.
   */
  skip?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Count returned MonitorRules
  **/
  _count?: true | MonitorRuleCountAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to average
  **/
  _avg?: MonitorRuleAvgAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to sum
  **/
  _sum?: MonitorRuleSumAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to find the minimum value
  **/
  _min?: MonitorRuleMinAggregateInputType
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
   * 
   * Select which fields to find the maximum value
  **/
  _max?: MonitorRuleMaxAggregateInputType
}

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




export type MonitorRuleGroupByArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  where?: Prisma.MonitorRuleWhereInput
  orderBy?: Prisma.MonitorRuleOrderByWithAggregationInput | Prisma.MonitorRuleOrderByWithAggregationInput[]
  by: Prisma.MonitorRuleScalarFieldEnum[] | Prisma.MonitorRuleScalarFieldEnum
  having?: Prisma.MonitorRuleScalarWhereWithAggregatesInput
  take?: number
  skip?: number
  _count?: MonitorRuleCountAggregateInputType | true
  _avg?: MonitorRuleAvgAggregateInputType
  _sum?: MonitorRuleSumAggregateInputType
  _min?: MonitorRuleMinAggregateInputType
  _max?: MonitorRuleMaxAggregateInputType
}

export type MonitorRuleGroupByOutputType = {
  id: number
  itemId: number
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays: number
  offsetHours: number
  repeatType: $Enums.MonitorRepeatType
  repeatInterval: number | null
  remindTime: string | null
  maxTimes: number | null
  channelSms: boolean
  channelSystem: boolean
  stopWhenDone: boolean
  contentTpl: string | null
  isEnabled: boolean
  createdBy: number | null
  createdAt: Date
  updatedBy: number | null
  updatedAt: Date
  _count: MonitorRuleCountAggregateOutputType | null
  _avg: MonitorRuleAvgAggregateOutputType | null
  _sum: MonitorRuleSumAggregateOutputType | null
  _min: MonitorRuleMinAggregateOutputType | null
  _max: MonitorRuleMaxAggregateOutputType | null
}

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



export type MonitorRuleWhereInput = {
  AND?: Prisma.MonitorRuleWhereInput | Prisma.MonitorRuleWhereInput[]
  OR?: Prisma.MonitorRuleWhereInput[]
  NOT?: Prisma.MonitorRuleWhereInput | Prisma.MonitorRuleWhereInput[]
  id?: Prisma.IntFilter<"MonitorRule"> | number
  itemId?: Prisma.IntFilter<"MonitorRule"> | number
  ruleName?: Prisma.StringFilter<"MonitorRule"> | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFilter<"MonitorRule"> | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFilter<"MonitorRule"> | number
  offsetHours?: Prisma.IntFilter<"MonitorRule"> | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFilter<"MonitorRule"> | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  remindTime?: Prisma.StringNullableFilter<"MonitorRule"> | string | null
  maxTimes?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  channelSms?: Prisma.BoolFilter<"MonitorRule"> | boolean
  channelSystem?: Prisma.BoolFilter<"MonitorRule"> | boolean
  stopWhenDone?: Prisma.BoolFilter<"MonitorRule"> | boolean
  contentTpl?: Prisma.StringNullableFilter<"MonitorRule"> | string | null
  isEnabled?: Prisma.BoolFilter<"MonitorRule"> | boolean
  createdBy?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  createdAt?: Prisma.DateTimeFilter<"MonitorRule"> | Date | string
  updatedBy?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  updatedAt?: Prisma.DateTimeFilter<"MonitorRule"> | Date | string
  item?: Prisma.XOR<Prisma.MonitorItemScalarRelationFilter, Prisma.MonitorItemWhereInput>
  notifyLogs?: Prisma.MonitorNotifyLogListRelationFilter
}

export type MonitorRuleOrderByWithRelationInput = {
  id?: Prisma.SortOrder
  itemId?: Prisma.SortOrder
  ruleName?: Prisma.SortOrder
  triggerType?: Prisma.SortOrder
  offsetDays?: Prisma.SortOrder
  offsetHours?: Prisma.SortOrder
  repeatType?: Prisma.SortOrder
  repeatInterval?: Prisma.SortOrderInput | Prisma.SortOrder
  remindTime?: Prisma.SortOrderInput | Prisma.SortOrder
  maxTimes?: Prisma.SortOrderInput | Prisma.SortOrder
  channelSms?: Prisma.SortOrder
  channelSystem?: Prisma.SortOrder
  stopWhenDone?: Prisma.SortOrder
  contentTpl?: Prisma.SortOrderInput | Prisma.SortOrder
  isEnabled?: Prisma.SortOrder
  createdBy?: Prisma.SortOrderInput | Prisma.SortOrder
  createdAt?: Prisma.SortOrder
  updatedBy?: Prisma.SortOrderInput | Prisma.SortOrder
  updatedAt?: Prisma.SortOrder
  item?: Prisma.MonitorItemOrderByWithRelationInput
  notifyLogs?: Prisma.MonitorNotifyLogOrderByRelationAggregateInput
}

export type MonitorRuleWhereUniqueInput = Prisma.AtLeast<{
  id?: number
  AND?: Prisma.MonitorRuleWhereInput | Prisma.MonitorRuleWhereInput[]
  OR?: Prisma.MonitorRuleWhereInput[]
  NOT?: Prisma.MonitorRuleWhereInput | Prisma.MonitorRuleWhereInput[]
  itemId?: Prisma.IntFilter<"MonitorRule"> | number
  ruleName?: Prisma.StringFilter<"MonitorRule"> | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFilter<"MonitorRule"> | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFilter<"MonitorRule"> | number
  offsetHours?: Prisma.IntFilter<"MonitorRule"> | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFilter<"MonitorRule"> | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  remindTime?: Prisma.StringNullableFilter<"MonitorRule"> | string | null
  maxTimes?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  channelSms?: Prisma.BoolFilter<"MonitorRule"> | boolean
  channelSystem?: Prisma.BoolFilter<"MonitorRule"> | boolean
  stopWhenDone?: Prisma.BoolFilter<"MonitorRule"> | boolean
  contentTpl?: Prisma.StringNullableFilter<"MonitorRule"> | string | null
  isEnabled?: Prisma.BoolFilter<"MonitorRule"> | boolean
  createdBy?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  createdAt?: Prisma.DateTimeFilter<"MonitorRule"> | Date | string
  updatedBy?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  updatedAt?: Prisma.DateTimeFilter<"MonitorRule"> | Date | string
  item?: Prisma.XOR<Prisma.MonitorItemScalarRelationFilter, Prisma.MonitorItemWhereInput>
  notifyLogs?: Prisma.MonitorNotifyLogListRelationFilter
}, "id">

export type MonitorRuleOrderByWithAggregationInput = {
  id?: Prisma.SortOrder
  itemId?: Prisma.SortOrder
  ruleName?: Prisma.SortOrder
  triggerType?: Prisma.SortOrder
  offsetDays?: Prisma.SortOrder
  offsetHours?: Prisma.SortOrder
  repeatType?: Prisma.SortOrder
  repeatInterval?: Prisma.SortOrderInput | Prisma.SortOrder
  remindTime?: Prisma.SortOrderInput | Prisma.SortOrder
  maxTimes?: Prisma.SortOrderInput | Prisma.SortOrder
  channelSms?: Prisma.SortOrder
  channelSystem?: Prisma.SortOrder
  stopWhenDone?: Prisma.SortOrder
  contentTpl?: Prisma.SortOrderInput | Prisma.SortOrder
  isEnabled?: Prisma.SortOrder
  createdBy?: Prisma.SortOrderInput | Prisma.SortOrder
  createdAt?: Prisma.SortOrder
  updatedBy?: Prisma.SortOrderInput | Prisma.SortOrder
  updatedAt?: Prisma.SortOrder
  _count?: Prisma.MonitorRuleCountOrderByAggregateInput
  _avg?: Prisma.MonitorRuleAvgOrderByAggregateInput
  _max?: Prisma.MonitorRuleMaxOrderByAggregateInput
  _min?: Prisma.MonitorRuleMinOrderByAggregateInput
  _sum?: Prisma.MonitorRuleSumOrderByAggregateInput
}

export type MonitorRuleScalarWhereWithAggregatesInput = {
  AND?: Prisma.MonitorRuleScalarWhereWithAggregatesInput | Prisma.MonitorRuleScalarWhereWithAggregatesInput[]
  OR?: Prisma.MonitorRuleScalarWhereWithAggregatesInput[]
  NOT?: Prisma.MonitorRuleScalarWhereWithAggregatesInput | Prisma.MonitorRuleScalarWhereWithAggregatesInput[]
  id?: Prisma.IntWithAggregatesFilter<"MonitorRule"> | number
  itemId?: Prisma.IntWithAggregatesFilter<"MonitorRule"> | number
  ruleName?: Prisma.StringWithAggregatesFilter<"MonitorRule"> | string
  triggerType?: Prisma.EnumMonitorTriggerTypeWithAggregatesFilter<"MonitorRule"> | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntWithAggregatesFilter<"MonitorRule"> | number
  offsetHours?: Prisma.IntWithAggregatesFilter<"MonitorRule"> | number
  repeatType?: Prisma.EnumMonitorRepeatTypeWithAggregatesFilter<"MonitorRule"> | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.IntNullableWithAggregatesFilter<"MonitorRule"> | number | null
  remindTime?: Prisma.StringNullableWithAggregatesFilter<"MonitorRule"> | string | null
  maxTimes?: Prisma.IntNullableWithAggregatesFilter<"MonitorRule"> | number | null
  channelSms?: Prisma.BoolWithAggregatesFilter<"MonitorRule"> | boolean
  channelSystem?: Prisma.BoolWithAggregatesFilter<"MonitorRule"> | boolean
  stopWhenDone?: Prisma.BoolWithAggregatesFilter<"MonitorRule"> | boolean
  contentTpl?: Prisma.StringNullableWithAggregatesFilter<"MonitorRule"> | string | null
  isEnabled?: Prisma.BoolWithAggregatesFilter<"MonitorRule"> | boolean
  createdBy?: Prisma.IntNullableWithAggregatesFilter<"MonitorRule"> | number | null
  createdAt?: Prisma.DateTimeWithAggregatesFilter<"MonitorRule"> | Date | string
  updatedBy?: Prisma.IntNullableWithAggregatesFilter<"MonitorRule"> | number | null
  updatedAt?: Prisma.DateTimeWithAggregatesFilter<"MonitorRule"> | Date | string
}

export type MonitorRuleCreateInput = {
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
  item: Prisma.MonitorItemCreateNestedOneWithoutRulesInput
  notifyLogs?: Prisma.MonitorNotifyLogCreateNestedManyWithoutRuleInput
}

export type MonitorRuleUncheckedCreateInput = {
  id?: number
  itemId: number
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
  notifyLogs?: Prisma.MonitorNotifyLogUncheckedCreateNestedManyWithoutRuleInput
}

export type MonitorRuleUpdateInput = {
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  item?: Prisma.MonitorItemUpdateOneRequiredWithoutRulesNestedInput
  notifyLogs?: Prisma.MonitorNotifyLogUpdateManyWithoutRuleNestedInput
}

export type MonitorRuleUncheckedUpdateInput = {
  id?: Prisma.IntFieldUpdateOperationsInput | number
  itemId?: Prisma.IntFieldUpdateOperationsInput | number
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  notifyLogs?: Prisma.MonitorNotifyLogUncheckedUpdateManyWithoutRuleNestedInput
}

export type MonitorRuleCreateManyInput = {
  id?: number
  itemId: number
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
}

export type MonitorRuleUpdateManyMutationInput = {
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
}

export type MonitorRuleUncheckedUpdateManyInput = {
  id?: Prisma.IntFieldUpdateOperationsInput | number
  itemId?: Prisma.IntFieldUpdateOperationsInput | number
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
}

export type MonitorRuleListRelationFilter = {
  every?: Prisma.MonitorRuleWhereInput
  some?: Prisma.MonitorRuleWhereInput
  none?: Prisma.MonitorRuleWhereInput
}

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

export type MonitorRuleCountOrderByAggregateInput = {
  id?: Prisma.SortOrder
  itemId?: Prisma.SortOrder
  ruleName?: Prisma.SortOrder
  triggerType?: Prisma.SortOrder
  offsetDays?: Prisma.SortOrder
  offsetHours?: Prisma.SortOrder
  repeatType?: Prisma.SortOrder
  repeatInterval?: Prisma.SortOrder
  remindTime?: Prisma.SortOrder
  maxTimes?: Prisma.SortOrder
  channelSms?: Prisma.SortOrder
  channelSystem?: Prisma.SortOrder
  stopWhenDone?: Prisma.SortOrder
  contentTpl?: Prisma.SortOrder
  isEnabled?: Prisma.SortOrder
  createdBy?: Prisma.SortOrder
  createdAt?: Prisma.SortOrder
  updatedBy?: Prisma.SortOrder
  updatedAt?: Prisma.SortOrder
}

export type MonitorRuleAvgOrderByAggregateInput = {
  id?: Prisma.SortOrder
  itemId?: Prisma.SortOrder
  offsetDays?: Prisma.SortOrder
  offsetHours?: Prisma.SortOrder
  repeatInterval?: Prisma.SortOrder
  maxTimes?: Prisma.SortOrder
  createdBy?: Prisma.SortOrder
  updatedBy?: Prisma.SortOrder
}

export type MonitorRuleMaxOrderByAggregateInput = {
  id?: Prisma.SortOrder
  itemId?: Prisma.SortOrder
  ruleName?: Prisma.SortOrder
  triggerType?: Prisma.SortOrder
  offsetDays?: Prisma.SortOrder
  offsetHours?: Prisma.SortOrder
  repeatType?: Prisma.SortOrder
  repeatInterval?: Prisma.SortOrder
  remindTime?: Prisma.SortOrder
  maxTimes?: Prisma.SortOrder
  channelSms?: Prisma.SortOrder
  channelSystem?: Prisma.SortOrder
  stopWhenDone?: Prisma.SortOrder
  contentTpl?: Prisma.SortOrder
  isEnabled?: Prisma.SortOrder
  createdBy?: Prisma.SortOrder
  createdAt?: Prisma.SortOrder
  updatedBy?: Prisma.SortOrder
  updatedAt?: Prisma.SortOrder
}

export type MonitorRuleMinOrderByAggregateInput = {
  id?: Prisma.SortOrder
  itemId?: Prisma.SortOrder
  ruleName?: Prisma.SortOrder
  triggerType?: Prisma.SortOrder
  offsetDays?: Prisma.SortOrder
  offsetHours?: Prisma.SortOrder
  repeatType?: Prisma.SortOrder
  repeatInterval?: Prisma.SortOrder
  remindTime?: Prisma.SortOrder
  maxTimes?: Prisma.SortOrder
  channelSms?: Prisma.SortOrder
  channelSystem?: Prisma.SortOrder
  stopWhenDone?: Prisma.SortOrder
  contentTpl?: Prisma.SortOrder
  isEnabled?: Prisma.SortOrder
  createdBy?: Prisma.SortOrder
  createdAt?: Prisma.SortOrder
  updatedBy?: Prisma.SortOrder
  updatedAt?: Prisma.SortOrder
}

export type MonitorRuleSumOrderByAggregateInput = {
  id?: Prisma.SortOrder
  itemId?: Prisma.SortOrder
  offsetDays?: Prisma.SortOrder
  offsetHours?: Prisma.SortOrder
  repeatInterval?: Prisma.SortOrder
  maxTimes?: Prisma.SortOrder
  createdBy?: Prisma.SortOrder
  updatedBy?: Prisma.SortOrder
}

export type MonitorRuleScalarRelationFilter = {
  is?: Prisma.MonitorRuleWhereInput
  isNot?: Prisma.MonitorRuleWhereInput
}

export type MonitorRuleCreateNestedManyWithoutItemInput = {
  create?: Prisma.XOR<Prisma.MonitorRuleCreateWithoutItemInput, Prisma.MonitorRuleUncheckedCreateWithoutItemInput> | Prisma.MonitorRuleCreateWithoutItemInput[] | Prisma.MonitorRuleUncheckedCreateWithoutItemInput[]
  connectOrCreate?: Prisma.MonitorRuleCreateOrConnectWithoutItemInput | Prisma.MonitorRuleCreateOrConnectWithoutItemInput[]
  createMany?: Prisma.MonitorRuleCreateManyItemInputEnvelope
  connect?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
}

export type MonitorRuleUncheckedCreateNestedManyWithoutItemInput = {
  create?: Prisma.XOR<Prisma.MonitorRuleCreateWithoutItemInput, Prisma.MonitorRuleUncheckedCreateWithoutItemInput> | Prisma.MonitorRuleCreateWithoutItemInput[] | Prisma.MonitorRuleUncheckedCreateWithoutItemInput[]
  connectOrCreate?: Prisma.MonitorRuleCreateOrConnectWithoutItemInput | Prisma.MonitorRuleCreateOrConnectWithoutItemInput[]
  createMany?: Prisma.MonitorRuleCreateManyItemInputEnvelope
  connect?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
}

export type MonitorRuleUpdateManyWithoutItemNestedInput = {
  create?: Prisma.XOR<Prisma.MonitorRuleCreateWithoutItemInput, Prisma.MonitorRuleUncheckedCreateWithoutItemInput> | Prisma.MonitorRuleCreateWithoutItemInput[] | Prisma.MonitorRuleUncheckedCreateWithoutItemInput[]
  connectOrCreate?: Prisma.MonitorRuleCreateOrConnectWithoutItemInput | Prisma.MonitorRuleCreateOrConnectWithoutItemInput[]
  upsert?: Prisma.MonitorRuleUpsertWithWhereUniqueWithoutItemInput | Prisma.MonitorRuleUpsertWithWhereUniqueWithoutItemInput[]
  createMany?: Prisma.MonitorRuleCreateManyItemInputEnvelope
  set?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  disconnect?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  delete?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  connect?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  update?: Prisma.MonitorRuleUpdateWithWhereUniqueWithoutItemInput | Prisma.MonitorRuleUpdateWithWhereUniqueWithoutItemInput[]
  updateMany?: Prisma.MonitorRuleUpdateManyWithWhereWithoutItemInput | Prisma.MonitorRuleUpdateManyWithWhereWithoutItemInput[]
  deleteMany?: Prisma.MonitorRuleScalarWhereInput | Prisma.MonitorRuleScalarWhereInput[]
}

export type MonitorRuleUncheckedUpdateManyWithoutItemNestedInput = {
  create?: Prisma.XOR<Prisma.MonitorRuleCreateWithoutItemInput, Prisma.MonitorRuleUncheckedCreateWithoutItemInput> | Prisma.MonitorRuleCreateWithoutItemInput[] | Prisma.MonitorRuleUncheckedCreateWithoutItemInput[]
  connectOrCreate?: Prisma.MonitorRuleCreateOrConnectWithoutItemInput | Prisma.MonitorRuleCreateOrConnectWithoutItemInput[]
  upsert?: Prisma.MonitorRuleUpsertWithWhereUniqueWithoutItemInput | Prisma.MonitorRuleUpsertWithWhereUniqueWithoutItemInput[]
  createMany?: Prisma.MonitorRuleCreateManyItemInputEnvelope
  set?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  disconnect?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  delete?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  connect?: Prisma.MonitorRuleWhereUniqueInput | Prisma.MonitorRuleWhereUniqueInput[]
  update?: Prisma.MonitorRuleUpdateWithWhereUniqueWithoutItemInput | Prisma.MonitorRuleUpdateWithWhereUniqueWithoutItemInput[]
  updateMany?: Prisma.MonitorRuleUpdateManyWithWhereWithoutItemInput | Prisma.MonitorRuleUpdateManyWithWhereWithoutItemInput[]
  deleteMany?: Prisma.MonitorRuleScalarWhereInput | Prisma.MonitorRuleScalarWhereInput[]
}

export type EnumMonitorTriggerTypeFieldUpdateOperationsInput = {
  set?: $Enums.MonitorTriggerType
}

export type EnumMonitorRepeatTypeFieldUpdateOperationsInput = {
  set?: $Enums.MonitorRepeatType
}

export type MonitorRuleCreateNestedOneWithoutNotifyLogsInput = {
  create?: Prisma.XOR<Prisma.MonitorRuleCreateWithoutNotifyLogsInput, Prisma.MonitorRuleUncheckedCreateWithoutNotifyLogsInput>
  connectOrCreate?: Prisma.MonitorRuleCreateOrConnectWithoutNotifyLogsInput
  connect?: Prisma.MonitorRuleWhereUniqueInput
}

export type MonitorRuleUpdateOneRequiredWithoutNotifyLogsNestedInput = {
  create?: Prisma.XOR<Prisma.MonitorRuleCreateWithoutNotifyLogsInput, Prisma.MonitorRuleUncheckedCreateWithoutNotifyLogsInput>
  connectOrCreate?: Prisma.MonitorRuleCreateOrConnectWithoutNotifyLogsInput
  upsert?: Prisma.MonitorRuleUpsertWithoutNotifyLogsInput
  connect?: Prisma.MonitorRuleWhereUniqueInput
  update?: Prisma.XOR<Prisma.XOR<Prisma.MonitorRuleUpdateToOneWithWhereWithoutNotifyLogsInput, Prisma.MonitorRuleUpdateWithoutNotifyLogsInput>, Prisma.MonitorRuleUncheckedUpdateWithoutNotifyLogsInput>
}

export type MonitorRuleCreateWithoutItemInput = {
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
  notifyLogs?: Prisma.MonitorNotifyLogCreateNestedManyWithoutRuleInput
}

export type MonitorRuleUncheckedCreateWithoutItemInput = {
  id?: number
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
  notifyLogs?: Prisma.MonitorNotifyLogUncheckedCreateNestedManyWithoutRuleInput
}

export type MonitorRuleCreateOrConnectWithoutItemInput = {
  where: Prisma.MonitorRuleWhereUniqueInput
  create: Prisma.XOR<Prisma.MonitorRuleCreateWithoutItemInput, Prisma.MonitorRuleUncheckedCreateWithoutItemInput>
}

export type MonitorRuleCreateManyItemInputEnvelope = {
  data: Prisma.MonitorRuleCreateManyItemInput | Prisma.MonitorRuleCreateManyItemInput[]
  skipDuplicates?: boolean
}

export type MonitorRuleUpsertWithWhereUniqueWithoutItemInput = {
  where: Prisma.MonitorRuleWhereUniqueInput
  update: Prisma.XOR<Prisma.MonitorRuleUpdateWithoutItemInput, Prisma.MonitorRuleUncheckedUpdateWithoutItemInput>
  create: Prisma.XOR<Prisma.MonitorRuleCreateWithoutItemInput, Prisma.MonitorRuleUncheckedCreateWithoutItemInput>
}

export type MonitorRuleUpdateWithWhereUniqueWithoutItemInput = {
  where: Prisma.MonitorRuleWhereUniqueInput
  data: Prisma.XOR<Prisma.MonitorRuleUpdateWithoutItemInput, Prisma.MonitorRuleUncheckedUpdateWithoutItemInput>
}

export type MonitorRuleUpdateManyWithWhereWithoutItemInput = {
  where: Prisma.MonitorRuleScalarWhereInput
  data: Prisma.XOR<Prisma.MonitorRuleUpdateManyMutationInput, Prisma.MonitorRuleUncheckedUpdateManyWithoutItemInput>
}

export type MonitorRuleScalarWhereInput = {
  AND?: Prisma.MonitorRuleScalarWhereInput | Prisma.MonitorRuleScalarWhereInput[]
  OR?: Prisma.MonitorRuleScalarWhereInput[]
  NOT?: Prisma.MonitorRuleScalarWhereInput | Prisma.MonitorRuleScalarWhereInput[]
  id?: Prisma.IntFilter<"MonitorRule"> | number
  itemId?: Prisma.IntFilter<"MonitorRule"> | number
  ruleName?: Prisma.StringFilter<"MonitorRule"> | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFilter<"MonitorRule"> | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFilter<"MonitorRule"> | number
  offsetHours?: Prisma.IntFilter<"MonitorRule"> | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFilter<"MonitorRule"> | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  remindTime?: Prisma.StringNullableFilter<"MonitorRule"> | string | null
  maxTimes?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  channelSms?: Prisma.BoolFilter<"MonitorRule"> | boolean
  channelSystem?: Prisma.BoolFilter<"MonitorRule"> | boolean
  stopWhenDone?: Prisma.BoolFilter<"MonitorRule"> | boolean
  contentTpl?: Prisma.StringNullableFilter<"MonitorRule"> | string | null
  isEnabled?: Prisma.BoolFilter<"MonitorRule"> | boolean
  createdBy?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  createdAt?: Prisma.DateTimeFilter<"MonitorRule"> | Date | string
  updatedBy?: Prisma.IntNullableFilter<"MonitorRule"> | number | null
  updatedAt?: Prisma.DateTimeFilter<"MonitorRule"> | Date | string
}

export type MonitorRuleCreateWithoutNotifyLogsInput = {
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
  item: Prisma.MonitorItemCreateNestedOneWithoutRulesInput
}

export type MonitorRuleUncheckedCreateWithoutNotifyLogsInput = {
  id?: number
  itemId: number
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
}

export type MonitorRuleCreateOrConnectWithoutNotifyLogsInput = {
  where: Prisma.MonitorRuleWhereUniqueInput
  create: Prisma.XOR<Prisma.MonitorRuleCreateWithoutNotifyLogsInput, Prisma.MonitorRuleUncheckedCreateWithoutNotifyLogsInput>
}

export type MonitorRuleUpsertWithoutNotifyLogsInput = {
  update: Prisma.XOR<Prisma.MonitorRuleUpdateWithoutNotifyLogsInput, Prisma.MonitorRuleUncheckedUpdateWithoutNotifyLogsInput>
  create: Prisma.XOR<Prisma.MonitorRuleCreateWithoutNotifyLogsInput, Prisma.MonitorRuleUncheckedCreateWithoutNotifyLogsInput>
  where?: Prisma.MonitorRuleWhereInput
}

export type MonitorRuleUpdateToOneWithWhereWithoutNotifyLogsInput = {
  where?: Prisma.MonitorRuleWhereInput
  data: Prisma.XOR<Prisma.MonitorRuleUpdateWithoutNotifyLogsInput, Prisma.MonitorRuleUncheckedUpdateWithoutNotifyLogsInput>
}

export type MonitorRuleUpdateWithoutNotifyLogsInput = {
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  item?: Prisma.MonitorItemUpdateOneRequiredWithoutRulesNestedInput
}

export type MonitorRuleUncheckedUpdateWithoutNotifyLogsInput = {
  id?: Prisma.IntFieldUpdateOperationsInput | number
  itemId?: Prisma.IntFieldUpdateOperationsInput | number
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
}

export type MonitorRuleCreateManyItemInput = {
  id?: number
  ruleName: string
  triggerType: $Enums.MonitorTriggerType
  offsetDays?: number
  offsetHours?: number
  repeatType?: $Enums.MonitorRepeatType
  repeatInterval?: number | null
  remindTime?: string | null
  maxTimes?: number | null
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: string | null
  isEnabled?: boolean
  createdBy?: number | null
  createdAt?: Date | string
  updatedBy?: number | null
  updatedAt?: Date | string
}

export type MonitorRuleUpdateWithoutItemInput = {
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  notifyLogs?: Prisma.MonitorNotifyLogUpdateManyWithoutRuleNestedInput
}

export type MonitorRuleUncheckedUpdateWithoutItemInput = {
  id?: Prisma.IntFieldUpdateOperationsInput | number
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  notifyLogs?: Prisma.MonitorNotifyLogUncheckedUpdateManyWithoutRuleNestedInput
}

export type MonitorRuleUncheckedUpdateManyWithoutItemInput = {
  id?: Prisma.IntFieldUpdateOperationsInput | number
  ruleName?: Prisma.StringFieldUpdateOperationsInput | string
  triggerType?: Prisma.EnumMonitorTriggerTypeFieldUpdateOperationsInput | $Enums.MonitorTriggerType
  offsetDays?: Prisma.IntFieldUpdateOperationsInput | number
  offsetHours?: Prisma.IntFieldUpdateOperationsInput | number
  repeatType?: Prisma.EnumMonitorRepeatTypeFieldUpdateOperationsInput | $Enums.MonitorRepeatType
  repeatInterval?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  remindTime?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  maxTimes?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  channelSms?: Prisma.BoolFieldUpdateOperationsInput | boolean
  channelSystem?: Prisma.BoolFieldUpdateOperationsInput | boolean
  stopWhenDone?: Prisma.BoolFieldUpdateOperationsInput | boolean
  contentTpl?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
  isEnabled?: Prisma.BoolFieldUpdateOperationsInput | boolean
  createdBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
  updatedBy?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
  updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
}


/**
 * Count Type MonitorRuleCountOutputType
 */

export type MonitorRuleCountOutputType = {
  notifyLogs: number
}

export type MonitorRuleCountOutputTypeSelect<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  notifyLogs?: boolean | MonitorRuleCountOutputTypeCountNotifyLogsArgs
}

/**
 * MonitorRuleCountOutputType without action
 */
export type MonitorRuleCountOutputTypeDefaultArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRuleCountOutputType
   */
  select?: Prisma.MonitorRuleCountOutputTypeSelect<ExtArgs> | null
}

/**
 * MonitorRuleCountOutputType without action
 */
export type MonitorRuleCountOutputTypeCountNotifyLogsArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  where?: Prisma.MonitorNotifyLogWhereInput
}


export type MonitorRuleSelect<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{
  id?: boolean
  itemId?: boolean
  ruleName?: boolean
  triggerType?: boolean
  offsetDays?: boolean
  offsetHours?: boolean
  repeatType?: boolean
  repeatInterval?: boolean
  remindTime?: boolean
  maxTimes?: boolean
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: boolean
  isEnabled?: boolean
  createdBy?: boolean
  createdAt?: boolean
  updatedBy?: boolean
  updatedAt?: boolean
  item?: boolean | Prisma.MonitorItemDefaultArgs<ExtArgs>
  notifyLogs?: boolean | Prisma.MonitorRule$notifyLogsArgs<ExtArgs>
  _count?: boolean | Prisma.MonitorRuleCountOutputTypeDefaultArgs<ExtArgs>
}, ExtArgs["result"]["monitorRule"]>

export type MonitorRuleSelectCreateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{
  id?: boolean
  itemId?: boolean
  ruleName?: boolean
  triggerType?: boolean
  offsetDays?: boolean
  offsetHours?: boolean
  repeatType?: boolean
  repeatInterval?: boolean
  remindTime?: boolean
  maxTimes?: boolean
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: boolean
  isEnabled?: boolean
  createdBy?: boolean
  createdAt?: boolean
  updatedBy?: boolean
  updatedAt?: boolean
  item?: boolean | Prisma.MonitorItemDefaultArgs<ExtArgs>
}, ExtArgs["result"]["monitorRule"]>

export type MonitorRuleSelectUpdateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetSelect<{
  id?: boolean
  itemId?: boolean
  ruleName?: boolean
  triggerType?: boolean
  offsetDays?: boolean
  offsetHours?: boolean
  repeatType?: boolean
  repeatInterval?: boolean
  remindTime?: boolean
  maxTimes?: boolean
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: boolean
  isEnabled?: boolean
  createdBy?: boolean
  createdAt?: boolean
  updatedBy?: boolean
  updatedAt?: boolean
  item?: boolean | Prisma.MonitorItemDefaultArgs<ExtArgs>
}, ExtArgs["result"]["monitorRule"]>

export type MonitorRuleSelectScalar = {
  id?: boolean
  itemId?: boolean
  ruleName?: boolean
  triggerType?: boolean
  offsetDays?: boolean
  offsetHours?: boolean
  repeatType?: boolean
  repeatInterval?: boolean
  remindTime?: boolean
  maxTimes?: boolean
  channelSms?: boolean
  channelSystem?: boolean
  stopWhenDone?: boolean
  contentTpl?: boolean
  isEnabled?: boolean
  createdBy?: boolean
  createdAt?: boolean
  updatedBy?: boolean
  updatedAt?: boolean
}

export type MonitorRuleOmit<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetOmit<"id" | "itemId" | "ruleName" | "triggerType" | "offsetDays" | "offsetHours" | "repeatType" | "repeatInterval" | "remindTime" | "maxTimes" | "channelSms" | "channelSystem" | "stopWhenDone" | "contentTpl" | "isEnabled" | "createdBy" | "createdAt" | "updatedBy" | "updatedAt", ExtArgs["result"]["monitorRule"]>
export type MonitorRuleInclude<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  item?: boolean | Prisma.MonitorItemDefaultArgs<ExtArgs>
  notifyLogs?: boolean | Prisma.MonitorRule$notifyLogsArgs<ExtArgs>
  _count?: boolean | Prisma.MonitorRuleCountOutputTypeDefaultArgs<ExtArgs>
}
export type MonitorRuleIncludeCreateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  item?: boolean | Prisma.MonitorItemDefaultArgs<ExtArgs>
}
export type MonitorRuleIncludeUpdateManyAndReturn<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  item?: boolean | Prisma.MonitorItemDefaultArgs<ExtArgs>
}

export type $MonitorRulePayload<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  name: "MonitorRule"
  objects: {
    item: Prisma.$MonitorItemPayload<ExtArgs>
    notifyLogs: Prisma.$MonitorNotifyLogPayload<ExtArgs>[]
  }
  scalars: runtime.Types.Extensions.GetPayloadResult<{
    id: number
    itemId: number
    ruleName: string
    triggerType: $Enums.MonitorTriggerType
    offsetDays: number
    offsetHours: number
    repeatType: $Enums.MonitorRepeatType
    repeatInterval: number | null
    remindTime: string | null
    maxTimes: number | null
    channelSms: boolean
    channelSystem: boolean
    stopWhenDone: boolean
    contentTpl: string | null
    isEnabled: boolean
    createdBy: number | null
    createdAt: Date
    updatedBy: number | null
    updatedAt: Date
  }, ExtArgs["result"]["monitorRule"]>
  composites: {}
}

export type MonitorRuleGetPayload<S extends boolean | null | undefined | MonitorRuleDefaultArgs> = runtime.Types.Result.GetResult<Prisma.$MonitorRulePayload, S>

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

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

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

/**
 * The delegate class that acts as a "Promise-like" for MonitorRule.
 * 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__MonitorRuleClient<T, Null = never, ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs, GlobalOmitOptions = {}> extends Prisma.PrismaPromise<T> {
  readonly [Symbol.toStringTag]: "PrismaPromise"
  item<T extends Prisma.MonitorItemDefaultArgs<ExtArgs> = {}>(args?: Prisma.Subset<T, Prisma.MonitorItemDefaultArgs<ExtArgs>>): Prisma.Prisma__MonitorItemClient<runtime.Types.Result.GetResult<Prisma.$MonitorItemPayload<ExtArgs>, T, "findUniqueOrThrow", GlobalOmitOptions> | Null, Null, ExtArgs, GlobalOmitOptions>
  notifyLogs<T extends Prisma.MonitorRule$notifyLogsArgs<ExtArgs> = {}>(args?: Prisma.Subset<T, Prisma.MonitorRule$notifyLogsArgs<ExtArgs>>): Prisma.PrismaPromise<runtime.Types.Result.GetResult<Prisma.$MonitorNotifyLogPayload<ExtArgs>, T, "findMany", GlobalOmitOptions> | Null>
  /**
   * 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 MonitorRule model
 */
export interface MonitorRuleFieldRefs {
  readonly id: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly itemId: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly ruleName: Prisma.FieldRef<"MonitorRule", 'String'>
  readonly triggerType: Prisma.FieldRef<"MonitorRule", 'MonitorTriggerType'>
  readonly offsetDays: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly offsetHours: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly repeatType: Prisma.FieldRef<"MonitorRule", 'MonitorRepeatType'>
  readonly repeatInterval: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly remindTime: Prisma.FieldRef<"MonitorRule", 'String'>
  readonly maxTimes: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly channelSms: Prisma.FieldRef<"MonitorRule", 'Boolean'>
  readonly channelSystem: Prisma.FieldRef<"MonitorRule", 'Boolean'>
  readonly stopWhenDone: Prisma.FieldRef<"MonitorRule", 'Boolean'>
  readonly contentTpl: Prisma.FieldRef<"MonitorRule", 'String'>
  readonly isEnabled: Prisma.FieldRef<"MonitorRule", 'Boolean'>
  readonly createdBy: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly createdAt: Prisma.FieldRef<"MonitorRule", 'DateTime'>
  readonly updatedBy: Prisma.FieldRef<"MonitorRule", 'Int'>
  readonly updatedAt: Prisma.FieldRef<"MonitorRule", 'DateTime'>
}
    

// Custom InputTypes
/**
 * MonitorRule findUnique
 */
export type MonitorRuleFindUniqueArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * Filter, which MonitorRule to fetch.
   */
  where: Prisma.MonitorRuleWhereUniqueInput
}

/**
 * MonitorRule findUniqueOrThrow
 */
export type MonitorRuleFindUniqueOrThrowArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * Filter, which MonitorRule to fetch.
   */
  where: Prisma.MonitorRuleWhereUniqueInput
}

/**
 * MonitorRule findFirst
 */
export type MonitorRuleFindFirstArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * Filter, which MonitorRule to fetch.
   */
  where?: Prisma.MonitorRuleWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of MonitorRules to fetch.
   */
  orderBy?: Prisma.MonitorRuleOrderByWithRelationInput | Prisma.MonitorRuleOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the position for searching for MonitorRules.
   */
  cursor?: Prisma.MonitorRuleWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` MonitorRules 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` MonitorRules.
   */
  skip?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/distinct Distinct Docs}
   * 
   * Filter by unique combinations of MonitorRules.
   */
  distinct?: Prisma.MonitorRuleScalarFieldEnum | Prisma.MonitorRuleScalarFieldEnum[]
}

/**
 * MonitorRule findFirstOrThrow
 */
export type MonitorRuleFindFirstOrThrowArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * Filter, which MonitorRule to fetch.
   */
  where?: Prisma.MonitorRuleWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of MonitorRules to fetch.
   */
  orderBy?: Prisma.MonitorRuleOrderByWithRelationInput | Prisma.MonitorRuleOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the position for searching for MonitorRules.
   */
  cursor?: Prisma.MonitorRuleWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` MonitorRules 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` MonitorRules.
   */
  skip?: number
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/distinct Distinct Docs}
   * 
   * Filter by unique combinations of MonitorRules.
   */
  distinct?: Prisma.MonitorRuleScalarFieldEnum | Prisma.MonitorRuleScalarFieldEnum[]
}

/**
 * MonitorRule findMany
 */
export type MonitorRuleFindManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * Filter, which MonitorRules to fetch.
   */
  where?: Prisma.MonitorRuleWhereInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/sorting Sorting Docs}
   * 
   * Determine the order of MonitorRules to fetch.
   */
  orderBy?: Prisma.MonitorRuleOrderByWithRelationInput | Prisma.MonitorRuleOrderByWithRelationInput[]
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination#cursor-based-pagination Cursor Docs}
   * 
   * Sets the position for listing MonitorRules.
   */
  cursor?: Prisma.MonitorRuleWhereUniqueInput
  /**
   * {@link https://www.prisma.io/docs/concepts/components/prisma-client/pagination Pagination Docs}
   * 
   * Take `±n` MonitorRules 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` MonitorRules.
   */
  skip?: number
  distinct?: Prisma.MonitorRuleScalarFieldEnum | Prisma.MonitorRuleScalarFieldEnum[]
}

/**
 * MonitorRule create
 */
export type MonitorRuleCreateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * The data needed to create a MonitorRule.
   */
  data: Prisma.XOR<Prisma.MonitorRuleCreateInput, Prisma.MonitorRuleUncheckedCreateInput>
}

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

/**
 * MonitorRule createManyAndReturn
 */
export type MonitorRuleCreateManyAndReturnArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelectCreateManyAndReturn<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * The data used to create many MonitorRules.
   */
  data: Prisma.MonitorRuleCreateManyInput | Prisma.MonitorRuleCreateManyInput[]
  skipDuplicates?: boolean
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleIncludeCreateManyAndReturn<ExtArgs> | null
}

/**
 * MonitorRule update
 */
export type MonitorRuleUpdateArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * The data needed to update a MonitorRule.
   */
  data: Prisma.XOR<Prisma.MonitorRuleUpdateInput, Prisma.MonitorRuleUncheckedUpdateInput>
  /**
   * Choose, which MonitorRule to update.
   */
  where: Prisma.MonitorRuleWhereUniqueInput
}

/**
 * MonitorRule updateMany
 */
export type MonitorRuleUpdateManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * The data used to update MonitorRules.
   */
  data: Prisma.XOR<Prisma.MonitorRuleUpdateManyMutationInput, Prisma.MonitorRuleUncheckedUpdateManyInput>
  /**
   * Filter which MonitorRules to update
   */
  where?: Prisma.MonitorRuleWhereInput
  /**
   * Limit how many MonitorRules to update.
   */
  limit?: number
}

/**
 * MonitorRule updateManyAndReturn
 */
export type MonitorRuleUpdateManyAndReturnArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelectUpdateManyAndReturn<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * The data used to update MonitorRules.
   */
  data: Prisma.XOR<Prisma.MonitorRuleUpdateManyMutationInput, Prisma.MonitorRuleUncheckedUpdateManyInput>
  /**
   * Filter which MonitorRules to update
   */
  where?: Prisma.MonitorRuleWhereInput
  /**
   * Limit how many MonitorRules to update.
   */
  limit?: number
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleIncludeUpdateManyAndReturn<ExtArgs> | null
}

/**
 * MonitorRule upsert
 */
export type MonitorRuleUpsertArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * The filter to search for the MonitorRule to update in case it exists.
   */
  where: Prisma.MonitorRuleWhereUniqueInput
  /**
   * In case the MonitorRule found by the `where` argument doesn't exist, create a new MonitorRule with this data.
   */
  create: Prisma.XOR<Prisma.MonitorRuleCreateInput, Prisma.MonitorRuleUncheckedCreateInput>
  /**
   * In case the MonitorRule was found with the provided `where` argument, update it with this data.
   */
  update: Prisma.XOR<Prisma.MonitorRuleUpdateInput, Prisma.MonitorRuleUncheckedUpdateInput>
}

/**
 * MonitorRule delete
 */
export type MonitorRuleDeleteArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorRule
   */
  select?: Prisma.MonitorRuleSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorRule
   */
  omit?: Prisma.MonitorRuleOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorRuleInclude<ExtArgs> | null
  /**
   * Filter which MonitorRule to delete.
   */
  where: Prisma.MonitorRuleWhereUniqueInput
}

/**
 * MonitorRule deleteMany
 */
export type MonitorRuleDeleteManyArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Filter which MonitorRules to delete
   */
  where?: Prisma.MonitorRuleWhereInput
  /**
   * Limit how many MonitorRules to delete.
   */
  limit?: number
}

/**
 * MonitorRule.notifyLogs
 */
export type MonitorRule$notifyLogsArgs<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
  /**
   * Select specific fields to fetch from the MonitorNotifyLog
   */
  select?: Prisma.MonitorNotifyLogSelect<ExtArgs> | null
  /**
   * Omit specific fields from the MonitorNotifyLog
   */
  omit?: Prisma.MonitorNotifyLogOmit<ExtArgs> | null
  /**
   * Choose, which related nodes to fetch as well
   */
  include?: Prisma.MonitorNotifyLogInclude<ExtArgs> | null
  where?: Prisma.MonitorNotifyLogWhereInput
  orderBy?: Prisma.MonitorNotifyLogOrderByWithRelationInput | Prisma.MonitorNotifyLogOrderByWithRelationInput[]
  cursor?: Prisma.MonitorNotifyLogWhereUniqueInput
  take?: number
  skip?: number
  distinct?: Prisma.MonitorNotifyLogScalarFieldEnum | Prisma.MonitorNotifyLogScalarFieldEnum[]
}

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