2018-09-04 21:08:00 +00:00
|
|
|
package http
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"net/http"
|
|
|
|
|
2019-01-08 00:37:16 +00:00
|
|
|
platform "github.com/influxdata/influxdb"
|
2018-09-04 21:08:00 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// OrgID is the http query parameter to specify an organization by ID.
|
2018-12-21 04:18:09 +00:00
|
|
|
OrgID = "orgID"
|
2019-08-06 04:20:26 +00:00
|
|
|
// Org is the http query parameter that take either the ID or Name interchangeably
|
|
|
|
Org = "org"
|
2019-04-09 10:05:42 +00:00
|
|
|
// BucketID is the http query parameter to specify an bucket by ID.
|
|
|
|
BucketID = "bucketID"
|
|
|
|
// Bucket is the http query parameter take either the ID or Name interchangably
|
|
|
|
Bucket = "bucket"
|
2018-09-04 21:08:00 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
// queryOrganization returns the organization for any http request.
|
2019-09-12 18:39:24 +00:00
|
|
|
//
|
|
|
|
// It checks the org= and then orgID= parameter of the request.
|
|
|
|
//
|
|
|
|
// This will try to find the organization using an ID string or
|
|
|
|
// the name. It interprets the &org= parameter as either the name
|
|
|
|
// or the ID.
|
2018-09-04 21:08:00 +00:00
|
|
|
func queryOrganization(ctx context.Context, r *http.Request, svc platform.OrganizationService) (o *platform.Organization, err error) {
|
2019-08-06 04:20:26 +00:00
|
|
|
|
2018-09-04 21:08:00 +00:00
|
|
|
filter := platform.OrganizationFilter{}
|
2019-08-06 04:20:26 +00:00
|
|
|
|
|
|
|
if organization := r.URL.Query().Get(Org); organization != "" {
|
|
|
|
if id, err := platform.IDFromString(organization); err == nil {
|
|
|
|
filter.ID = id
|
|
|
|
} else {
|
|
|
|
filter.Name = &organization
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-09-04 21:08:00 +00:00
|
|
|
if reqID := r.URL.Query().Get(OrgID); reqID != "" {
|
|
|
|
filter.ID, err = platform.IDFromString(reqID)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return svc.FindOrganization(ctx, filter)
|
|
|
|
}
|
2019-04-09 10:05:42 +00:00
|
|
|
|
|
|
|
// queryBucket returns the bucket for any http request.
|
|
|
|
//
|
|
|
|
// It checks the bucket= and then bucketID= parameter of the request.
|
|
|
|
//
|
|
|
|
// This will try to find the bucket using an ID string or
|
|
|
|
// the name. It interprets the &bucket= parameter as either the name
|
|
|
|
// or the ID.
|
|
|
|
func queryBucket(ctx context.Context, r *http.Request, svc platform.BucketService) (b *platform.Bucket, err error) {
|
|
|
|
filter := platform.BucketFilter{}
|
|
|
|
if bucket := r.URL.Query().Get(Bucket); bucket != "" {
|
|
|
|
if id, err := platform.IDFromString(bucket); err == nil {
|
|
|
|
filter.ID = id
|
|
|
|
} else {
|
|
|
|
filter.Name = &bucket
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if reqID := r.URL.Query().Get(BucketID); reqID != "" {
|
|
|
|
filter.ID, err = platform.IDFromString(reqID)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if filter.ID == nil && filter.Name == nil {
|
|
|
|
return nil, &platform.Error{
|
|
|
|
Code: platform.EInvalid,
|
|
|
|
Msg: "Please provide either bucketID or bucket",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return svc.FindBucket(ctx, filter)
|
|
|
|
}
|