您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. // Copyright 2018 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. // Package cmd provides subcommands to the gitea binary - such as "web" or
  4. // "admin".
  5. package cmd
  6. import (
  7. "context"
  8. "errors"
  9. "fmt"
  10. "io"
  11. "os"
  12. "os/signal"
  13. "strings"
  14. "syscall"
  15. "code.gitea.io/gitea/models/db"
  16. "code.gitea.io/gitea/modules/log"
  17. "code.gitea.io/gitea/modules/setting"
  18. "code.gitea.io/gitea/modules/util"
  19. "github.com/urfave/cli/v2"
  20. )
  21. // argsSet checks that all the required arguments are set. args is a list of
  22. // arguments that must be set in the passed Context.
  23. func argsSet(c *cli.Context, args ...string) error {
  24. for _, a := range args {
  25. if !c.IsSet(a) {
  26. return errors.New(a + " is not set")
  27. }
  28. if util.IsEmptyString(c.String(a)) {
  29. return errors.New(a + " is required")
  30. }
  31. }
  32. return nil
  33. }
  34. // confirm waits for user input which confirms an action
  35. func confirm() (bool, error) {
  36. var response string
  37. _, err := fmt.Scanln(&response)
  38. if err != nil {
  39. return false, err
  40. }
  41. switch strings.ToLower(response) {
  42. case "y", "yes":
  43. return true, nil
  44. case "n", "no":
  45. return false, nil
  46. default:
  47. return false, errors.New(response + " isn't a correct confirmation string")
  48. }
  49. }
  50. func initDB(ctx context.Context) error {
  51. setting.MustInstalled()
  52. setting.LoadDBSetting()
  53. setting.InitSQLLoggersForCli(log.INFO)
  54. if setting.Database.Type == "" {
  55. log.Fatal(`Database settings are missing from the configuration file: %q.
  56. Ensure you are running in the correct environment or set the correct configuration file with -c.
  57. If this is the intended configuration file complete the [database] section.`, setting.CustomConf)
  58. }
  59. if err := db.InitEngine(ctx); err != nil {
  60. return fmt.Errorf("unable to initialize the database using the configuration in %q. Error: %w", setting.CustomConf, err)
  61. }
  62. return nil
  63. }
  64. func installSignals() (context.Context, context.CancelFunc) {
  65. ctx, cancel := context.WithCancel(context.Background())
  66. go func() {
  67. // install notify
  68. signalChannel := make(chan os.Signal, 1)
  69. signal.Notify(
  70. signalChannel,
  71. syscall.SIGINT,
  72. syscall.SIGTERM,
  73. )
  74. select {
  75. case <-signalChannel:
  76. case <-ctx.Done():
  77. }
  78. cancel()
  79. signal.Reset()
  80. }()
  81. return ctx, cancel
  82. }
  83. func setupConsoleLogger(level log.Level, colorize bool, out io.Writer) {
  84. if out != os.Stdout && out != os.Stderr {
  85. panic("setupConsoleLogger can only be used with os.Stdout or os.Stderr")
  86. }
  87. writeMode := log.WriterMode{
  88. Level: level,
  89. Colorize: colorize,
  90. WriterOption: log.WriterConsoleOption{Stderr: out == os.Stderr},
  91. }
  92. writer := log.NewEventWriterConsole("console-default", writeMode)
  93. log.GetManager().GetLogger(log.DEFAULT).ReplaceAllWriters(writer)
  94. }
  95. func globalBool(c *cli.Context, name string) bool {
  96. for _, ctx := range c.Lineage() {
  97. if ctx.Bool(name) {
  98. return true
  99. }
  100. }
  101. return false
  102. }
  103. // PrepareConsoleLoggerLevel by default, use INFO level for console logger, but some sub-commands (for git/ssh protocol) shouldn't output any log to stdout.
  104. // Any log appears in git stdout pipe will break the git protocol, eg: client can't push and hangs forever.
  105. func PrepareConsoleLoggerLevel(defaultLevel log.Level) func(*cli.Context) error {
  106. return func(c *cli.Context) error {
  107. level := defaultLevel
  108. if globalBool(c, "quiet") {
  109. level = log.FATAL
  110. }
  111. if globalBool(c, "debug") || globalBool(c, "verbose") {
  112. level = log.TRACE
  113. }
  114. log.SetConsoleLogger(log.DEFAULT, "console-default", level)
  115. return nil
  116. }
  117. }