|
@@ -74,7 +74,7 @@ func (app *App) HandleProvisionAWSECRInfra(w http.ResponseWriter, r *http.Reques
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// convert the form to an aws infra instance
|
|
// convert the form to an aws infra instance
|
|
|
- infra, err := form.ToAWSInfra()
|
|
|
|
|
|
|
+ infra, err := form.ToInfra()
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
@@ -82,7 +82,7 @@ func (app *App) HandleProvisionAWSECRInfra(w http.ResponseWriter, r *http.Reques
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// handle write to the database
|
|
// handle write to the database
|
|
|
- infra, err = app.Repo.AWSInfra.CreateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, err = app.Repo.Infra.CreateInfra(infra)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorDataWrite(err, w)
|
|
app.handleErrorDataWrite(err, w)
|
|
@@ -93,7 +93,7 @@ func (app *App) HandleProvisionAWSECRInfra(w http.ResponseWriter, r *http.Reques
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
|
return
|
|
return
|
|
@@ -104,7 +104,7 @@ func (app *App) HandleProvisionAWSECRInfra(w http.ResponseWriter, r *http.Reques
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
|
return
|
|
return
|
|
@@ -122,7 +122,7 @@ func (app *App) HandleProvisionAWSECRInfra(w http.ResponseWriter, r *http.Reques
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorInternal(err, w)
|
|
app.handleErrorInternal(err, w)
|
|
|
return
|
|
return
|
|
@@ -151,7 +151,7 @@ func (app *App) HandleDestroyAWSECRInfra(w http.ResponseWriter, r *http.Request)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// read infra to get id
|
|
// read infra to get id
|
|
|
- infra, err := app.Repo.AWSInfra.ReadAWSInfra(uint(infraID))
|
|
|
|
|
|
|
+ infra, err := app.Repo.Infra.ReadInfra(uint(infraID))
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
@@ -165,7 +165,7 @@ func (app *App) HandleDestroyAWSECRInfra(w http.ResponseWriter, r *http.Request)
|
|
|
// decode from JSON to form value
|
|
// decode from JSON to form value
|
|
|
if err := json.NewDecoder(r.Body).Decode(form); err != nil {
|
|
if err := json.NewDecoder(r.Body).Decode(form); err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
return
|
|
return
|
|
@@ -174,7 +174,7 @@ func (app *App) HandleDestroyAWSECRInfra(w http.ResponseWriter, r *http.Request)
|
|
|
// validate the form
|
|
// validate the form
|
|
|
if err := app.validator.Struct(form); err != nil {
|
|
if err := app.validator.Struct(form); err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorFormValidation(err, ErrProjectValidateFields, w)
|
|
app.handleErrorFormValidation(err, ErrProjectValidateFields, w)
|
|
|
return
|
|
return
|
|
@@ -185,7 +185,7 @@ func (app *App) HandleDestroyAWSECRInfra(w http.ResponseWriter, r *http.Request)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
|
return
|
|
return
|
|
@@ -193,7 +193,7 @@ func (app *App) HandleDestroyAWSECRInfra(w http.ResponseWriter, r *http.Request)
|
|
|
|
|
|
|
|
// mark infra for deletion
|
|
// mark infra for deletion
|
|
|
infra.Status = models.StatusDestroying
|
|
infra.Status = models.StatusDestroying
|
|
|
- infra, err = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, err = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorDataWrite(err, w)
|
|
app.handleErrorDataWrite(err, w)
|
|
@@ -246,7 +246,7 @@ func (app *App) HandleProvisionAWSEKSInfra(w http.ResponseWriter, r *http.Reques
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// convert the form to an aws infra instance
|
|
// convert the form to an aws infra instance
|
|
|
- infra, err := form.ToAWSInfra()
|
|
|
|
|
|
|
+ infra, err := form.ToInfra()
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
@@ -254,7 +254,7 @@ func (app *App) HandleProvisionAWSEKSInfra(w http.ResponseWriter, r *http.Reques
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// handle write to the database
|
|
// handle write to the database
|
|
|
- infra, err = app.Repo.AWSInfra.CreateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, err = app.Repo.Infra.CreateInfra(infra)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorDataWrite(err, w)
|
|
app.handleErrorDataWrite(err, w)
|
|
@@ -265,7 +265,7 @@ func (app *App) HandleProvisionAWSEKSInfra(w http.ResponseWriter, r *http.Reques
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
|
return
|
|
return
|
|
@@ -276,7 +276,7 @@ func (app *App) HandleProvisionAWSEKSInfra(w http.ResponseWriter, r *http.Reques
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
|
return
|
|
return
|
|
@@ -294,7 +294,7 @@ func (app *App) HandleProvisionAWSEKSInfra(w http.ResponseWriter, r *http.Reques
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorInternal(err, w)
|
|
app.handleErrorInternal(err, w)
|
|
|
return
|
|
return
|
|
@@ -323,7 +323,7 @@ func (app *App) HandleDestroyAWSEKSInfra(w http.ResponseWriter, r *http.Request)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// read infra to get id
|
|
// read infra to get id
|
|
|
- infra, err := app.Repo.AWSInfra.ReadAWSInfra(uint(infraID))
|
|
|
|
|
|
|
+ infra, err := app.Repo.Infra.ReadInfra(uint(infraID))
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
@@ -337,7 +337,7 @@ func (app *App) HandleDestroyAWSEKSInfra(w http.ResponseWriter, r *http.Request)
|
|
|
// decode from JSON to form value
|
|
// decode from JSON to form value
|
|
|
if err := json.NewDecoder(r.Body).Decode(form); err != nil {
|
|
if err := json.NewDecoder(r.Body).Decode(form); err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
return
|
|
return
|
|
@@ -346,7 +346,7 @@ func (app *App) HandleDestroyAWSEKSInfra(w http.ResponseWriter, r *http.Request)
|
|
|
// validate the form
|
|
// validate the form
|
|
|
if err := app.validator.Struct(form); err != nil {
|
|
if err := app.validator.Struct(form); err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorFormValidation(err, ErrProjectValidateFields, w)
|
|
app.handleErrorFormValidation(err, ErrProjectValidateFields, w)
|
|
|
return
|
|
return
|
|
@@ -357,7 +357,7 @@ func (app *App) HandleDestroyAWSEKSInfra(w http.ResponseWriter, r *http.Request)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
infra.Status = models.StatusError
|
|
infra.Status = models.StatusError
|
|
|
- infra, _ = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|
|
|
return
|
|
return
|
|
@@ -365,7 +365,7 @@ func (app *App) HandleDestroyAWSEKSInfra(w http.ResponseWriter, r *http.Request)
|
|
|
|
|
|
|
|
// mark infra for deletion
|
|
// mark infra for deletion
|
|
|
infra.Status = models.StatusDestroying
|
|
infra.Status = models.StatusDestroying
|
|
|
- infra, err = app.Repo.AWSInfra.UpdateAWSInfra(infra)
|
|
|
|
|
|
|
+ infra, err = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorDataWrite(err, w)
|
|
app.handleErrorDataWrite(err, w)
|
|
@@ -392,6 +392,269 @@ func (app *App) HandleDestroyAWSEKSInfra(w http.ResponseWriter, r *http.Request)
|
|
|
w.WriteHeader(http.StatusOK)
|
|
w.WriteHeader(http.StatusOK)
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
|
|
+// HandleProvisionGCPGCRInfra enables GCR for a project
|
|
|
|
|
+func (app *App) HandleProvisionGCPGCRInfra(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
+ projID, err := strconv.ParseUint(chi.URLParam(r, "project_id"), 0, 64)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil || projID == 0 {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ form := &forms.CreateGCRInfra{
|
|
|
|
|
+ ProjectID: uint(projID),
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // decode from JSON to form value
|
|
|
|
|
+ if err := json.NewDecoder(r.Body).Decode(form); err != nil {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // validate the form
|
|
|
|
|
+ if err := app.validator.Struct(form); err != nil {
|
|
|
|
|
+ app.handleErrorFormValidation(err, ErrProjectValidateFields, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // convert the form to an aws infra instance
|
|
|
|
|
+ infra, err := form.ToInfra()
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // handle write to the database
|
|
|
|
|
+ infra, err = app.Repo.Infra.CreateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorDataWrite(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ gcpInt, err := app.Repo.GCPIntegration.ReadGCPIntegration(infra.GCPIntegrationID)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorDataRead(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // launch provisioning pod
|
|
|
|
|
+ agent, err := kubernetes.GetAgentInClusterConfig()
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorDataRead(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ _, err = agent.ProvisionGCR(
|
|
|
|
|
+ uint(projID),
|
|
|
|
|
+ gcpInt,
|
|
|
|
|
+ infra,
|
|
|
|
|
+ provisioner.Apply,
|
|
|
|
|
+ &app.DBConf,
|
|
|
|
|
+ app.RedisConf,
|
|
|
|
|
+ )
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorInternal(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ app.Logger.Info().Msgf("New gcp gcr infra created: %d", infra.ID)
|
|
|
|
|
+
|
|
|
|
|
+ w.WriteHeader(http.StatusCreated)
|
|
|
|
|
+
|
|
|
|
|
+ infraExt := infra.Externalize()
|
|
|
|
|
+
|
|
|
|
|
+ if err := json.NewEncoder(w).Encode(infraExt); err != nil {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+// HandleProvisionGCPGKEInfra provisions a new GKE instance for a project
|
|
|
|
|
+func (app *App) HandleProvisionGCPGKEInfra(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
+ projID, err := strconv.ParseUint(chi.URLParam(r, "project_id"), 0, 64)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil || projID == 0 {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ form := &forms.CreateGKEInfra{
|
|
|
|
|
+ ProjectID: uint(projID),
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // decode from JSON to form value
|
|
|
|
|
+ if err := json.NewDecoder(r.Body).Decode(form); err != nil {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // validate the form
|
|
|
|
|
+ if err := app.validator.Struct(form); err != nil {
|
|
|
|
|
+ app.handleErrorFormValidation(err, ErrProjectValidateFields, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // convert the form to an aws infra instance
|
|
|
|
|
+ infra, err := form.ToInfra()
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // handle write to the database
|
|
|
|
|
+ infra, err = app.Repo.Infra.CreateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorDataWrite(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ gcpInt, err := app.Repo.GCPIntegration.ReadGCPIntegration(infra.GCPIntegrationID)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorDataRead(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // launch provisioning pod
|
|
|
|
|
+ agent, err := kubernetes.GetAgentInClusterConfig()
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorDataRead(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ _, err = agent.ProvisionGKE(
|
|
|
|
|
+ uint(projID),
|
|
|
|
|
+ gcpInt,
|
|
|
|
|
+ form.GKEName,
|
|
|
|
|
+ infra,
|
|
|
|
|
+ provisioner.Apply,
|
|
|
|
|
+ &app.DBConf,
|
|
|
|
|
+ app.RedisConf,
|
|
|
|
|
+ )
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorInternal(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ app.Logger.Info().Msgf("New gcp gke infra created: %d", infra.ID)
|
|
|
|
|
+
|
|
|
|
|
+ w.WriteHeader(http.StatusCreated)
|
|
|
|
|
+
|
|
|
|
|
+ infraExt := infra.Externalize()
|
|
|
|
|
+
|
|
|
|
|
+ if err := json.NewEncoder(w).Encode(infraExt); err != nil {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
|
|
+// HandleDestroyGCPGKEInfra destroys gke infra
|
|
|
|
|
+func (app *App) HandleDestroyGCPGKEInfra(w http.ResponseWriter, r *http.Request) {
|
|
|
|
|
+ // get path parameters
|
|
|
|
|
+ infraID, err := strconv.ParseUint(chi.URLParam(r, "infra_id"), 10, 64)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // read infra to get id
|
|
|
|
|
+ infra, err := app.Repo.Infra.ReadInfra(uint(infraID))
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorDataRead(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ gcpInt, err := app.Repo.GCPIntegration.ReadGCPIntegration(infra.GCPIntegrationID)
|
|
|
|
|
+
|
|
|
|
|
+ form := &forms.DestroyGKEInfra{}
|
|
|
|
|
+
|
|
|
|
|
+ // decode from JSON to form value
|
|
|
|
|
+ if err := json.NewDecoder(r.Body).Decode(form); err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorFormDecoding(err, ErrProjectDecode, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // validate the form
|
|
|
|
|
+ if err := app.validator.Struct(form); err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorFormValidation(err, ErrProjectValidateFields, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // launch provisioning destruction pod
|
|
|
|
|
+ agent, err := kubernetes.GetAgentInClusterConfig()
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ infra.Status = models.StatusError
|
|
|
|
|
+ infra, _ = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ app.handleErrorDataRead(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ // mark infra for deletion
|
|
|
|
|
+ infra.Status = models.StatusDestroying
|
|
|
|
|
+ infra, err = app.Repo.Infra.UpdateInfra(infra)
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorDataWrite(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ _, err = agent.ProvisionGKE(
|
|
|
|
|
+ infra.ProjectID,
|
|
|
|
|
+ gcpInt,
|
|
|
|
|
+ form.GKEName,
|
|
|
|
|
+ infra,
|
|
|
|
|
+ provisioner.Destroy,
|
|
|
|
|
+ &app.DBConf,
|
|
|
|
|
+ app.RedisConf,
|
|
|
|
|
+ )
|
|
|
|
|
+
|
|
|
|
|
+ if err != nil {
|
|
|
|
|
+ app.handleErrorInternal(err, w)
|
|
|
|
|
+ return
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ app.Logger.Info().Msgf("GCP GKE infra marked for destruction: %d", infra.ID)
|
|
|
|
|
+
|
|
|
|
|
+ w.WriteHeader(http.StatusOK)
|
|
|
|
|
+}
|
|
|
|
|
+
|
|
|
// HandleGetProvisioningLogs returns real-time logs of the provisioning process via websockets
|
|
// HandleGetProvisioningLogs returns real-time logs of the provisioning process via websockets
|
|
|
func (app *App) HandleGetProvisioningLogs(w http.ResponseWriter, r *http.Request) {
|
|
func (app *App) HandleGetProvisioningLogs(w http.ResponseWriter, r *http.Request) {
|
|
|
// get path parameters
|
|
// get path parameters
|
|
@@ -403,7 +666,7 @@ func (app *App) HandleGetProvisioningLogs(w http.ResponseWriter, r *http.Request
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
// read infra to get id
|
|
// read infra to get id
|
|
|
- infra, err := app.Repo.AWSInfra.ReadAWSInfra(uint(infraID))
|
|
|
|
|
|
|
+ infra, err := app.Repo.Infra.ReadInfra(uint(infraID))
|
|
|
|
|
|
|
|
if err != nil {
|
|
if err != nil {
|
|
|
app.handleErrorDataRead(err, w)
|
|
app.handleErrorDataRead(err, w)
|