create_aws.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package project_integration
  2. import (
  3. "context"
  4. "net/http"
  5. "github.com/porter-dev/porter/api/server/handlers"
  6. "github.com/porter-dev/porter/api/server/shared"
  7. "github.com/porter-dev/porter/api/server/shared/apierrors"
  8. "github.com/porter-dev/porter/api/server/shared/config"
  9. "github.com/porter-dev/porter/api/types"
  10. "github.com/porter-dev/porter/internal/models"
  11. ints "github.com/porter-dev/porter/internal/models/integrations"
  12. )
  13. type CreateAWSHandler struct {
  14. handlers.PorterHandlerReadWriter
  15. }
  16. func NewCreateAWSHandler(
  17. config *config.Config,
  18. decoderValidator shared.RequestDecoderValidator,
  19. writer shared.ResultWriter,
  20. ) *CreateAWSHandler {
  21. return &CreateAWSHandler{
  22. PorterHandlerReadWriter: handlers.NewDefaultPorterHandler(config, decoderValidator, writer),
  23. }
  24. }
  25. func (p *CreateAWSHandler) ServeHTTP(w http.ResponseWriter, r *http.Request) {
  26. user, _ := r.Context().Value(types.UserScope).(*models.User)
  27. project, _ := r.Context().Value(types.ProjectScope).(*models.Project)
  28. request := &types.CreateAWSRequest{}
  29. if ok := p.DecodeAndValidate(w, r, request); !ok {
  30. return
  31. }
  32. aws := CreateAWSIntegration(request, project.ID, user.ID)
  33. aws, err := p.Repo().AWSIntegration().CreateAWSIntegration(aws)
  34. if err != nil {
  35. p.HandleAPIError(w, r, apierrors.NewErrInternal(err))
  36. return
  37. }
  38. aint := aws.ToAWSIntegrationType()
  39. res := types.CreateAWSResponse{
  40. AWSIntegration: &aint,
  41. }
  42. p.WriteResult(w, r, res)
  43. }
  44. func CreateAWSIntegration(request *types.CreateAWSRequest, projectID, userID uint) *ints.AWSIntegration {
  45. ctx := context.Background()
  46. resp := &ints.AWSIntegration{
  47. UserID: userID,
  48. ProjectID: projectID,
  49. AWSRegion: request.AWSRegion,
  50. AWSAssumeRoleArn: request.AWSAssumeRoleArn,
  51. AWSClusterID: []byte(request.AWSClusterID),
  52. AWSAccessKeyID: []byte(request.AWSAccessKeyID),
  53. AWSSecretAccessKey: []byte(request.AWSSecretAccessKey),
  54. }
  55. // attempt to populate the ARN
  56. resp.PopulateAWSArn(ctx)
  57. return resp
  58. }