Documentation ¶
Index ¶
- func FromAMQPMessage(msg *amqp.Message) *common.Message
- func ParseConnectionString(cs string) (*common.SharedAccessKey, error)
- type AckType
- type AuthType
- type Authentication
- type BadRequestError
- type BulkError
- type BulkResult
- type Client
- func (c *Client) ApplyConfigurationContentOnDevice(ctx context.Context, deviceID string, content *ConfigurationContent) error
- func (c *Client) CallDeviceMethod(ctx context.Context, deviceID string, call *MethodCall) (*MethodResult, error)
- func (c *Client) CallModuleMethod(ctx context.Context, deviceID, moduleID string, call *MethodCall) (*MethodResult, error)
- func (c *Client) CancelJob(ctx context.Context, jobID string) (map[string]interface{}, error)
- func (c *Client) CancelJobV2(ctx context.Context, jobID string) (*JobV2, error)
- func (c *Client) Close() error
- func (c *Client) CreateConfiguration(ctx context.Context, config *Configuration) (*Configuration, error)
- func (c *Client) CreateDevice(ctx context.Context, device *Device) (*Device, error)
- func (c *Client) CreateDevices(ctx context.Context, devices []*Device) (*BulkResult, error)
- func (c *Client) CreateJob(ctx context.Context, job *Job) (map[string]interface{}, error)
- func (c *Client) CreateJobV2(ctx context.Context, job *JobV2) (*JobV2, error)
- func (c *Client) CreateModule(ctx context.Context, module *Module) (*Module, error)
- func (c *Client) DeleteConfiguration(ctx context.Context, config *Configuration) error
- func (c *Client) DeleteDevice(ctx context.Context, device *Device) error
- func (c *Client) DeleteDevices(ctx context.Context, devices []*Device, force bool) (*BulkResult, error)
- func (c *Client) DeleteModule(ctx context.Context, module *Module) error
- func (c *Client) DeviceConnectionString(device *Device, secondary bool) (string, error)
- func (c *Client) DeviceSAS(device *Device, resource string, duration time.Duration, secondary bool) (string, error)
- func (c *Client) GetConfiguration(ctx context.Context, configID string) (*Configuration, error)
- func (c *Client) GetDevice(ctx context.Context, deviceID string) (*Device, error)
- func (c *Client) GetDeviceTwin(ctx context.Context, deviceID string) (*Twin, error)
- func (c *Client) GetJob(ctx context.Context, jobID string) (map[string]interface{}, error)
- func (c *Client) GetJobV2(ctx context.Context, jobID string) (*JobV2, error)
- func (c *Client) GetModule(ctx context.Context, deviceID, moduleID string) (*Module, error)
- func (c *Client) GetModuleTwin(ctx context.Context, deviceID, moduleID string) (*ModuleTwin, error)
- func (c *Client) HostName() string
- func (c *Client) ListConfigurations(ctx context.Context) ([]*Configuration, error)
- func (c *Client) ListDevices(ctx context.Context) ([]*Device, error)
- func (c *Client) ListJobs(ctx context.Context) ([]map[string]interface{}, error)
- func (c *Client) ListModules(ctx context.Context, deviceID string) ([]*Module, error)
- func (c *Client) ModuleConnectionString(module *Module, secondary bool) (string, error)
- func (c *Client) QueryDevices(ctx context.Context, query string, fn func(v map[string]interface{}) error) error
- func (c *Client) QueryJobsV2(ctx context.Context, q *JobV2Query, fn func(*JobV2) error) error
- func (c *Client) SendEvent(ctx context.Context, deviceID string, payload []byte, opts ...SendOption) error
- func (c *Client) Stats(ctx context.Context) (*Stats, error)
- func (c *Client) SubscribeEvents(ctx context.Context, fn EventHandler, consumerGroup string) error
- func (c *Client) SubscribeFeedback(ctx context.Context, fn FeedbackHandler) error
- func (c *Client) SubscribeFileNotifications(ctx context.Context, fn FileNotificationHandler) error
- func (c *Client) UpdateConfiguration(ctx context.Context, config *Configuration) (*Configuration, error)
- func (c *Client) UpdateDevice(ctx context.Context, device *Device) (*Device, error)
- func (c *Client) UpdateDeviceTwin(ctx context.Context, twin *Twin) (*Twin, error)
- func (c *Client) UpdateDevices(ctx context.Context, devices []*Device, force bool) (*BulkResult, error)
- func (c *Client) UpdateModule(ctx context.Context, module *Module) (*Module, error)
- func (c *Client) UpdateModuleTwin(ctx context.Context, twin *ModuleTwin) (*ModuleTwin, error)
- type ClientOption
- type Configuration
- type ConfigurationContent
- type ConfigurationMetrics
- type ConnectionState
- type Device
- type DeviceMethodParams
- type DeviceStatus
- type Event
- type EventHandler
- type Feedback
- type FeedbackHandler
- type FileNotification
- type FileNotificationHandler
- type Job
- type JobType
- type JobV2
- type JobV2Query
- type JobV2Status
- type JobV2Type
- type MethodCall
- type MethodResult
- type MicrosoftTime
- type Module
- type ModuleTwin
- type Properties
- type RequestError
- type SendOption
- func WithSendAck(ack AckType) SendOption
- func WithSendCorrelationID(cid string) SendOption
- func WithSendExpiryTime(t time.Time) SendOption
- func WithSendMessageID(mid string) SendOption
- func WithSendProperties(m map[string]string) SendOption
- func WithSendProperty(k, v string) SendOption
- func WithSendUserID(uid string) SendOption
- type Stats
- type SymmetricKey
- type Twin
- type X509Thumbprint
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func FromAMQPMessage ¶
FromAMQPMessage converts a amqp.Message into common.Message.
Exported to use with a custom stream when devices telemetry is routed for example to an EventhHub instance.
func ParseConnectionString ¶
func ParseConnectionString(cs string) (*common.SharedAccessKey, error)
Types ¶
type AckType ¶
type AckType string
AckType is event feedback acknowledgement type.
const ( // AckNone no feedback. AckNone AckType = "none" // AckPositive receive a feedback message if the message was completed. AckPositive AckType = "positive" // AckNegative receive a feedback message if the message expired // (or maximum delivery count was reached) without being completed by the device. AckNegative AckType = "negative" // AckFull both positive and negative. AckFull AckType = "full" )
type Authentication ¶
type Authentication struct { SymmetricKey *SymmetricKey `json:"symmetricKey,omitempty"` X509Thumbprint *X509Thumbprint `json:"x509Thumbprint,omitempty"` Type AuthType `json:"type,omitempty"` }
type BadRequestError ¶
type BadRequestError struct { Message string `json:"Message"` ExceptionMessage string `json:"ExceptionMessage"` }
func (*BadRequestError) Error ¶
func (e *BadRequestError) Error() string
type BulkResult ¶
type Client ¶
type Client struct {
// contains filtered or unexported fields
}
Client is IoT Hub service client.
func New ¶
func New(sak *common.SharedAccessKey, opts ...ClientOption) (*Client, error)
New creates new iothub service client.
func NewFromConnectionString ¶
func NewFromConnectionString(cs string, opts ...ClientOption) (*Client, error)
func (*Client) ApplyConfigurationContentOnDevice ¶
func (*Client) CallDeviceMethod ¶
func (c *Client) CallDeviceMethod( ctx context.Context, deviceID string, call *MethodCall, ) (*MethodResult, error)
func (*Client) CallModuleMethod ¶
func (c *Client) CallModuleMethod( ctx context.Context, deviceID, moduleID string, call *MethodCall, ) (*MethodResult, error)
func (*Client) CancelJobV2 ¶
func (*Client) CreateConfiguration ¶
func (c *Client) CreateConfiguration(ctx context.Context, config *Configuration) ( *Configuration, error, )
CreateConfiguration adds the given configuration to the registry.
func (*Client) CreateDevice ¶
CreateDevice creates a new device.
func (*Client) CreateDevices ¶
CreateDevices creates array of devices in bulk mode.
func (*Client) CreateJob ¶
CreateJob creates import / export jobs.
https://docs.microsoft.com/en-us/azure/iot-hub/iot-hub-bulk-identity-mgmt#get-the-container-sas-uri
func (*Client) CreateJobV2 ¶
func (*Client) CreateModule ¶
CreateModule adds the given module to the registry.
func (*Client) DeleteConfiguration ¶
func (c *Client) DeleteConfiguration(ctx context.Context, config *Configuration) error
DeleteConfiguration removes the given configuration from the registry.
func (*Client) DeleteDevice ¶
DeleteDevice deletes the named device.
func (*Client) DeleteDevices ¶
func (c *Client) DeleteDevices( ctx context.Context, devices []*Device, force bool, ) (*BulkResult, error)
DeleteDevices deletes array of devices in bulk mode.
func (*Client) DeleteModule ¶
DeleteModule removes the named device module.
func (*Client) DeviceConnectionString ¶
DeviceConnectionString builds up a connection string for the given device.
func (*Client) DeviceSAS ¶
func (c *Client) DeviceSAS( device *Device, resource string, duration time.Duration, secondary bool, ) (string, error)
DeviceSAS generates a GenerateToken token for the named device.
Resource shouldn't include hostname.
func (*Client) GetConfiguration ¶
GetConfiguration gets the named configuration from the registry.
func (*Client) GetDeviceTwin ¶
GetDeviceTwin retrieves the named twin device from the registry.
func (*Client) GetModuleTwin ¶
func (c *Client) GetModuleTwin(ctx context.Context, deviceID, moduleID string) ( *ModuleTwin, error, )
GetModuleTwin retrieves the named module's path.
func (*Client) ListConfigurations ¶
func (c *Client) ListConfigurations(ctx context.Context) ([]*Configuration, error)
ListConfigurations gets all available configurations from the registry.
func (*Client) ListDevices ¶
ListDevices lists all registered devices.
func (*Client) ListModules ¶
ListModules list all the registered modules on the named device.
func (*Client) ModuleConnectionString ¶
func (*Client) QueryDevices ¶
func (*Client) QueryJobsV2 ¶
func (*Client) SendEvent ¶
func (c *Client) SendEvent( ctx context.Context, deviceID string, payload []byte, opts ...SendOption, ) error
SendEvent sends the given cloud-to-device message and returns its id. Panics when event is nil.
func (*Client) SubscribeEvents ¶
SubscribeEvents subscribes to D2C events.
Event handler is blocking, handle asynchronous processing on your own.
func (*Client) SubscribeFeedback ¶
func (c *Client) SubscribeFeedback(ctx context.Context, fn FeedbackHandler) error
SubscribeFeedback subscribes to feedback of messages that ack was requested.
func (*Client) SubscribeFileNotifications ¶
func (c *Client) SubscribeFileNotifications( ctx context.Context, fn FileNotificationHandler, ) error
SubscribeFileNotifications subscribes to file notifications.
The feature has to be enabled in the console.
func (*Client) UpdateConfiguration ¶
func (c *Client) UpdateConfiguration(ctx context.Context, config *Configuration) ( *Configuration, error, )
UpdateConfiguration updates the given configuration in the registry.
func (*Client) UpdateDevice ¶
UpdateDevice updates the named device.
func (*Client) UpdateDeviceTwin ¶
UpdateDeviceTwin updates the named twin desired properties.
func (*Client) UpdateDevices ¶
func (c *Client) UpdateDevices( ctx context.Context, devices []*Device, force bool, ) (*BulkResult, error)
UpdateDevices updates array of devices in bulk mode.
func (*Client) UpdateModule ¶
UpdateModule updates the given module.
func (*Client) UpdateModuleTwin ¶
func (c *Client) UpdateModuleTwin(ctx context.Context, twin *ModuleTwin) ( *ModuleTwin, error, )
UpdateModuleTwin updates the named module twin's desired attributes.
type ClientOption ¶
type ClientOption func(c *Client)
ClientOption is a client configuration option.
func WithHTTPClient ¶
func WithHTTPClient(client *http.Client) ClientOption
WithHTTPClient changes default http rest client.
func WithTLSConfig ¶
func WithTLSConfig(config *tls.Config) ClientOption
WithTLSConfig sets TLS config that's used by REST HTTP and AMQP clients.
type Configuration ¶
type Configuration struct { ID string `json:"id,omitempty"` SchemaVersion string `json:"schemaVersion,omitempty"` Labels map[string]string `json:"labels,omitempty"` Content *ConfigurationContent `json:"content,omitempty"` TargetCondition string `json:"targetCondition,omitempty"` CreatedTimeUTC *time.Time `json:"createdTimeUtc,omitempty"` LastUpdatedTimeUTC *time.Time `json:"lastUpdatedTimeUtc,omitempty"` Priority uint `json:"priority,omitempty"` SystemMetrics *ConfigurationMetrics `json:"systemMetrics,omitempty"` Metrics *ConfigurationMetrics `json:"metrics,omitempty"` ETag string `json:"etag,omitempty"` }
type ConfigurationContent ¶
type ConfigurationMetrics ¶
type ConnectionState ¶
type ConnectionState string
const ( Connected ConnectionState = "Connected" Disconnected ConnectionState = "Disconnected" )
type Device ¶
type Device struct { DeviceID string `json:"deviceId,omitempty"` GenerationID string `json:"generationId,omitempty"` ETag string `json:"etag,omitempty"` ConnectionState ConnectionState `json:"connectionState,omitempty"` Status DeviceStatus `json:"status,omitempty"` StatusReason string `json:"statusReason,omitempty"` ConnectionStateUpdatedTime *MicrosoftTime `json:"connectionStateUpdatedTime,omitempty"` StatusUpdatedTime *MicrosoftTime `json:"statusUpdatedTime,omitempty"` LastActivityTime *MicrosoftTime `json:"lastActivityTime,omitempty"` CloudToDeviceMessageCount uint `json:"cloudToDeviceMessageCount,omitempty"` Authentication *Authentication `json:"authentication,omitempty"` Capabilities map[string]interface{} `json:"capabilities,omitempty"` }
type DeviceMethodParams ¶
type DeviceStatus ¶
type DeviceStatus string
const ( Enabled DeviceStatus = "enabled" Disabled DeviceStatus = "disabled" )
type EventHandler ¶
EventHandler handles incoming cloud-to-device events.
type Feedback ¶
type Feedback struct { OriginalMessageID string `json:"originalMessageId"` Description string `json:"description"` DeviceGenerationID string `json:"deviceGenerationId"` DeviceID string `json:"deviceId"` EnqueuedTimeUTC time.Time `json:"enqueuedTimeUtc"` StatusCode string `json:"statusCode"` }
Feedback is message feedback.
type FeedbackHandler ¶
FeedbackHandler handles message feedback.
type FileNotification ¶
FileNotification is emitted once a blob file is uploaded to the hub.
TODO: structure is yet to define.
type FileNotificationHandler ¶
type FileNotificationHandler func(event *FileNotification) error
FileNotificationHandler handles file upload notifications.
type JobV2 ¶
type JobV2 struct { JobID string `json:"jobId"` Type JobV2Type `json:"type"` Status JobV2Status `json:"status,omitempty"` CloudToDeviceMethod *DeviceMethodParams `json:"cloudToDeviceMethod,omitempty"` UpdateTwin interface{} `json:"updateTwin,omitempty"` QueryCondition string `json:"queryCondition"` StartTime time.Time `json:"startTime"` MaxExecutionTimeInSeconds uint `json:"maxExecutionTimeInSeconds"` }
type JobV2Query ¶
type JobV2Query struct { Type JobV2Type Status JobV2Status PageSize uint }
type JobV2Status ¶
type JobV2Status string
const ( JobStatusUnknown JobV2Status = "unknown" JobStatusQueued JobV2Status = "queued" JobStatusScheduled JobV2Status = "scheduled" JobStatusRunning JobV2Status = "running" JobStatusCancelled JobV2Status = "cancelled" JobStatusCompleted JobV2Status = "completed" )
type MethodCall ¶
type MethodResult ¶
type MicrosoftTime ¶
MicrosoftTime is a hack to parse time json attributes that don't follow RFC3339 and don't put timezone at the end of timestamp.
func (*MicrosoftTime) UnmarshalJSON ¶
func (t *MicrosoftTime) UnmarshalJSON(b []byte) error
type Module ¶
type Module struct { ModuleID string `json:"moduleId,omitempty"` DeviceID string `json:"deviceId,omitempty"` GenerationID string `json:"generationId,omitempty"` ETag string `json:"etag,omitempty"` ConnectionState ConnectionState `json:"connectionState,omitempty"` ConnectionStateUpdatedTime *MicrosoftTime `json:"connectionStateUpdatedTime,omitempty"` LastActivityTime *MicrosoftTime `json:"lastActivityTime,omitempty"` CloudToDeviceMessageCount uint `json:"cloudToDeviceMessageCount,omitempty"` Authentication *Authentication `json:"authentication,omitempty"` ManagedBy string `json:"managedBy,omitempty"` }
type ModuleTwin ¶
type ModuleTwin struct { DeviceID string `json:"deviceId,omitempty"` ModuleID string `json:"moduleId,omitempty"` ETag string `json:"etag,omitempty"` DeviceETag string `json:"deviceEtag,omitempty"` Status DeviceStatus `json:"status,omitempty"` StatusUpdateTime *MicrosoftTime `json:"statusUpdateTime,omitempty"` ConnectionState ConnectionState `json:"connectionState,omitempty"` LastActivityTime *MicrosoftTime `json:"lastActivityTime,omitempty"` AuthenticationType string `json:"authenticationType,omitempty"` X509Thumbprint *X509Thumbprint `json:"x509Thumbprint,omitempty"` Version uint `json:"version,omitempty"` Properties *Properties `json:"properties,omitempty"` }
type Properties ¶
type RequestError ¶
RequestError is an API request error.
Response body is already read out to Body attribute, so there's no need read it manually and call `e.Res.Body.Close()`
func (*RequestError) Error ¶
func (e *RequestError) Error() string
type SendOption ¶
SendOption is a send option.
func WithSendAck ¶
func WithSendAck(ack AckType) SendOption
WithSendAck sets message confirmation type.
func WithSendCorrelationID ¶
func WithSendCorrelationID(cid string) SendOption
WithSendCorrelationID sets correlation id.
func WithSendExpiryTime ¶
func WithSendExpiryTime(t time.Time) SendOption
WithSendExpiryTime sets message expiration time.
func WithSendMessageID ¶
func WithSendMessageID(mid string) SendOption
WithSendMessageID sets message id.
func WithSendProperties ¶
func WithSendProperties(m map[string]string) SendOption
WithSendProperties same as `WithSendProperty` but accepts map of keys and values.
func WithSendProperty ¶
func WithSendProperty(k, v string) SendOption
WithSendProperty sets a message property.
type SymmetricKey ¶
type Twin ¶
type Twin struct { DeviceID string `json:"deviceId,omitempty"` ETag string `json:"etag,omitempty"` DeviceETag string `json:"deviceEtag,omitempty"` Status DeviceStatus `json:"status,omitempty"` StatusReason string `json:"statusReason,omitempty"` StatusUpdateTime *MicrosoftTime `json:"statusUpdateTime,omitempty"` ConnectionState ConnectionState `json:"connectionState,omitempty"` LastActivityTime *MicrosoftTime `json:"lastActivityTime,omitempty"` CloudToDeviceMessageCount uint `json:"cloudToDeviceMessageCount,omitempty"` AuthenticationType string `json:"authenticationType,omitempty"` X509Thumbprint *X509Thumbprint `json:"x509Thumbprint,omitempty"` Version int `json:"version,omitempty"` Tags map[string]interface{} `json:"tags,omitempty"` Properties *Properties `json:"properties,omitempty"` Capabilities map[string]interface{} `json:"capabilities,omitempty"` }