summaryrefslogtreecommitdiff
path: root/system/api/json.go
diff options
context:
space:
mode:
authorSteve <nilslice@gmail.com>2017-02-13 11:06:14 -0800
committerGitHub <noreply@github.com>2017-02-13 11:06:14 -0800
commit4222b04d45b2932022c71eecf909e0e43f5f9d9d (patch)
treedf0a0cc191834d9220fe5a9f952ad61c9527a43e /system/api/json.go
parent7a85b284dec2bbb462969fb7e9e949b1a2ae720a (diff)
parent46d7c021d8de124be803b5c10f157c132343ab4e (diff)
Merge pull request #73 from ponzu-cms/ponzu-dev
[core] Adding support to omit fields from json response, minor code reorganization
Diffstat (limited to 'system/api/json.go')
-rw-r--r--system/api/json.go57
1 files changed, 57 insertions, 0 deletions
diff --git a/system/api/json.go b/system/api/json.go
new file mode 100644
index 0000000..e9d448e
--- /dev/null
+++ b/system/api/json.go
@@ -0,0 +1,57 @@
+package api
+
+import (
+ "bytes"
+ "encoding/json"
+ "log"
+ "net/http"
+)
+
+func fmtJSON(data ...json.RawMessage) ([]byte, error) {
+ var msg = []json.RawMessage{}
+ for _, d := range data {
+ msg = append(msg, d)
+ }
+
+ resp := map[string][]json.RawMessage{
+ "data": msg,
+ }
+
+ var buf = &bytes.Buffer{}
+ enc := json.NewEncoder(buf)
+ err := enc.Encode(resp)
+ if err != nil {
+ log.Println("Failed to encode data to JSON:", err)
+ return nil, err
+ }
+
+ return buf.Bytes(), nil
+}
+
+func toJSON(data []string) ([]byte, error) {
+ var buf = &bytes.Buffer{}
+ enc := json.NewEncoder(buf)
+ resp := map[string][]string{
+ "data": data,
+ }
+
+ err := enc.Encode(resp)
+ if err != nil {
+ log.Println("Failed to encode data to JSON:", err)
+ return nil, err
+ }
+
+ return buf.Bytes(), nil
+}
+
+// sendData should be used any time you want to communicate
+// data back to a foreign client
+func sendData(res http.ResponseWriter, req *http.Request, data []byte) {
+ res.Header().Set("Content-Type", "application/json")
+ res.Header().Set("Vary", "Accept-Encoding")
+
+ _, err := res.Write(data)
+ if err != nil {
+ log.Println("Error writing to response in sendData")
+ }
+}