2022-09-14 10:39:37 +03:00
|
|
|
// Command mycorrhiza is a program that runs a mycorrhiza wiki.
|
|
|
|
//
|
2021-11-10 20:14:39 +07:00
|
|
|
//go:generate go run github.com/valyala/quicktemplate/qtc -dir=history
|
2022-06-10 18:45:27 +03:00
|
|
|
//go:generate go run github.com/valyala/quicktemplate/qtc -dir=mycoopts
|
2020-06-12 21:22:02 +05:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2020-08-09 01:10:28 +05:00
|
|
|
"github.com/bouncepaw/mycorrhiza/history"
|
2024-09-07 21:22:41 +03:00
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/backlinks"
|
2024-09-07 23:55:39 +03:00
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/categories"
|
2024-09-07 21:22:41 +03:00
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/cfg"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/files"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/hyphae"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/migration"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/shroom"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/user"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/internal/version"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/interwiki"
|
2021-05-09 15:42:12 +05:00
|
|
|
"github.com/bouncepaw/mycorrhiza/web"
|
2024-09-07 21:22:41 +03:00
|
|
|
"github.com/bouncepaw/mycorrhiza/web/static"
|
|
|
|
"github.com/bouncepaw/mycorrhiza/web/viewutil"
|
2024-09-07 23:55:39 +03:00
|
|
|
"log/slog"
|
|
|
|
"os"
|
2020-06-12 21:22:02 +05:00
|
|
|
)
|
|
|
|
|
2020-08-05 20:08:59 +05:00
|
|
|
func main() {
|
2024-09-07 23:55:39 +03:00
|
|
|
if err := parseCliArgs(); err != nil {
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2021-04-28 17:12:36 +07:00
|
|
|
|
2021-06-19 11:51:10 +07:00
|
|
|
if err := files.PrepareWikiRoot(); err != nil {
|
2024-09-07 23:55:39 +03:00
|
|
|
slog.Error("Failed to prepare wiki root", "err", err)
|
|
|
|
os.Exit(1)
|
2021-04-26 22:25:47 +05:00
|
|
|
}
|
2021-06-20 00:00:28 +07:00
|
|
|
|
|
|
|
if err := cfg.ReadConfigFile(files.ConfigPath()); err != nil {
|
2024-09-07 23:55:39 +03:00
|
|
|
slog.Error("Failed to read config", "err", err)
|
|
|
|
os.Exit(1)
|
2021-06-20 00:00:28 +07:00
|
|
|
}
|
2021-04-26 22:25:47 +05:00
|
|
|
|
2021-06-19 11:51:10 +07:00
|
|
|
if err := os.Chdir(files.HyphaeDir()); err != nil {
|
2024-09-07 23:55:39 +03:00
|
|
|
slog.Error("Failed to chdir to hyphae dir",
|
|
|
|
"err", err, "hyphaeDir", files.HyphaeDir())
|
|
|
|
os.Exit(1)
|
2020-08-19 23:54:23 +05:00
|
|
|
}
|
2024-09-07 23:55:39 +03:00
|
|
|
slog.Info("Running Mycorrhiza Wiki",
|
|
|
|
"version", version.Short, "wikiDir", cfg.WikiDir)
|
2020-08-05 20:08:59 +05:00
|
|
|
|
2021-05-09 16:09:27 +05:00
|
|
|
// Init the subsystems:
|
2024-09-07 23:55:39 +03:00
|
|
|
// TODO: keep all crashes in main rather than somewhere there
|
2022-03-29 23:59:36 +03:00
|
|
|
viewutil.Init()
|
2021-06-19 11:51:10 +07:00
|
|
|
hyphae.Index(files.HyphaeDir())
|
2021-04-28 17:12:05 +07:00
|
|
|
user.InitUserDatabase()
|
2024-09-07 23:55:39 +03:00
|
|
|
if err := history.Start(); err != nil {
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2021-06-19 13:04:04 +07:00
|
|
|
history.InitGitRepo()
|
2022-01-31 02:34:52 +05:00
|
|
|
migration.MigrateRocketsMaybe()
|
2022-05-20 13:17:53 +03:00
|
|
|
migration.MigrateHeadingsMaybe()
|
2021-02-20 19:03:54 +05:00
|
|
|
shroom.SetHeaderLinks()
|
2024-09-07 23:55:39 +03:00
|
|
|
if err := categories.Init(); err != nil {
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
if err := interwiki.Init(); err != nil {
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2025-03-07 10:26:46 +00:00
|
|
|
backlinks.IndexBacklinks()
|
|
|
|
go backlinks.RunBacklinksConveyor()
|
2020-08-09 01:10:28 +05:00
|
|
|
|
2021-06-12 20:51:28 +07:00
|
|
|
// Static files:
|
2021-06-19 11:51:10 +07:00
|
|
|
static.InitFS(files.StaticFiles())
|
2021-06-12 20:51:28 +07:00
|
|
|
|
2024-06-01 23:43:26 +03:00
|
|
|
if !user.HasAnyAdmins() {
|
2024-09-07 23:55:39 +03:00
|
|
|
slog.Error("Your wiki has no admin yet. Run Mycorrhiza with -create-admin <username> option to create an admin.")
|
2024-06-01 23:43:26 +03:00
|
|
|
}
|
|
|
|
|
2024-09-07 23:55:39 +03:00
|
|
|
err := serveHTTP(web.Handler())
|
|
|
|
if err != nil {
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
2020-06-12 21:22:02 +05:00
|
|
|
}
|