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) 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 Deployment
- type DeploymentContent
- 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 ¶ added in v0.4.0
func ParseConnectionString(cs string) (*common.SharedAccessKey, error)
Types ¶
type AckType ¶ added in v0.3.0
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 ¶ added in v0.4.0
type BadRequestError struct { Message string `json:"Message"` ExceptionMessage string `json:"ExceptionMessage"` }
func (*BadRequestError) Error ¶ added in v0.4.0
func (e *BadRequestError) Error() string
type BulkResult ¶ added in v0.3.0
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 ¶ added in v0.4.0
func NewFromConnectionString(cs string, opts ...ClientOption) (*Client, error)
func (*Client) ApplyConfigurationContentOnDevice ¶ added in v0.2.0
func (*Client) CallDeviceMethod ¶ added in v0.2.0
func (c *Client) CallDeviceMethod( ctx context.Context, deviceID string, call *MethodCall, ) (*MethodResult, error)
func (*Client) CallModuleMethod ¶ added in v0.2.0
func (c *Client) CallModuleMethod( ctx context.Context, deviceID, moduleID string, call *MethodCall, ) (*MethodResult, error)
func (*Client) CancelJobV2 ¶ added in v0.4.0
func (*Client) CreateConfiguration ¶ added in v0.2.0
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 ¶ added in v0.3.0
CreateDevices creates array of devices in bulk mode.
func (*Client) CreateJob ¶ added in v0.2.0
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 ¶ added in v0.4.0
func (*Client) CreateModule ¶ added in v0.2.0
CreateModule adds the given module to the registry.
func (*Client) DeleteConfiguration ¶ added in v0.2.0
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 ¶ added in v0.3.0
func (c *Client) DeleteDevices( ctx context.Context, devices []*Device, force bool, ) (*BulkResult, error)
DeleteDevices deletes array of devices in bulk mode.
func (*Client) DeleteModule ¶ added in v0.2.0
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 ¶ added in v0.2.0
GetConfiguration gets the named configuration from the registry.
func (*Client) GetDeviceTwin ¶ added in v0.2.0
GetDeviceTwin retrieves the named twin device from the registry.
func (*Client) GetModuleTwin ¶ added in v0.2.0
func (c *Client) GetModuleTwin(ctx context.Context, deviceID, moduleID string) ( *ModuleTwin, error, )
GetModuleTwin retrieves the named module's path.
func (*Client) ListConfigurations ¶ added in v0.2.0
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 ¶ added in v0.2.0
ListModules list all the registered modules on the named device.
func (*Client) ModuleConnectionString ¶ added in v0.2.0
func (*Client) QueryDevices ¶ added in v0.2.0
func (*Client) QueryJobsV2 ¶ added in v0.4.0
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 ¶
func (c *Client) SubscribeEvents(ctx context.Context, fn EventHandler) error
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 ¶ added in v0.3.0
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 ¶ added in v0.2.0
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 ¶ added in v0.2.0
UpdateDeviceTwin updates the named twin desired properties.
func (*Client) UpdateDevices ¶ added in v0.3.0
func (c *Client) UpdateDevices( ctx context.Context, devices []*Device, force bool, ) (*BulkResult, error)
UpdateDevices updates array of devices in bulk mode.
func (*Client) UpdateModule ¶ added in v0.2.0
UpdateModule updates the given module.
func (*Client) UpdateModuleTwin ¶ added in v0.2.0
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 ¶ added in v0.1.0
func WithTLSConfig(config *tls.Config) ClientOption
WithTLSConfig sets TLS config that's used by REST HTTP and AMQP clients.
type Configuration ¶ added in v0.2.0
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 ¶ added in v0.2.0
type ConfigurationMetrics ¶ added in v0.2.0
type ConnectionState ¶ added in v0.2.0
type ConnectionState string
const ( Connected ConnectionState = "Connected" Disconnected ConnectionState = "Disconnected" )
type Deployment ¶ added in v0.5.0
type Deployment struct { ID string `json:"id"` Labels map[string]string `json:"labels"` Priority uint `json:"priority"` TargetCondition string `json:"targetCondition"` Content *DeploymentContent `json:"content"` Metrics *ConfigurationMetrics `json:"metrics"` ETag string `json:"etag"` }
type DeploymentContent ¶ added in v0.5.0
type DeploymentContent struct {
ModulesContent map[string]interface{} `json:"modulesContent"`
}
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 ¶ added in v0.4.0
type DeviceStatus ¶ added in v0.2.0
type DeviceStatus string
const ( Enabled DeviceStatus = "enabled" Disabled DeviceStatus = "disabled" )
type EventHandler ¶ added in v0.1.0
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 ¶ added in v0.3.0
type FileNotification struct {
*amqp.Message
}
FileNotification is emitted once a blob file is uploaded to the hub.
TODO: structure is yet to define.
type FileNotificationHandler ¶ added in v0.3.0
type FileNotificationHandler func(event *FileNotification) error
FileNotificationHandler handles file upload notifications.
type JobV2 ¶ added in v0.4.0
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 ¶ added in v0.4.0
type JobV2Query struct { Type JobV2Type Status JobV2Status PageSize uint }
type JobV2Status ¶ added in v0.4.0
type JobV2Status string
const ( JobStatusUnknown JobV2Status = "unknown" JobStatusQueued JobV2Status = "queued" JobStatusScheduled JobV2Status = "scheduled" JobStatusRunning JobV2Status = "running" JobStatusCancelled JobV2Status = "cancelled" JobStatusCompleted JobV2Status = "completed" )
type MethodCall ¶ added in v0.2.0
type MethodResult ¶ added in v0.2.0
type MicrosoftTime ¶ added in v0.2.0
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 ¶ added in v0.2.0
func (t *MicrosoftTime) UnmarshalJSON(b []byte) error
type Module ¶ added in v0.2.0
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 ¶ added in v0.2.0
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 ¶ added in v0.3.0
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 ¶ added in v0.3.0
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 ¶ added in v0.3.0
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"` }