mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-29 13:49:28 +08:00

* Add resetPassword to the SDK Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add space to sdk comments Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add tab space to comments Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update .env file Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add referer header to sdk request Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update .env file Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update adding headers to processRequest Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * remove code repetition Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add comment to content-Type Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update header initialization Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update docker-compose file Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add cli functionality Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add host as a tag Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update hostURL flag Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update comments Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * remove hostURL duplication Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update inline Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add space in comments Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * add space in comment Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> * update description of reset password request Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> --------- Signed-off-by: ianmuchyri <ianmuchiri8@gmail.com> Co-authored-by: Drasko DRASKOVIC <drasko.draskovic@gmail.com>
106 lines
2.4 KiB
Go
106 lines
2.4 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package sdk
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"net/http"
|
|
"time"
|
|
|
|
"github.com/mainflux/mainflux/pkg/errors"
|
|
)
|
|
|
|
const (
|
|
certsEndpoint = "certs"
|
|
serialsEndpoint = "serials"
|
|
)
|
|
|
|
// Cert represents certs data.
|
|
type Cert struct {
|
|
ThingID string `json:"thing_id,omitempty"`
|
|
CertSerial string `json:"cert_serial,omitempty"`
|
|
ClientKey string `json:"client_key,omitempty"`
|
|
ClientCert string `json:"client_cert,omitempty"`
|
|
Expiration time.Time `json:"expiration,omitempty"`
|
|
}
|
|
|
|
func (sdk mfSDK) IssueCert(thingID, valid, token string) (Cert, errors.SDKError) {
|
|
r := certReq{
|
|
ThingID: thingID,
|
|
Valid: valid,
|
|
}
|
|
d, err := json.Marshal(r)
|
|
if err != nil {
|
|
return Cert{}, errors.NewSDKError(err)
|
|
}
|
|
|
|
url := fmt.Sprintf("%s/%s", sdk.certsURL, certsEndpoint)
|
|
|
|
_, body, sdkerr := sdk.processRequest(http.MethodPost, url, token, d, nil, http.StatusCreated)
|
|
if sdkerr != nil {
|
|
return Cert{}, sdkerr
|
|
}
|
|
|
|
var c Cert
|
|
if err := json.Unmarshal(body, &c); err != nil {
|
|
return Cert{}, errors.NewSDKError(err)
|
|
}
|
|
|
|
return c, nil
|
|
}
|
|
|
|
func (sdk mfSDK) ViewCert(id, token string) (Cert, errors.SDKError) {
|
|
url := fmt.Sprintf("%s/%s/%s", sdk.certsURL, certsEndpoint, id)
|
|
|
|
_, body, err := sdk.processRequest(http.MethodGet, url, token, nil, nil, http.StatusOK)
|
|
if err != nil {
|
|
return Cert{}, err
|
|
}
|
|
|
|
var cert Cert
|
|
if err := json.Unmarshal(body, &cert); err != nil {
|
|
return Cert{}, errors.NewSDKError(err)
|
|
}
|
|
|
|
return cert, nil
|
|
}
|
|
|
|
func (sdk mfSDK) ViewCertByThing(thingID, token string) (CertSerials, errors.SDKError) {
|
|
url := fmt.Sprintf("%s/%s/%s", sdk.certsURL, serialsEndpoint, thingID)
|
|
|
|
_, body, err := sdk.processRequest(http.MethodGet, url, token, nil, nil, http.StatusOK)
|
|
if err != nil {
|
|
return CertSerials{}, err
|
|
}
|
|
|
|
var cs CertSerials
|
|
if err := json.Unmarshal(body, &cs); err != nil {
|
|
return CertSerials{}, errors.NewSDKError(err)
|
|
}
|
|
|
|
return cs, nil
|
|
}
|
|
|
|
func (sdk mfSDK) RevokeCert(id, token string) (time.Time, errors.SDKError) {
|
|
url := fmt.Sprintf("%s/%s/%s", sdk.certsURL, certsEndpoint, id)
|
|
|
|
_, body, err := sdk.processRequest(http.MethodDelete, url, token, nil, nil, http.StatusOK)
|
|
if err != nil {
|
|
return time.Time{}, err
|
|
}
|
|
|
|
var rcr revokeCertsRes
|
|
if err := json.Unmarshal(body, &rcr); err != nil {
|
|
return time.Time{}, errors.NewSDKError(err)
|
|
}
|
|
|
|
return rcr.RevocationTime, nil
|
|
}
|
|
|
|
type certReq struct {
|
|
ThingID string `json:"thing_id"`
|
|
Valid string `json:"ttl"`
|
|
}
|