summaryrefslogtreecommitdiff
path: root/srv/src/cmd/import-asset/main.go
diff options
context:
space:
mode:
authorBrian Picciano <mediocregopher@gmail.com>2022-05-17 12:41:17 -0600
committerBrian Picciano <mediocregopher@gmail.com>2022-05-17 13:28:56 -0600
commitf9d1f664f0a554b58e674f195572cc8a71d0bbfa (patch)
treea0511f27a8261b98812ff1be0f2dd39bbf7efb78 /srv/src/cmd/import-asset/main.go
parent4d2332582355c0b4c70d7817e569139d502d97a1 (diff)
Implement import-asset script
Diffstat (limited to 'srv/src/cmd/import-asset/main.go')
-rw-r--r--srv/src/cmd/import-asset/main.go114
1 files changed, 114 insertions, 0 deletions
diff --git a/srv/src/cmd/import-asset/main.go b/srv/src/cmd/import-asset/main.go
new file mode 100644
index 0000000..611bb1c
--- /dev/null
+++ b/srv/src/cmd/import-asset/main.go
@@ -0,0 +1,114 @@
+package main
+
+import (
+ "bufio"
+ "context"
+ "errors"
+ "fmt"
+ "io"
+ "os"
+ "strings"
+
+ cfgpkg "github.com/mediocregopher/blog.mediocregopher.com/srv/cfg"
+ "github.com/mediocregopher/blog.mediocregopher.com/srv/post"
+ "github.com/mediocregopher/mediocre-go-lib/v2/mctx"
+ "github.com/mediocregopher/mediocre-go-lib/v2/mlog"
+)
+
+func importAsset(assetStore post.AssetStore, id, path string) error {
+
+ f, err := os.Open(path)
+ if err != nil {
+ return fmt.Errorf("opening file: %w", err)
+ }
+ defer f.Close()
+
+ if err := assetStore.Set(id, f); err != nil {
+ return fmt.Errorf("setting into asset store: %w", err)
+ }
+
+ return nil
+}
+
+func main() {
+
+ ctx := context.Background()
+
+ cfg := cfgpkg.NewBlogCfg(cfgpkg.Params{})
+
+ var dataDir cfgpkg.DataDir
+ dataDir.SetupCfg(cfg)
+ defer dataDir.Close()
+ ctx = mctx.WithAnnotator(ctx, &dataDir)
+
+ id := cfg.String("id", "", "ID the asset will be stored under")
+ path := cfg.String("path", "", "Path the asset should be imported from")
+
+ fromStdin := cfg.Bool("from-stdin", false, "If set, ignore id and path, read space separated id/path pairs from stdin")
+
+ // initialization
+ err := cfg.Init(ctx)
+
+ logger := mlog.NewLogger(nil)
+ defer logger.Close()
+
+ if !*fromStdin && (*id == "" || *path == "") {
+ logger.FatalString(ctx, "-id and -path are required if -from-stdin is not given")
+ }
+
+ logger.Info(ctx, "process started")
+ defer logger.Info(ctx, "process exiting")
+
+ if err != nil {
+ logger.Fatal(ctx, "initializing", err)
+ }
+
+ postDB, err := post.NewSQLDB(dataDir)
+ if err != nil {
+ logger.Fatal(ctx, "initializing post sql db", err)
+ }
+ defer postDB.Close()
+
+ assetStore := post.NewAssetStore(postDB)
+
+ if !*fromStdin {
+
+ ctx := mctx.Annotate(ctx, "id", *id, "path", *path)
+
+ if err := importAsset(assetStore, *id, *path); err != nil {
+ logger.Fatal(ctx, "failed to import asset", err)
+ }
+
+ logger.Info(ctx, "asset stored")
+
+ return
+ }
+
+ for stdin := bufio.NewReader(os.Stdin); ; {
+
+ line, err := stdin.ReadString('\n')
+
+ if errors.Is(err, io.EOF) {
+ return
+ } else if err != nil {
+ logger.Fatal(ctx, "reading from stdin", err)
+ }
+
+ fields := strings.Fields(line)
+
+ if len(fields) < 2 {
+ ctx := mctx.Annotate(ctx, "line", line)
+ logger.FatalString(ctx, "cannot process line with fewer than 2 fields")
+ }
+
+ id, path := fields[0], fields[1]
+
+ ctx := mctx.Annotate(ctx, "id", id, "path", path)
+
+ if err := importAsset(assetStore, id, path); err != nil {
+ logger.Fatal(ctx, "failed to import asset", err)
+ }
+
+ logger.Info(ctx, "asset stored")
+ }
+}