func restDeployAppTemplate(w *rest.ResponseWriter, r *rest.Request, client *node.ControlClient) { var payload dao.ServiceTemplateDeploymentRequest err := r.DecodeJsonPayload(&payload) if err != nil { glog.V(1).Info("Could not decode deployment payload: ", err) restBadRequest(w, err) return } var tenantID string err = client.DeployTemplate(payload, &tenantID) if err != nil { glog.Error("Could not deploy template: ", err) restServerError(w, err) return } glog.V(0).Info("Deployed template ", payload) assignmentRequest := dao.AssignmentRequest{tenantID, "", true} if err := client.AssignIPs(assignmentRequest, nil); err != nil { glog.Error("Could not automatically assign IPs: %v", err) return } glog.Infof("Automatically assigned IP addresses to service: %v", tenantID) // end of automatic IP assignment w.WriteJson(&simpleResponse{tenantID, servicesLinks()}) }