/* * Copyright 2018 Intel Corporation, Inc * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package api import ( "encoding/json" "io" "io/ioutil" "net/http" "strings" "github.com/onap/multicloud-k8s/src/k8splugin/internal/rb" "github.com/gorilla/mux" ) // Used to store backend implementations objects // Also simplifies mocking for unit testing purposes type rbProfileHandler struct { // Interface that implements bundle profile operations // Set this variable with a mock interface for testing client rb.ProfileManager } // createHandler creates a profile entry in the database func (h rbProfileHandler) createHandler(w http.ResponseWriter, r *http.Request) { var p rb.Profile err := json.NewDecoder(r.Body).Decode(&p) switch { case err == io.EOF: http.Error(w, "Empty body", http.StatusBadRequest) return case err != nil: http.Error(w, err.Error(), http.StatusUnprocessableEntity) return } // Name is required. if p.ProfileName == "" { http.Error(w, "Missing name in POST request", http.StatusBadRequest) return } ret, err := h.client.CreateOrUpdate(p, false) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } w.Header().Set("Content-Type", "application/json") w.WriteHeader(http.StatusCreated) err = json.NewEncoder(w).Encode(ret) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } } // uploadHandler uploads the profile artifact tar file into the database func (h rbProfileHandler) uploadHandler(w http.ResponseWriter, r *http.Request) { vars := mux.Vars(r) rbName := vars["rbname"] rbVersion := vars["rbversion"] prName := vars["prname"] inpBytes, err := ioutil.ReadAll(r.Body) if err != nil { http.Error(w, "Unable to read body", http.StatusBadRequest) return } if len(inpBytes) == 0 { http.Error(w, "Empty body", http.StatusBadRequest) return } err = h.client.Upload(rbName, rbVersion, prName, inpBytes) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } w.WriteHeader(http.StatusOK) } // getHandler gets a Profile Key in the database // Returns an rb.Profile func (h rbProfileHandler) getHandler(w http.ResponseWriter, r *http.Request) { vars := mux.Vars(r) rbName := vars["rbname"] rbVersion := vars["rbversion"] prName := vars["prname"] ret, err := h.client.Get(rbName, rbVersion, prName) if err != nil { // Separate "Not found" from generic DB errors if strings.Contains(err.Error(), "Error finding") { http.Error(w, err.Error(), http.StatusNotFound) return } else { http.Error(w, err.Error(), http.StatusInternalServerError) return } } w.Header().Set("Content-Type", "application/json") w.WriteHeader(http.StatusOK) err = json.NewEncoder(w).Encode(ret) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } } // updateHandler updates Profile Key in the database // Returns an rb.Profile func (h rbProfileHandler) updateHandler(w http.ResponseWriter, r *http.Request) { vars := mux.Vars(r) rbName := vars["rbname"] rbVersion := vars["rbversion"] prName := vars["prname"] ret, err := h.client.Get(rbName, rbVersion, prName) if err != nil { // Separate "Not found" from generic DB errors if strings.Contains(err.Error(), "Error finding") { http.Error(w, err.Error(), http.StatusNotFound) return } else { http.Error(w, err.Error(), http.StatusInternalServerError) return } } var p rb.Profile err = json.NewDecoder(r.Body).Decode(&p) switch { case err == io.EOF: http.Error(w, "Empty body", http.StatusBadRequest) return case err != nil: http.Error(w, err.Error(), http.StatusUnprocessableEntity) return } if p.ProfileName != "" && p.ProfileName != ret.ProfileName { http.Error(w, "Profile name mismatch", http.StatusBadRequest) return } if p.RBVersion != "" && p.RBVersion != ret.RBVersion { http.Error(w, "RB version mismatch", http.StatusBadRequest) return } if p.RBName != "" && p.RBName != ret.RBName { http.Error(w, "RB name mismatch", http.StatusBadRequest) return } p.ProfileName = ret.ProfileName p.RBVersion = ret.RBVersion p.RBName = ret.RBName ret, err = h.client.CreateOrUpdate(p, true) w.Header().Set("Content-Type", "application/json") w.WriteHeader(http.StatusOK) err = json.NewEncoder(w).Encode(ret) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } } // getHandler gets all profiles of a Resource Bundle Key in the database // Returns a list of rb.Profile func (h rbProfileHandler) listHandler(w http.ResponseWriter, r *http.Request) { vars := mux.Vars(r) rbName := vars["rbname"] rbVersion := vars["rbversion"] ret, err := h.client.List(rbName, rbVersion) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } w.Header().Set("Content-Type", "application/json") w.WriteHeader(http.StatusOK) err = json.NewEncoder(w).Encode(ret) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } } // deleteHandler deletes a particular Profile Key in the database func (h rbProfileHandler) deleteHandler(w http.ResponseWriter, r *http.Request) { vars := mux.Vars(r) rbName := vars["rbname"] rbVersion := vars["rbversion"] prName := vars["prname"] err := h.client.Delete(rbName, rbVersion, prName) if err != nil { http.Error(w, err.Error(), http.StatusInternalServerError) return } w.WriteHeader(http.StatusNoContent) }