// GlobalInit is for global configuration reload-able. func GlobalInit() { setting.NewConfigContext() log.Trace("Custom path: %s", setting.CustomPath) log.Trace("Log path: %s", setting.LogRootPath) mailer.NewMailerContext() models.LoadModelsConfig() NewServices() if setting.InstallLock { models.LoadRepoConfig() models.NewRepoContext() if err := models.NewEngine(); err != nil { log.Fatal(4, "Fail to initialize ORM engine: %v", err) } models.HasEngine = true cron.NewCronContext() log.NewGitLogger(path.Join(setting.LogRootPath, "http.log")) } if models.EnableSQLite3 { log.Info("SQLite3 Enabled") } checkRunMode() }
func runFixLocation(ctx *cli.Context) { if len(ctx.Args()) != 1 { fmt.Println("Incorrect arguments number, expect 1") os.Exit(2) } execPath, _ := setting.ExecPath() oldPath := ctx.Args().First() fmt.Printf("Old location: %s\n", oldPath) fmt.Println("This command should be executed in the new Gogs path") fmt.Printf("Do you want to change Gogs app path from old location to:\n") fmt.Printf("-> %s?\n", execPath) fmt.Print("Press <enter> to continue, use <Ctrl+c> to exit.") fmt.Scanln() // Fix in authorized_keys file. sshPath := path.Join(models.SshPath, "authorized_keys") fmt.Printf("Fixing pathes in file: %s\n", sshPath) if err := rewriteAuthorizedKeys(sshPath, oldPath, execPath); err != nil { fmt.Println(err) os.Exit(1) } // Fix position in gogs-repositories. setting.NewConfigContext() fmt.Printf("Fixing pathes in repositories: %s\n", setting.RepoRootPath) if err := walkDir(setting.RepoRootPath, "", execPath, 0); err != nil { fmt.Println(err) os.Exit(1) } fmt.Println("Fix position finished!") }
func setup(logPath string) { setting.NewConfigContext() log.NewGitLogger(filepath.Join(setting.LogRootPath, logPath)) models.LoadModelsConfig() if models.UseSQLite3 { workDir, _ := setting.WorkDir() os.Chdir(workDir) } models.SetEngine() }
func setup(logPath string) { workDir, _ := setting.WorkDir() newLogger(path.Join(workDir, logPath)) setting.NewConfigContext() models.LoadModelsConfig() if models.UseSQLite3 { os.Chdir(workDir) } models.SetEngine() }
func setup(logPath string) { setting.NewConfigContext() log.NewGitLogger(filepath.Join(setting.LogRootPath, logPath)) if setting.DisableSSH { println("Gogs: SSH has been disabled") os.Exit(1) } models.LoadModelsConfig() if setting.UseSQLite3 { workDir, _ := setting.WorkDir() os.Chdir(workDir) } models.SetEngine() }
func runDump(ctx *cli.Context) { if ctx.IsSet("config") { setting.CustomConf = ctx.String("config") } setting.NewConfigContext() models.LoadModelsConfig() models.SetEngine() log.Printf("Dumping local repositories...%s", setting.RepoRootPath) zip.Verbose = ctx.Bool("verbose") defer os.Remove("gogs-repo.zip") if err := zip.PackTo(setting.RepoRootPath, "gogs-repo.zip", true); err != nil { log.Fatalf("Fail to dump local repositories: %v", err) } log.Printf("Dumping database...") defer os.Remove("gogs-db.sql") if err := models.DumpDatabase("gogs-db.sql"); err != nil { log.Fatalf("Fail to dump database: %v", err) } fileName := fmt.Sprintf("gogs-dump-%d.zip", time.Now().Unix()) log.Printf("Packing dump files...") z, err := zip.Create(fileName) if err != nil { os.Remove(fileName) log.Fatalf("Fail to create %s: %v", fileName, err) } workDir, _ := setting.WorkDir() z.AddFile("gogs-repo.zip", path.Join(workDir, "gogs-repo.zip")) z.AddFile("gogs-db.sql", path.Join(workDir, "gogs-db.sql")) z.AddDir("custom", path.Join(workDir, "custom")) z.AddDir("log", path.Join(workDir, "log")) // FIXME: SSH key file. if err = z.Close(); err != nil { os.Remove(fileName) log.Fatalf("Fail to save %s: %v", fileName, err) } log.Println("Finish dumping!") }
func runFix(k *cli.Context) { workDir, _ := setting.WorkDir() newLogger(workDir) setting.NewConfigContext() models.LoadModelsConfig() if models.UseSQLite3 { os.Chdir(workDir) } models.SetEngine() err := models.Fix() if err != nil { fmt.Println(err) } else { fmt.Println("Fix successfully!") } }
// GlobalInit is for global configuration reload-able. func GlobalInit() { setting.NewConfigContext() log.Trace("Custom path: %s", setting.CustomPath) log.Trace("Log path: %s", setting.LogRootPath) mailer.NewMailerContext() models.LoadModelsConfig() models.LoadRepoConfig() models.NewRepoContext() NewServices() if setting.InstallLock { if err := models.NewEngine(); err != nil { qlog.Fatal(err) } models.HasEngine = true cron.NewCronContext() } if models.EnableSQLite3 { log.Info("SQLite3 Enabled") } checkRunMode() }