2018-10-03 14:51:14 +00:00
|
|
|
package inmem
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2018-12-20 21:46:21 +00:00
|
|
|
"fmt"
|
2018-10-03 14:51:14 +00:00
|
|
|
"time"
|
|
|
|
|
2019-01-08 00:37:16 +00:00
|
|
|
platform "github.com/influxdata/influxdb"
|
2018-10-03 14:51:14 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const onboardingKey = "onboarding_key"
|
|
|
|
|
|
|
|
var _ platform.OnboardingService = (*Service)(nil)
|
|
|
|
|
|
|
|
// IsOnboarding checks onboardingBucket
|
|
|
|
// to see if the onboarding key is true.
|
|
|
|
func (s *Service) IsOnboarding(ctx context.Context) (isOnboarding bool, err error) {
|
|
|
|
result, ok := s.onboardingKV.Load(onboardingKey)
|
|
|
|
isOnboarding = !ok || !result.(bool)
|
|
|
|
return isOnboarding, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// PutOnboardingStatus will put the isOnboarding to storage
|
|
|
|
func (s *Service) PutOnboardingStatus(ctx context.Context, v bool) error {
|
|
|
|
s.onboardingKV.Store(onboardingKey, v)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// Generate OnboardingResults from onboarding request,
|
|
|
|
// update storage so this request will be disabled for the second run.
|
|
|
|
func (s *Service) Generate(ctx context.Context, req *platform.OnboardingRequest) (*platform.OnboardingResults, error) {
|
|
|
|
isOnboarding, err := s.IsOnboarding(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
if !isOnboarding {
|
|
|
|
return nil, &platform.Error{
|
|
|
|
Code: platform.EConflict,
|
|
|
|
Msg: "onboarding has already been completed",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if req.Password == "" {
|
|
|
|
return nil, &platform.Error{
|
|
|
|
Code: platform.EEmptyValue,
|
|
|
|
Msg: "password is empty",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if req.User == "" {
|
|
|
|
return nil, &platform.Error{
|
|
|
|
Code: platform.EEmptyValue,
|
|
|
|
Msg: "username is empty",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if req.Org == "" {
|
|
|
|
return nil, &platform.Error{
|
|
|
|
Code: platform.EEmptyValue,
|
|
|
|
Msg: "org name is empty",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if req.Bucket == "" {
|
|
|
|
return nil, &platform.Error{
|
|
|
|
Code: platform.EEmptyValue,
|
|
|
|
Msg: "bucket name is empty",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
u := &platform.User{Name: req.User}
|
|
|
|
if err := s.CreateUser(ctx, u); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = s.SetPassword(ctx, u.Name, req.Password); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
o := &platform.Organization{
|
|
|
|
Name: req.Org,
|
|
|
|
}
|
|
|
|
if err = s.CreateOrganization(ctx, o); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
bucket := &platform.Bucket{
|
|
|
|
Name: req.Bucket,
|
|
|
|
Organization: o.Name,
|
|
|
|
OrganizationID: o.ID,
|
|
|
|
RetentionPeriod: time.Duration(req.RetentionPeriod) * time.Hour,
|
|
|
|
}
|
|
|
|
if err = s.CreateBucket(ctx, bucket); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2019-01-09 16:43:58 +00:00
|
|
|
|
2018-10-03 14:51:14 +00:00
|
|
|
auth := &platform.Authorization{
|
2018-12-07 22:22:23 +00:00
|
|
|
UserID: u.ID,
|
2018-12-20 21:46:21 +00:00
|
|
|
Description: fmt.Sprintf("%s's Token", u.Name),
|
2018-12-28 23:02:19 +00:00
|
|
|
OrgID: o.ID,
|
2019-01-18 23:27:28 +00:00
|
|
|
Permissions: platform.OperPermissions(),
|
2019-01-22 21:23:51 +00:00
|
|
|
Token: req.Token,
|
2018-10-03 14:51:14 +00:00
|
|
|
}
|
|
|
|
if err = s.CreateAuthorization(ctx, auth); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if err = s.PutOnboardingStatus(ctx, true); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return &platform.OnboardingResults{
|
|
|
|
User: u,
|
|
|
|
Org: o,
|
|
|
|
Bucket: bucket,
|
|
|
|
Auth: auth,
|
|
|
|
}, nil
|
|
|
|
}
|