mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Some bugs caused by less unit tests in fundamental packages. This PR refactor `setting` package so that create a unit test will be easier than before. - All `LoadFromXXX` files has been splited as two functions, one is `InitProviderFromXXX` and `LoadCommonSettings`. The first functions will only include the code to create or new a ini file. The second function will load common settings. - It also renames all functions in setting from `newXXXService` to `loadXXXSetting` or `loadXXXFrom` to make the function name less confusing. - Move `XORMLog` to `SQLLog` because it's a better name for that. Maybe we should finally move these `loadXXXSetting` into the `XXXInit` function? Any idea? --------- Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: delvh <dev.lh@web.de>
		
			
				
	
	
		
			56 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2020 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package cmd
 | 
						|
 | 
						|
import (
 | 
						|
	"fmt"
 | 
						|
	"net/http"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/modules/private"
 | 
						|
	"code.gitea.io/gitea/modules/setting"
 | 
						|
 | 
						|
	"github.com/urfave/cli"
 | 
						|
)
 | 
						|
 | 
						|
func runSendMail(c *cli.Context) error {
 | 
						|
	ctx, cancel := installSignals()
 | 
						|
	defer cancel()
 | 
						|
 | 
						|
	setting.InitProviderFromExistingFile()
 | 
						|
	setting.LoadCommonSettings()
 | 
						|
 | 
						|
	if err := argsSet(c, "title"); err != nil {
 | 
						|
		return err
 | 
						|
	}
 | 
						|
 | 
						|
	subject := c.String("title")
 | 
						|
	confirmSkiped := c.Bool("force")
 | 
						|
	body := c.String("content")
 | 
						|
 | 
						|
	if !confirmSkiped {
 | 
						|
		if len(body) == 0 {
 | 
						|
			fmt.Print("warning: Content is empty")
 | 
						|
		}
 | 
						|
 | 
						|
		fmt.Print("Proceed with sending email? [Y/n] ")
 | 
						|
		isConfirmed, err := confirm()
 | 
						|
		if err != nil {
 | 
						|
			return err
 | 
						|
		} else if !isConfirmed {
 | 
						|
			fmt.Println("The mail was not sent")
 | 
						|
			return nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
 | 
						|
	status, message := private.SendEmail(ctx, subject, body, nil)
 | 
						|
	if status != http.StatusOK {
 | 
						|
		fmt.Printf("error: %s\n", message)
 | 
						|
		return nil
 | 
						|
	}
 | 
						|
 | 
						|
	fmt.Printf("Success: %s\n", message)
 | 
						|
 | 
						|
	return nil
 | 
						|
}
 |