mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-04 05:18:25 +00:00 
			
		
		
		
	* github.com/yuin/goldmark v1.3.1 -> v1.3.2 * github.com/xanzy/go-gitlab v0.42.0 -> v0.44.0 * github.com/prometheus/client_golang v1.8.0 -> v1.9.0 * github.com/minio/minio-go v7.0.7 -> v7.0.9 * github.com/lafriks/xormstore v1.3.2 -> v1.4.0 Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
		
			
				
	
	
		
			231 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			231 lines
		
	
	
		
			8.3 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
//
 | 
						|
// Copyright 2021, Sander van Harmelen
 | 
						|
//
 | 
						|
// 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 gitlab
 | 
						|
 | 
						|
import (
 | 
						|
	"errors"
 | 
						|
	"fmt"
 | 
						|
	"net/http"
 | 
						|
)
 | 
						|
 | 
						|
// NotificationSettingsService handles communication with the notification settings
 | 
						|
// related methods of the GitLab API.
 | 
						|
//
 | 
						|
// GitLab API docs: https://docs.gitlab.com/ce/api/notification_settings.html
 | 
						|
type NotificationSettingsService struct {
 | 
						|
	client *Client
 | 
						|
}
 | 
						|
 | 
						|
// NotificationSettings represents the Gitlab notification setting.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#notification-settings
 | 
						|
type NotificationSettings struct {
 | 
						|
	Level             NotificationLevelValue `json:"level"`
 | 
						|
	NotificationEmail string                 `json:"notification_email"`
 | 
						|
	Events            *NotificationEvents    `json:"events"`
 | 
						|
}
 | 
						|
 | 
						|
// NotificationEvents represents the available notification setting events.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#notification-settings
 | 
						|
type NotificationEvents struct {
 | 
						|
	CloseIssue           bool `json:"close_issue"`
 | 
						|
	CloseMergeRequest    bool `json:"close_merge_request"`
 | 
						|
	FailedPipeline       bool `json:"failed_pipeline"`
 | 
						|
	MergeMergeRequest    bool `json:"merge_merge_request"`
 | 
						|
	NewIssue             bool `json:"new_issue"`
 | 
						|
	NewMergeRequest      bool `json:"new_merge_request"`
 | 
						|
	NewNote              bool `json:"new_note"`
 | 
						|
	ReassignIssue        bool `json:"reassign_issue"`
 | 
						|
	ReassignMergeRequest bool `json:"reassign_merge_request"`
 | 
						|
	ReopenIssue          bool `json:"reopen_issue"`
 | 
						|
	ReopenMergeRequest   bool `json:"reopen_merge_request"`
 | 
						|
	SuccessPipeline      bool `json:"success_pipeline"`
 | 
						|
}
 | 
						|
 | 
						|
func (ns NotificationSettings) String() string {
 | 
						|
	return Stringify(ns)
 | 
						|
}
 | 
						|
 | 
						|
// GetGlobalSettings returns current notification settings and email address.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#global-notification-settings
 | 
						|
func (s *NotificationSettingsService) GetGlobalSettings(options ...RequestOptionFunc) (*NotificationSettings, *Response, error) {
 | 
						|
	u := "notification_settings"
 | 
						|
 | 
						|
	req, err := s.client.NewRequest(http.MethodGet, u, nil, options)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	ns := new(NotificationSettings)
 | 
						|
	resp, err := s.client.Do(req, ns)
 | 
						|
	if err != nil {
 | 
						|
		return nil, resp, err
 | 
						|
	}
 | 
						|
 | 
						|
	return ns, resp, err
 | 
						|
}
 | 
						|
 | 
						|
// NotificationSettingsOptions represents the available options that can be passed
 | 
						|
// to the API when updating the notification settings.
 | 
						|
type NotificationSettingsOptions struct {
 | 
						|
	Level                *NotificationLevelValue `url:"level,omitempty" json:"level,omitempty"`
 | 
						|
	NotificationEmail    *string                 `url:"notification_email,omitempty" json:"notification_email,omitempty"`
 | 
						|
	CloseIssue           *bool                   `url:"close_issue,omitempty" json:"close_issue,omitempty"`
 | 
						|
	CloseMergeRequest    *bool                   `url:"close_merge_request,omitempty" json:"close_merge_request,omitempty"`
 | 
						|
	FailedPipeline       *bool                   `url:"failed_pipeline,omitempty" json:"failed_pipeline,omitempty"`
 | 
						|
	MergeMergeRequest    *bool                   `url:"merge_merge_request,omitempty" json:"merge_merge_request,omitempty"`
 | 
						|
	NewIssue             *bool                   `url:"new_issue,omitempty" json:"new_issue,omitempty"`
 | 
						|
	NewMergeRequest      *bool                   `url:"new_merge_request,omitempty" json:"new_merge_request,omitempty"`
 | 
						|
	NewNote              *bool                   `url:"new_note,omitempty" json:"new_note,omitempty"`
 | 
						|
	ReassignIssue        *bool                   `url:"reassign_issue,omitempty" json:"reassign_issue,omitempty"`
 | 
						|
	ReassignMergeRequest *bool                   `url:"reassign_merge_request,omitempty" json:"reassign_merge_request,omitempty"`
 | 
						|
	ReopenIssue          *bool                   `url:"reopen_issue,omitempty" json:"reopen_issue,omitempty"`
 | 
						|
	ReopenMergeRequest   *bool                   `url:"reopen_merge_request,omitempty" json:"reopen_merge_request,omitempty"`
 | 
						|
	SuccessPipeline      *bool                   `url:"success_pipeline,omitempty" json:"success_pipeline,omitempty"`
 | 
						|
}
 | 
						|
 | 
						|
