mirror of
https://github.com/mainflux/mainflux.git
synced 2025-05-06 19:29:15 +08:00

* initial commit Signed-off-by: aryan <aryangodara03@gmail.com> * remove unused variables. Signed-off-by: aryan <aryangodara03@gmail.com> * removed temporarily created file. Signed-off-by: aryan <aryangodara03@gmail.com> * Fix failing CI Signed-off-by: aryan <aryangodara03@gmail.com> * Fix thing_test failing cases. Signed-off-by: aryan <aryangodara03@gmail.com> * Remove dead code, debug statements, and add comments. Signed-off-by: aryan <aryangodara03@gmail.com> * Extract errors to separate file. Signed-off-by: aryan <aryangodara03@gmail.com> * Updated things/api/http tests Signed-off-by: aryan <aryangodara03@gmail.com> * Created custom SDK error. Signed-off-by: aryan <aryangodara03@gmail.com> * Changed to using CheckError. All tests passing. Signed-off-by: aryan <aryangodara03@gmail.com> * Replace error interface with errors.SDKError interface. Signed-off-by: aryan <aryangodara03@gmail.com> * Fix failing CI. Signed-off-by: aryan <aryangodara03@gmail.com> * Remove unused sdk errors. Signed-off-by: aryan <aryangodara03@gmail.com> * Change SDKError to error in internal function of sdk package. Signed-off-by: aryan <aryangodara03@gmail.com> * Remove unused error. Signed-off-by: aryan <aryangodara03@gmail.com> * Remove encodeError. All tests working. Signed-off-by: aryan <aryangodara03@gmail.com> * Rename sdkerr vars, convert common strings to constants. Signed-off-by: aryan <aryangodara03@gmail.com> * Change checkerror to take error instead of string. Signed-off-by: aryan <aryangodara03@gmail.com> * Remove unused errors, and removed errfailedwhitelist wrap. Signed-off-by: aryan <aryangodara03@gmail.com> * Removed unused errors, and remove errors.go since it only had a repeated error from errors package Signed-off-by: aryan <aryangodara03@gmail.com> * Remove unused errors. Signed-off-by: aryan <aryangodara03@gmail.com> * Update sdk_error. Signed-off-by: aryan <aryangodara03@gmail.com> * Used function to reduce code for sending and receiving requests. Signed-off-by: aryan <aryangodara03@gmail.com> * Added function sendrequestandgetheadersorerror. Signed-off-by: aryan <aryangodara03@gmail.com> * sdk_error updated. Signed-off-by: aryan <aryangodara03@gmail.com> * Updated function names to processRequest. Signed-off-by: aryan <aryangodara03@gmail.com> * Made errors internal, fixed typo in http. Signed-off-by: aryan <aryangodara03@gmail.com> * Remove empty line. Signed-off-by: aryan <aryangodara03@gmail.com> * merged proceessBody and processHeaders functions in sdk. Signed-off-by: aryan <aryangodara03@gmail.com> * remove sendThingRequest function. Signed-off-by: aryan <aryangodara03@gmail.com> * changed processRequest signature Signed-off-by: aryan <aryangodara03@gmail.com> * changed processRequest signature, changed error names. Signed-off-by: aryan <aryangodara03@gmail.com> Signed-off-by: aryan <aryangodara03@gmail.com> Co-authored-by: Dušan Borovčanin <dusan.borovcanin@mainflux.com>
97 lines
2.3 KiB
Go
97 lines
2.3 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package sdk
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/mainflux/mainflux/pkg/errors"
|
|
)
|
|
|
|
const certsEndpoint = "certs"
|
|
|
|
// Cert represents certs data.
|
|
type Cert struct {
|
|
CACert string `json:"issuing_ca,omitempty"`
|
|
ClientKey string `json:"client_key,omitempty"`
|
|
ClientCert string `json:"client_cert,omitempty"`
|
|
}
|
|
|
|
func (sdk mfSDK) IssueCert(thingID string, keyBits int, keyType, valid, token string) (Cert, errors.SDKError) {
|
|
r := certReq{
|
|
ThingID: thingID,
|
|
KeyBits: keyBits,
|
|
KeyType: keyType,
|
|
Valid: valid,
|
|
}
|
|
d, err := json.Marshal(r)
|
|
if err != nil {
|
|
return Cert{}, errors.NewSDKError(err)
|
|
}
|
|
|
|
url := fmt.Sprintf("%s/%s", sdk.certsURL, certsEndpoint)
|
|
resp, err := request(http.MethodPost, token, url, d)
|
|
if err != nil {
|
|
return Cert{}, errors.NewSDKError(err)
|
|
}
|
|
defer resp.Body.Close()
|
|
|
|
if err := errors.CheckError(resp, http.StatusOK); err != nil {
|
|
return Cert{}, err
|
|
}
|
|
|
|
var c Cert
|
|
if err := json.NewDecoder(resp.Body).Decode(&c); err != nil {
|
|
return Cert{}, errors.NewSDKError(err)
|
|
}
|
|
return c, nil
|
|
}
|
|
|
|
func (sdk mfSDK) RemoveCert(id, token string) errors.SDKError {
|
|
resp, err := request(http.MethodDelete, token, fmt.Sprintf("%s/%s", sdk.certsURL, id), nil)
|
|
if resp != nil {
|
|
resp.Body.Close()
|
|
}
|
|
if err != nil {
|
|
return errors.NewSDKError(err)
|
|
}
|
|
switch resp.StatusCode {
|
|
case http.StatusForbidden:
|
|
return errors.NewSDKError(errors.ErrAuthorization)
|
|
default:
|
|
return errors.CheckError(resp, http.StatusNoContent)
|
|
}
|
|
}
|
|
|
|
func (sdk mfSDK) RevokeCert(thingID, certID string, token string) errors.SDKError {
|
|
panic("not implemented")
|
|
}
|
|
|
|
func request(method, jwt, url string, data []byte) (*http.Response, errors.SDKError) {
|
|
req, err := http.NewRequest(method, url, bytes.NewReader(data))
|
|
if err != nil {
|
|
return nil, errors.NewSDKError(err)
|
|
}
|
|
req.Header.Set("Content-Type", "application/json")
|
|
req.Header.Set("Authorization", jwt)
|
|
c := &http.Client{}
|
|
res, err := c.Do(req)
|
|
if err != nil {
|
|
return nil, errors.NewSDKError(err)
|
|
}
|
|
|
|
return res, nil
|
|
}
|
|
|
|
type certReq struct {
|
|
ThingID string `json:"thing_id"`
|
|
KeyBits int `json:"key_bits"`
|
|
KeyType string `json:"key_type"`
|
|
Encryption string `json:"encryption"`
|
|
Valid string `json:"valid"`
|
|
}
|