Adding Listsecret capability
[aaf/sms.git] / sms-service / src / sms / handler / handler.go
index 79b8618..5fdbf3b 100644 (file)
@@ -18,88 +18,190 @@ package handler
 
 import (
        "encoding/json"
+       "fmt"
+       "github.com/gorilla/mux"
        "net/http"
 
-       "sms/backend"
-
-       "github.com/gorilla/mux"
+       smsbackend "sms/backend"
 )
 
-type secretDomainJSON struct {
-       name string
+// handler stores two interface implementations that implement
+// the backend functionality
+type handler struct {
+       secretBackend smsbackend.SecretBackend
+       loginBackend  smsbackend.LoginBackend
 }
 
-type secretKeyValue struct {
-       name  string
-       value string
+// createSecretDomainHandler creates a secret domain with a name provided
+func (h handler) createSecretDomainHandler(w http.ResponseWriter, r *http.Request) {
+       var d smsbackend.SecretDomain
+
+       err := json.NewDecoder(r.Body).Decode(&d)
+       if err != nil {
+               http.Error(w, err.Error(), 400)
+               return
+       }
+
+       dom, err := h.secretBackend.CreateSecretDomain(d.Name)
+       if err != nil {
+               http.Error(w, err.Error(), 500)
+               return
+       }
+
+       err = json.NewEncoder(w).Encode(dom)
+       if err != nil {
+               http.Error(w, err.Error(), 400)
+               return
+       }
 }
 
-type secretJSON struct {
-       name   string
-       values []secretKeyValue
+// getSecretDomainHandler returns list of secret domains
+func (h handler) getSecretDomainHandler(w http.ResponseWriter, r *http.Request) {
+       vars := mux.Vars(r)
+       domName := vars["domName"]
+
+       fmt.Fprintf(w, "Got req %s", domName)
+       //h.secretBackend.GetSecretDomain(domName)
+       //encode data into json and return
 }
 
-type handler struct {
-       secretBackend backend.SecretBackend
-       loginBackend  backend.LoginBackend
+// deleteSecretDomainHandler deletes a secret domain with the name provided
+func (h handler) deleteSecretDomainHandler(w http.ResponseWriter, r *http.Request) {
+       vars := mux.Vars(r)
+       domName := vars["domName"]
+
+       h.secretBackend.DeleteSecretDomain(domName)
 }
 
-// GetSecretDomainHandler returns list of secret domains
-func (h handler) GetSecretDomainHandler(w http.ResponseWriter, r *http.Request) {
+// createSecretHandler handles creation of secrets on a given domain name
+func (h handler) createSecretHandler(w http.ResponseWriter, r *http.Request) {
+       // Get domain name from URL
+       vars := mux.Vars(r)
+       domName := vars["domName"]
+
+       // Get secrets to be stored from body
+       var b smsbackend.Secret
+       err := json.NewDecoder(r.Body).Decode(&b)
+       if err != nil {
+               http.Error(w, err.Error(), 400)
+               return
+       }
+
+       err = h.secretBackend.CreateSecret(domName, b)
+       if err != nil {
+               http.Error(w, err.Error(), 500)
+               return
+       }
 
+       w.WriteHeader(http.StatusCreated)
 }
 
-// CreateSecretDomainHandler creates a secret domain with a name provided
-func (h handler) CreateSecretDomainHandler(w http.ResponseWriter, r *http.Request) {
-       var d secretDomainJSON
+// getSecretHandler handles reading a secret by given domain name and secret name
+func (h handler) getSecretHandler(w http.ResponseWriter, r *http.Request) {
+       vars := mux.Vars(r)
+       domName := vars["domName"]
+       secName := vars["secretName"]
 
-       err := json.NewDecoder(r.Body).Decode(&d)
+       sec, err := h.secretBackend.GetSecret(domName, secName)
+       if err != nil {
+               http.Error(w, err.Error(), 500)
+               return
+       }
+
+       err = json.NewEncoder(w).Encode(sec)
        if err != nil {
                http.Error(w, err.Error(), 400)
                return
        }
 }
 
-// DeleteSecretDomainHandler deletes a secret domain with the ID provided
-func (h handler) DeleteSecretDomainHandler(w http.ResponseWriter, r *http.Request) {
+// listSecretHandler handles listing all secrets under a particular domain name
+func (h handler) listSecretHandler(w http.ResponseWriter, r *http.Request) {
+       vars := mux.Vars(r)
+       domName := vars["domName"]
 
+       sec, err := h.secretBackend.ListSecret(domName)
+       if err != nil {
+               http.Error(w, err.Error(), http.StatusInternalServerError)
+               return
+       }
+
+       err = json.NewEncoder(w).Encode(sec)
+       if err != nil {
+               http.Error(w, err.Error(), http.StatusInternalServerError)
+               return
+       }
+}
+
+// deleteSecretHandler handles deleting a secret by given domain name and secret name
+func (h handler) deleteSecretHandler(w http.ResponseWriter, r *http.Request) {
+       vars := mux.Vars(r)
+       domName := vars["domName"]
+       secName := vars["secretName"]
+
+       h.secretBackend.DeleteSecret(domName, secName)
 }
 
 // struct that tracks various status items for SMS and backend
-type status struct {
+type backendStatus struct {
        Seal bool `json:"sealstatus"`
 }
 
-// StatusHandler returns information related to SMS and SMS backend services
-func (h handler) StatusHandler(w http.ResponseWriter, r *http.Request) {
-       s := h.secretBackend.GetStatus()
-       status := status{Seal: s}
-       err := json.NewEncoder(w).Encode(status)
+// statusHandler returns information related to SMS and SMS backend services
+func (h handler) statusHandler(w http.ResponseWriter, r *http.Request) {
+       s, err := h.secretBackend.GetStatus()
        if err != nil {
-               http.Error(w, err.Error(), 400)
+               http.Error(w, err.Error(), 500)
+               return
+       }
+
+       status := backendStatus{Seal: s}
+       err = json.NewEncoder(w).Encode(status)
+       if err != nil {
+               http.Error(w, err.Error(), 500)
                return
        }
 }
 
-// LoginHandler handles login via password and username
-func (h handler) LoginHandler(w http.ResponseWriter, r *http.Request) {
+// loginHandler handles login via password and username
+func (h handler) loginHandler(w http.ResponseWriter, r *http.Request) {
+
+}
+
+// initSMSHandler
+func (h handler) initSMSHandler(w http.ResponseWriter, r *http.Request) {
+
+}
+
+// unsealHandler
+func (h handler) unsealHandler(w http.ResponseWriter, r *http.Request) {
 
 }
 
 // CreateRouter returns an http.Handler for the registered URLs
-func CreateRouter(b backend.SecretBackend) http.Handler {
+// Takes an interface implementation as input
+func CreateRouter(b smsbackend.SecretBackend) http.Handler {
        h := handler{secretBackend: b}
 
        // Create a new mux to handle URL endpoints
        router := mux.NewRouter()
 
-       router.HandleFunc("/v1/sms/login", h.LoginHandler).Methods("POST")
+       router.HandleFunc("/v1/sms/login", h.loginHandler).Methods("POST")
+
+       // Initialization APIs which will be used by quorum client
+       // to unseal and to provide root token to sms service
+       router.HandleFunc("/v1/sms/status", h.statusHandler).Methods("GET")
+       router.HandleFunc("/v1/sms/unseal", h.unsealHandler).Methods("POST")
+       router.HandleFunc("/v1/sms/init", h.initSMSHandler).Methods("POST")
 
-       router.HandleFunc("/v1/sms/status", h.StatusHandler).Methods("GET")
+       router.HandleFunc("/v1/sms/domain", h.createSecretDomainHandler).Methods("POST")
+       router.HandleFunc("/v1/sms/domain/{domName}", h.getSecretDomainHandler).Methods("GET")
+       router.HandleFunc("/v1/sms/domain/{domName}", h.deleteSecretDomainHandler).Methods("DELETE")
 
-       router.HandleFunc("/v1/sms/domain", h.GetSecretDomainHandler).Methods("GET")
-       router.HandleFunc("/v1/sms/domain", h.CreateSecretDomainHandler).Methods("POST")
-       router.HandleFunc("/v1/sms/domain/{domName}", h.DeleteSecretDomainHandler).Methods("DELETE")
+       router.HandleFunc("/v1/sms/domain/{domName}/secret", h.createSecretHandler).Methods("POST")
+       router.HandleFunc("/v1/sms/domain/{domName}/secret", h.listSecretHandler).Methods("GET")
+       router.HandleFunc("/v1/sms/domain/{domName}/secret/{secretName}", h.getSecretHandler).Methods("GET")
+       router.HandleFunc("/v1/sms/domain/{domName}/secret/{secretName}", h.deleteSecretHandler).Methods("DELETE")
 
        return router
 }