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

* Add provisioning to postgres Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Add provisioning to things and channels service Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Add JSON provisioning endpoint to things API Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Add provisioning to SDK and CLI Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Update docs Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Remove response location and adjust channelsFromFile Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Change naming from 'provison' to 'bulkCreate' Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Add gocsv to vendors folder Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Update "bulk" naming Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Move CSV to CLI and remove gocsv dependancy Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Update docs and responses Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Change AddThings to be CreateThings Signed-off-by: Nick Neisen <nwneisen@gmail.com> * Improve test coverage Signed-off-by: nwneisen <nwneisen@gmail.com> * Fixes after review Signed-off-by: nwneisen <nwneisen@gmail.com>
77 lines
2.5 KiB
Go
77 lines
2.5 KiB
Go
// Copyright (c) Mainflux
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
package things
|
|
|
|
import "context"
|
|
|
|
// Metadata to be used for mainflux thing or channel for customized
|
|
// describing of particular thing or channel.
|
|
type Metadata map[string]interface{}
|
|
|
|
// Thing represents a Mainflux thing. Each thing is owned by one user, and
|
|
// it is assigned with the unique identifier and (temporary) access key.
|
|
type Thing struct {
|
|
ID string
|
|
Owner string
|
|
Name string
|
|
Key string
|
|
Metadata Metadata
|
|
}
|
|
|
|
// ThingsPage contains page related metadata as well as list of things that
|
|
// belong to this page.
|
|
type ThingsPage struct {
|
|
PageMetadata
|
|
Things []Thing
|
|
}
|
|
|
|
// ThingRepository specifies a thing persistence API.
|
|
type ThingRepository interface {
|
|
// Save persists the thing. Successful operation is indicated by non-nil
|
|
// error response.
|
|
Save(context.Context, Thing) (string, error)
|
|
|
|
// BulkSave persistest multiple things. Successful operation is indicated by non-nil
|
|
// error response.
|
|
BulkSave(context.Context, []Thing) ([]Thing, error)
|
|
|
|
// Update performs an update to the existing thing. A non-nil error is
|
|
// returned to indicate operation failure.
|
|
Update(context.Context, Thing) error
|
|
|
|
// UpdateKey updates key value of the existing thing. A non-nil error is
|
|
// returned to indicate operation failure.
|
|
UpdateKey(context.Context, string, string, string) error
|
|
|
|
// RetrieveByID retrieves the thing having the provided identifier, that is owned
|
|
// by the specified user.
|
|
RetrieveByID(context.Context, string, string) (Thing, error)
|
|
|
|
// RetrieveByKey returns thing ID for given thing key.
|
|
RetrieveByKey(context.Context, string) (string, error)
|
|
|
|
// RetrieveAll retrieves the subset of things owned by the specified user.
|
|
RetrieveAll(context.Context, string, uint64, uint64, string, Metadata) (ThingsPage, error)
|
|
|
|
// RetrieveByChannel retrieves the subset of things owned by the specified
|
|
// user and connected to specified channel.
|
|
RetrieveByChannel(context.Context, string, string, uint64, uint64) (ThingsPage, error)
|
|
|
|
// Remove removes the thing having the provided identifier, that is owned
|
|
// by the specified user.
|
|
Remove(context.Context, string, string) error
|
|
}
|
|
|
|
// ThingCache contains thing caching interface.
|
|
type ThingCache interface {
|
|
// Save stores pair thing key, thing id.
|
|
Save(context.Context, string, string) error
|
|
|
|
// ID returns thing ID for given key.
|
|
ID(context.Context, string) (string, error)
|
|
|
|
// Removes thing from cache.
|
|
Remove(context.Context, string) error
|
|
}
|