summaryrefslogtreecommitdiff
path: root/recipe.go
diff options
context:
space:
mode:
authorxengineering <me@xengineering.eu>2023-04-22 17:40:02 +0200
committerxengineering <me@xengineering.eu>2023-04-22 17:54:57 +0200
commit17f2abc3961fb854fb127f6b99c30ebb494b8e3d (patch)
tree5659716de60641fba08742e386e386e1a31a9a8f /recipe.go
parentcff4718b1acd5a34e8dceaf4d21d4bc11c0de8d6 (diff)
downloadceres-17f2abc3961fb854fb127f6b99c30ebb494b8e3d.tar
ceres-17f2abc3961fb854fb127f6b99c30ebb494b8e3d.tar.zst
ceres-17f2abc3961fb854fb127f6b99c30ebb494b8e3d.zip
Implement basic recipe target with JSON
Diffstat (limited to 'recipe.go')
-rw-r--r--recipe.go37
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
+}