package main import ( "os" _ "github.com/mattn/go-sqlite3" "context" "fmt" metric "github.com/usememos/memos/plugin/metrics" "github.com/usememos/memos/server" "github.com/usememos/memos/server/profile" "github.com/usememos/memos/store" DB "github.com/usememos/memos/store/db" ) const ( greetingBanner = ` ███╗ ███╗███████╗███╗ ███╗ ██████╗ ███████╗ ████╗ ████║██╔════╝████╗ ████║██╔═══██╗██╔════╝ ██╔████╔██║█████╗ ██╔████╔██║██║ ██║███████╗ ██║╚██╔╝██║██╔══╝ ██║╚██╔╝██║██║ ██║╚════██║ ██║ ╚═╝ ██║███████╗██║ ╚═╝ ██║╚██████╔╝███████║ ╚═╝ ╚═╝╚══════╝╚═╝ ╚═╝ ╚═════╝ ╚══════╝ ` ) func run(profile *profile.Profile) error { ctx := context.Background() db := DB.NewDB(profile) if err := db.Open(ctx); err != nil { return fmt.Errorf("cannot open db: %w", err) } serverInstance := server.NewServer(profile) storeInstance := store.New(db.Db, profile) serverInstance.Store = storeInstance metricCollector := server.NewMetricCollector(profile, storeInstance) serverInstance.Collector = &metricCollector println(greetingBanner) fmt.Printf("Version %s has started at :%d\n", profile.Version, profile.Port) metricCollector.Collect(ctx, &metric.Metric{ Name: "service started", }) return serverInstance.Run() } func execute() error { profile, err := profile.GetProfile() if err != nil { return err } println("---") println("profile") println("mode:", profile.Mode) println("port:", profile.Port) println("dsn:", profile.DSN) println("version:", profile.Version) println("---") if err := run(profile); err != nil { fmt.Printf("error: %+v\n", err) return err } return nil } func main() { if err := execute(); err != nil { os.Exit(1) } }