// UpdateGlobalSettings updates current notification settings and email address.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#update-global-notification-settings
 | 
						|
func (s *NotificationSettingsService) UpdateGlobalSettings(opt *NotificationSettingsOptions, options ...RequestOptionFunc) (*NotificationSettings, *Response, error) {
 | 
						|
	if opt.Level != nil && *opt.Level == GlobalNotificationLevel {
 | 
						|
		return nil, nil, errors.New(
 | 
						|
			"notification level 'global' is not valid for global notification settings")
 | 
						|
	}
 | 
						|
 | 
						|
	u := "notification_settings"
 | 
						|
 | 
						|
	req, err := s.client.NewRequest(http.MethodPut, u, opt, options)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	ns := new(NotificationSettings)
 | 
						|
	resp, err := s.client.Do(req, ns)
 | 
						|
	if err != nil {
 | 
						|
		return nil, resp, err
 | 
						|
	}
 | 
						|
 | 
						|
	return ns, resp, err
 | 
						|
}
 | 
						|
 | 
						|
// GetSettingsForGroup returns current group notification settings.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#group-project-level-notification-settings
 | 
						|
func (s *NotificationSettingsService) GetSettingsForGroup(gid interface{}, options ...RequestOptionFunc) (*NotificationSettings, *Response, error) {
 | 
						|
	group, err := parseID(gid)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
	u := fmt.Sprintf("groups/%s/notification_settings", pathEscape(group))
 | 
						|
 | 
						|
	req, err := s.client.NewRequest(http.MethodGet, u, nil, options)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	ns := new(NotificationSettings)
 | 
						|
	resp, err := s.client.Do(req, ns)
 | 
						|
	if err != nil {
 | 
						|
		return nil, resp, err
 | 
						|
	}
 | 
						|
 | 
						|
	return ns, resp, err
 | 
						|
}
 | 
						|
 | 
						|
// GetSettingsForProject returns current project notification settings.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#group-project-level-notification-settings
 | 
						|
func (s *NotificationSettingsService) GetSettingsForProject(pid interface{}, options ...RequestOptionFunc) (*NotificationSettings, *Response, error) {
 | 
						|
	project, err := parseID(pid)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
	u := fmt.Sprintf("projects/%s/notification_settings", pathEscape(project))
 | 
						|
 | 
						|
	req, err := s.client.NewRequest(http.MethodGet, u, nil, options)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	ns := new(NotificationSettings)
 | 
						|
	resp, err := s.client.Do(req, ns)
 | 
						|
	if err != nil {
 | 
						|
		return nil, resp, err
 | 
						|
	}
 | 
						|
 | 
						|
	return ns, resp, err
 | 
						|
}
 | 
						|
 | 
						|
// UpdateSettingsForGroup updates current group notification settings.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#update-group-project-level-notification-settings
 | 
						|
func (s *NotificationSettingsService) UpdateSettingsForGroup(gid interface{}, opt *NotificationSettingsOptions, options ...RequestOptionFunc) (*NotificationSettings, *Response, error) {
 | 
						|
	group, err := parseID(gid)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
	u := fmt.Sprintf("groups/%s/notification_settings", pathEscape(group))
 | 
						|
 | 
						|
	req, err := s.client.NewRequest(http.MethodPut, u, opt, options)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	ns := new(NotificationSettings)
 | 
						|
	resp, err := s.client.Do(req, ns)
 | 
						|
	if err != nil {
 | 
						|
		return nil, resp, err
 | 
						|
	}
 | 
						|
 | 
						|
	return ns, resp, err
 | 
						|
}
 | 
						|
 | 
						|
// UpdateSettingsForProject updates current project notification settings.
 | 
						|
//
 | 
						|
// GitLab API docs:
 | 
						|
// https://docs.gitlab.com/ce/api/notification_settings.html#update-group-project-level-notification-settings
 | 
						|
func (s *NotificationSettingsService) UpdateSettingsForProject(pid interface{}, opt *NotificationSettingsOptions, options ...RequestOptionFunc) (*NotificationSettings, *Response, error) {
 | 
						|
	project, err := parseID(pid)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
	u := fmt.Sprintf("projects/%s/notification_settings", pathEscape(project))
 | 
						|
 | 
						|
	req, err := s.client.NewRequest(http.MethodPut, u, opt, options)
 | 
						|
	if err != nil {
 | 
						|
		return nil, nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	ns := new(NotificationSettings)
 | 
						|
	resp, err := s.client.Do(req, ns)
 | 
						|
	if err != nil {
 | 
						|
		return nil, resp, err
 | 
						|
	}
 | 
						|
 | 
						|
	return ns, resp, err
 | 
						|
}
 |