Skip to content

Commit

Permalink
configstore: update api and action request types
Browse files Browse the repository at this point in the history
Don't directly use object types as request but dedicated request types.
  • Loading branch information
sgotti committed Mar 10, 2022
1 parent 0c8d973 commit 46cb16d
Show file tree
Hide file tree
Showing 26 changed files with 792 additions and 505 deletions.
31 changes: 21 additions & 10 deletions internal/services/configstore/action/org.go
Original file line number Diff line number Diff line change
Expand Up @@ -70,20 +70,26 @@ func (h *ActionHandler) GetOrgMembers(ctx context.Context, orgRef string) ([]*Or
return res, nil
}

func (h *ActionHandler) CreateOrg(ctx context.Context, org *types.Organization) (*types.Organization, error) {
if org.Name == "" {
type CreateOrgRequest struct {
Name string
Visibility types.Visibility
CreatorUserID string
}

func (h *ActionHandler) CreateOrg(ctx context.Context, req *CreateOrgRequest) (*types.Organization, error) {
if req.Name == "" {
return nil, util.NewAPIError(util.ErrBadRequest, errors.Errorf("organization name required"))
}
if !util.ValidateName(org.Name) {
return nil, util.NewAPIError(util.ErrBadRequest, errors.Errorf("invalid organization name %q", org.Name))
if !util.ValidateName(req.Name) {
return nil, util.NewAPIError(util.ErrBadRequest, errors.Errorf("invalid organization name %q", req.Name))
}
if !types.IsValidVisibility(org.Visibility) {
if !types.IsValidVisibility(req.Visibility) {
return nil, util.NewAPIError(util.ErrBadRequest, errors.Errorf("invalid organization visibility"))
}

var cgt *datamanager.ChangeGroupsUpdateToken
// changegroup is the org name
cgNames := []string{util.EncodeSha256Hex("orgname-" + org.Name)}
cgNames := []string{util.EncodeSha256Hex("orgname-" + req.Name)}

// must do all the checks in a single transaction to avoid concurrent changes
err := h.readDB.Do(ctx, func(tx *db.Tx) error {
Expand All @@ -94,21 +100,21 @@ func (h *ActionHandler) CreateOrg(ctx context.Context, org *types.Organization)
}

// check duplicate org name
o, err := h.readDB.GetOrgByName(tx, org.Name)
o, err := h.readDB.GetOrgByName(tx, req.Name)
if err != nil {
return errors.WithStack(err)
}
if o != nil {
return util.NewAPIError(util.ErrBadRequest, errors.Errorf("org %q already exists", o.Name))
}

if org.CreatorUserID != "" {
user, err := h.readDB.GetUser(tx, org.CreatorUserID)
if req.CreatorUserID != "" {
user, err := h.readDB.GetUser(tx, req.CreatorUserID)
if err != nil {
return errors.WithStack(err)
}
if user == nil {
return util.NewAPIError(util.ErrBadRequest, errors.Errorf("creator user %q doesn't exist", org.CreatorUserID))
return util.NewAPIError(util.ErrBadRequest, errors.Errorf("creator user %q doesn't exist", req.CreatorUserID))
}
}

Expand All @@ -120,8 +126,13 @@ func (h *ActionHandler) CreateOrg(ctx context.Context, org *types.Organization)

actions := []*datamanager.Action{}

org := &types.Organization{}
org.ID = uuid.Must(uuid.NewV4()).String()
org.CreatedAt = time.Now()
org.Name = req.Name
org.Visibility = req.Visibility
org.CreatorUserID = req.CreatorUserID

orgj, err := json.Marshal(org)
if err != nil {
return nil, errors.Wrapf(err, "failed to marshal org")
Expand Down
Loading

0 comments on commit 46cb16d

Please sign in to comment.