diff options
author | xengineering <me@xengineering.eu> | 2023-04-22 17:40:02 +0200 |
---|---|---|
committer | xengineering <me@xengineering.eu> | 2023-04-22 17:54:57 +0200 |
commit | 17f2abc3961fb854fb127f6b99c30ebb494b8e3d (patch) | |
tree | 5659716de60641fba08742e386e386e1a31a9a8f /recipe.go | |
parent | cff4718b1acd5a34e8dceaf4d21d4bc11c0de8d6 (diff) | |
download | ceres-17f2abc3961fb854fb127f6b99c30ebb494b8e3d.tar ceres-17f2abc3961fb854fb127f6b99c30ebb494b8e3d.tar.zst ceres-17f2abc3961fb854fb127f6b99c30ebb494b8e3d.zip |
Implement basic recipe target with JSON
Diffstat (limited to 'recipe.go')
-rw-r--r-- | recipe.go | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/recipe.go b/recipe.go new file mode 100644 index 0000000..167f690 --- /dev/null +++ b/recipe.go @@ -0,0 +1,37 @@ +package main + +import ( + "encoding/json" + "path/filepath" + "io/ioutil" +) + +type recipe struct { + Title string + Portions int + Url string + Steps []struct { + Text string + Ingredients []struct { + Type string + Amount any + } + } +} + +func getRecipe(id string) (recipe, error) { + r := recipe{} + + textpath := filepath.Join(config.Data, "recipes", id, "text") + data, err := ioutil.ReadFile(textpath) + if err != nil { + return r, err + } + + err = json.Unmarshal(data, &r) + if err != nil { + return r, err + } + + return r, nil +} |