| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 |
- // Copyright 2019 Yunion
- //
- // Licensed under the Apache License, Version 2.0 (the "License");
- // you may not use this file except in compliance with the License.
- // You may obtain a copy of the License at
- //
- // http://www.apache.org/licenses/LICENSE-2.0
- //
- // Unless required by applicable law or agreed to in writing, software
- // distributed under the License is distributed on an "AS IS" BASIS,
- // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- // See the License for the specific language governing permissions and
- // limitations under the License.
- package notify
- import (
- "time"
- "yunion.io/x/jsonutils"
- "yunion.io/x/onecloud/pkg/apis"
- )
- type NotificationCreateInput struct {
- apis.StatusStandaloneResourceCreateInput
- // description: ids or names of receiver
- // required: false
- // example: {"adfb720ccdd34c638346ea4fa7a713a8", "zhangsan"}
- Receivers []string `json:"receivers"`
- // description: direct contact, admin privileges required
- // required: false
- Contacts []string `json:"contacts"`
- // description: robots
- // example: feishu robot
- Robots []string `json:"robots"`
- // description: contact type
- // required: ture
- // example: email
- ContactType string `json:"contact_type"`
- // description: notification topic
- // required: true
- // example: IMAGE_ACTIVE
- Topic string `json:"topic"`
- // description: notification priority
- // required: false
- // enum: ["fatal","important","nomal"]
- // example: normal
- Priority string `json:"priority"`
- // description: message content or jsonobject
- // required: ture
- Message string `json:"message"`
- // description: notification tag
- // required: false
- // example: alert
- Tag string `json:"tag"`
- IgnoreNonexistentReceiver bool `json:"ignore_nonexistent_receiver"`
- }
- type ReceiveDetail struct {
- ReceiverId string `json:"receiver_id"`
- ReceiverName string `json:"receiver_name"`
- Contact string `json:"contact"`
- ReceiverType string `json:"receiver_type"`
- SendAt time.Time `json:"sendAt"`
- SendBy string `json:"send_by"`
- Status string `json:"status"`
- FailedReason string `json:"failed_reason"`
- }
- type NotificationDetails struct {
- apis.StatusStandaloneResourceDetails
- SNotification
- Title string `json:"title"`
- Content string `json:"content"`
- ReceiveDetails []ReceiveDetail `json:"receive_details"`
- TopicType string `json:"topic_type"`
- }
- type NotificationListInput struct {
- apis.StatusStandaloneResourceListInput
- ContactType string `json:"contact_type"`
- ReceiverId string `json:"receiver_id"`
- Tag string `json:"tag"`
- TopicType string `json:"topic_type"`
- }
- type SContact struct {
- Contact string `json:"contact"`
- ContactType string `json:"contact_type"`
- }
- type NotificationManagerEventNotifyInput struct {
- // description: ids or names of receiver
- // required: false
- // example: {"adfb720ccdd34c638346ea4fa7a713a8"}
- ReceiverIds []string `json:"receiver_ids"`
- // description: direct contact, admin privileges required
- // required: false
- Contacts []SContact `json:"contacts"`
- // 消息机器人列表
- RobotIds []string `json:"robot_ids"`
- // description: contact types
- // required: false
- // example: email
- ContactTypes []string `json:"contact_type"`
- // description: notification priority
- // required: false
- // enum: ["fatal","important","nomal"]
- // example: normal
- Priority string `json:"priority"`
- // description: resource details
- // required: ture
- ResourceDetails *jsonutils.JSONDict `json:"resource_details"`
- // description: event trigger sending notification
- // required: true
- // example: SERVER_DELETE
- Event string `json:"event"`
- ResourceType string `json:"resource_type"`
- CloudAccountName string `json:"cloud_account_name"`
- Action SAction `json:"action"`
- // failed,succeed
- Result SResult `json:"result"`
- // description: day left before the event
- // required: false
- // example: 0
- AdvanceDays int `json:"advance_days"`
- // description: domainId of the resource that triggered the event notification
- // required: false
- // example: default
- ProjectDomainId string `json:"project_domain_id"`
- // description: projectId of the resource that triggered the event notification
- // required: false
- // example: f627e09f038645f08ce6880c8d9cb8fd
- ProjectId string `json:"project_id"`
- IsFailed SResult `json:"is_failed"`
- }
- type NotificationManagerEventNotifyOutput struct {
- FailedList []FailedElem `json:"failed_list"`
- }
- type FailedElem struct {
- ContactType string `json:"contact_type"`
- Reason string `json:"reason"`
- }
- type NotificationManagerContactNotifyInput struct {
- // description: ids or names of receiver
- // required: false
- // example: {"adfb720ccdd34c638346ea4fa7a713a8"}
- ReceiverIds []string `json:"receiver_ids"`
- // description: contact types
- // required: false
- // example: email
- ContactTypes []string `json:"contact_type"`
- // description: resource details
- // required: ture
- // description: ids of robot
- // required: false
- // example: {"adfb720ccdd34c638346ea4fa7a713a8"}
- RobotIds []string `json:"robot_ids"`
- RoleIds []string `json:"role_ids"`
- Subject string `json:"subject"`
- Body string `json:"body"`
- }
|