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

* initial commit update api docs Signed-off-by: rodneyosodo <socials@rodneyosodo.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * initial commit enrich sdk Signed-off-by: rodneyosodo <socials@rodneyosodo.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * initial commit enrich cli Signed-off-by: rodneyosodo <socials@rodneyosodo.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * add consumers test Signed-off-by: rodneyosodo <socials@rodneyosodo.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * remove dead code Signed-off-by: rodneyosodo <socials@rodneyosodo.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * add certs sdk tests Signed-off-by: rodneyosodo <socials@rodneyosodo.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * change contact name Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * fix tests Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * Rename Disconnect Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * Fix subscription typo Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * Fix Swagger File Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * Add Tests Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * Change Limit to 10 Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * Remove empty line Signed-off-by: rodneyosodo <blackd0t@protonmail.com> --------- Signed-off-by: rodneyosodo <socials@rodneyosodo.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com> Co-authored-by: rodneyosodo <socials@rodneyosodo.com>
101 lines
2.5 KiB
Go
101 lines
2.5 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, string(CTJSON), d, 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, string(CTJSON), 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, string(CTJSON), 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, string(CTJSON), 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"`
|
|
}
|