1
0
mirror of https://github.com/mainflux/mainflux.git synced 2025-04-26 13:48:53 +08:00
Filip Bugarski 4f56986c8e
NOISSUE - Add API keys functions to CLI (#1537)
* Add API keys to cli

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Fix typo

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Fix issue func, and sdk

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Remove email, hide type and fix name

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Remove type and add README

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Fix issue response

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Fix magic number and move struct to private

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Remove const and import auth

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

* Removing auth

Signed-off-by: Filip Bugarski <filipbugarski@gmail.com>

Co-authored-by: Dušan Borovčanin <dusan.borovcanin@mainflux.com>
2022-01-27 15:42:31 +01:00

115 lines
2.4 KiB
Go

package sdk
import (
"bytes"
"encoding/json"
"fmt"
"io/ioutil"
"net/http"
"time"
"github.com/mainflux/mainflux/pkg/errors"
)
type keyReq struct {
Type uint32 `json:"type,omitempty"`
Duration time.Duration `json:"duration,omitempty"`
}
const keysEndpoint = "keys"
const (
// LoginKey is temporary User key received on successfull login.
LoginKey uint32 = iota
// RecoveryKey represents a key for resseting password.
RecoveryKey
// APIKey enables the one to act on behalf of the user.
APIKey
)
func (sdk mfSDK) Issue(token string, d time.Duration) (KeyRes, error) {
datareq := keyReq{Type: APIKey, Duration: d}
data, err := json.Marshal(datareq)
if err != nil {
return KeyRes{}, err
}
url := fmt.Sprintf("%s/%s", sdk.authURL, keysEndpoint)
req, err := http.NewRequest(http.MethodPost, url, bytes.NewReader(data))
if err != nil {
return KeyRes{}, err
}
resp, err := sdk.sendRequest(req, token, string(CTJSON))
if err != nil {
return KeyRes{}, err
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
return KeyRes{}, err
}
if resp.StatusCode != http.StatusCreated {
return KeyRes{}, errors.Wrap(ErrFailedCreation, errors.New(resp.Status))
}
var key KeyRes
if err := json.Unmarshal(body, &key); err != nil {
return KeyRes{}, err
}
return key, nil
}
func (sdk mfSDK) Revoke(id, token string) error {
url := fmt.Sprintf("%s/%s/%s", sdk.authURL, keysEndpoint, id)
req, err := http.NewRequest(http.MethodDelete, url, nil)
if err != nil {
return err
}
resp, err := sdk.sendRequest(req, token, string(CTJSON))
if err != nil {
return err
}
if resp.StatusCode != http.StatusNoContent {
return errors.Wrap(ErrFailedRemoval, errors.New(resp.Status))
}
return nil
}
func (sdk mfSDK) RetrieveKey(id, token string) (retrieveKeyRes, error) {
url := fmt.Sprintf("%s/%s/%s", sdk.authURL, keysEndpoint, id)
req, err := http.NewRequest(http.MethodGet, url, nil)
if err != nil {
return retrieveKeyRes{}, err
}
resp, err := sdk.sendRequest(req, token, string(CTJSON))
if err != nil {
return retrieveKeyRes{}, err
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
return retrieveKeyRes{}, err
}
if resp.StatusCode != http.StatusOK {
return retrieveKeyRes{}, errors.Wrap(ErrFailedFetch, errors.New(resp.Status))
}
var key retrieveKeyRes
if err := json.Unmarshal(body, &key); err != nil {
return retrieveKeyRes{}, err
}
return key, nil
}