data

package
v1.0.0-beta.4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 3, 2020 License: Apache-2.0 Imports: 21 Imported by: 2

Documentation

Overview

Package data implements Data API

Index

Constants

View Source
const (
	INFLUXDB   = "influxdb"
	MONGODB    = "mongodb"
	SENMLSTORE = "senmlstore"
)
View Source
const (
	MaxPerPage = 1000
)

Variables

This section is empty.

Functions

func GetUrlFromQuery

func GetUrlFromQuery(q Query, id ...string) (url string)

func SupportedBackends added in v0.6.1

func SupportedBackends(name string) bool

SupportedBackends returns true if the backend is listed as true

Types

type API added in v0.6.1

type API struct {
	// contains filtered or unexported fields
}

API describes the RESTful HTTP data API

func NewAPI added in v0.6.1

func NewAPI(registry registry.Storage, storage Storage, autoRegistration bool) *API

NewAPI returns the configured Data API

func (*API) Query added in v0.6.1

func (api *API) Query(w http.ResponseWriter, r *http.Request)

Query is a handler for querying data Expected parameters: id(s), optional: pagination, query string

func (*API) Submit added in v0.6.1

func (api *API) Submit(w http.ResponseWriter, r *http.Request)

Submit is a handler for submitting a new data point Expected parameters: id(s)

func (*API) SubmitWithoutID added in v0.6.1

func (api *API) SubmitWithoutID(w http.ResponseWriter, r *http.Request)

SubmitWithoutID is a handler for submitting a new data point Expected parameters: none

type LightdbStorage

type LightdbStorage struct {
	// contains filtered or unexported fields
}

func NewSenmlStorage

func NewSenmlStorage(conf common.DataConf) (storage *LightdbStorage, disconnect_func func() error, err error)

func (*LightdbStorage) CreateHandler

func (s *LightdbStorage) CreateHandler(ds registry.DataStream) error

CreateHandler handles the creation of a new data source

func (*LightdbStorage) DeleteHandler

func (s *LightdbStorage) DeleteHandler(ds registry.DataStream) error

DeleteHandler handles deletion of a data source

func (*LightdbStorage) Disconnect

func (s *LightdbStorage) Disconnect() error

func (*LightdbStorage) Query

func (s *LightdbStorage) Query(q Query, sources ...*registry.DataStream) (senml.Pack, int, *time.Time, error)

func (*LightdbStorage) Submit

func (s *LightdbStorage) Submit(data map[string]senml.Pack) error

func (*LightdbStorage) UpdateHandler

func (s *LightdbStorage) UpdateHandler(oldDS registry.DataStream, newDS registry.DataStream) error

UpdateHandler handles updates of a data source

type MQTTConnector

type MQTTConnector struct {
	sync.Mutex
	// contains filtered or unexported fields
}

func NewMQTTConnector

func NewMQTTConnector(storage Storage, clientID string) (*MQTTConnector, error)

func (*MQTTConnector) CreateHandler added in v0.6.1

func (c *MQTTConnector) CreateHandler(ds registry.DataStream) error

CreateHandler handles the creation of a new data source

func (*MQTTConnector) DeleteHandler added in v0.6.1

func (c *MQTTConnector) DeleteHandler(oldDS registry.DataStream) error

DeleteHandler handles deletion of a data source

func (*MQTTConnector) Start added in v0.6.1

func (c *MQTTConnector) Start(reg registry.Storage) error

func (*MQTTConnector) UpdateHandler added in v0.6.1

func (c *MQTTConnector) UpdateHandler(oldDS registry.DataStream, newDS registry.DataStream) error

UpdateHandler handles updates of a data source

type Manager

type Manager struct {
	// contains filtered or unexported fields
}

type Query

type Query struct {
	From   time.Time
	To     time.Time
	Sort   string
	Offset time.Time
	Limit  int

	Denormalize datastore.DenormMask
	// contains filtered or unexported fields
}

func ParseQueryParameters

func ParseQueryParameters(form url.Values) (Query, error)

type RecordSet

type RecordSet struct {
	// SelfLink is the SelfLink of the returned recordset in the Data API
	SelfLink string `json:"selfLink"`
	// Data is a SenML object with data records, where
	// Name (bn and n) constitute the resource BrokerURL of the corresponding Data Sources(s)
	Data senml.Pack `json:"data"`
	// Time is the time of query in seconds
	TimeTook float64 `json:"took"`
	//Next link for the same query, in case there more entries to follow for the same query
	NextLink string `json:"nextLink,omitempty"`
}

RecordSet describes the recordset returned on querying the Data API

type RemoteClient

type RemoteClient struct {
	// contains filtered or unexported fields
}

func NewRemoteClient

func NewRemoteClient(serverEndpoint string, ticket *obtainer.Client) (*RemoteClient, error)

func (*RemoteClient) Query

func (c *RemoteClient) Query(q Query, id ...string) (*RecordSet, error)

func (*RemoteClient) Submit

func (c *RemoteClient) Submit(data []byte, contentType string, id ...string) error

Submit data for ingestion, where: data - is a byte array with actual data contentType - mime-type of the data (will be set in the header) id... - ID (or array of IDs) of data sources for which the data is being submitted

type Storage

type Storage interface {
	// Adds data points for multiple data sources
	// data is a map where keys are data source ids
	// sources is a map where keys are data source ids
	Submit(data map[string]senml.Pack) error

	// Queries data for specified data sources
	//Query(q Query, page, perPage int, sources ...*registry.DataSource) (senml.Pack, int, error)
	Query(q Query, sources ...*registry.DataStream) (senml.Pack, int, *time.Time, error)

	// EventListener includes methods for event handling
	registry.EventListener
}

Storage is an interface of a Data storage backend

type Subscription

type Subscription struct {
	// contains filtered or unexported fields
}

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL