Interface Function
- All Known Subinterfaces:
- Alarm,- BooleanControl,- BooleanSensor,- Keypad,- Meter,- MultiLevelControl,- MultiLevelSensor,- WakeUp
- properties;
- operations.
The function service is registered in the service registry with these service properties:
- SERVICE_UID- mandatory service property. The property value contains the function unique identifier.
- SERVICE_DEVICE_UID- optional service property. The property value is the Functional Device identifiers. The function belongs to those devices.
- SERVICE_REFERENCE_UIDS- optional service property. The property value contains the reference function unique identifiers.
- SERVICE_TYPE- mandatory service property. The property value is the function type.
- SERVICE_VERSION- optional service property. The property value contains the function version.
- SERVICE_DESCRIPTION- optional service property. The property value is the function description.
- SERVICE_OPERATION_NAMES- optional service property. The property is missing when there are no function operations and property must be set when there are function operations. The property value is the function operation names.
- SERVICE_PROPERTY_NAMES- optional service property. The property is missing when there are no function properties and property must be set when there are function properties. The property value is the function property names.
 On start up, the Function services are registered before the
 Device services. It's possible that SERVICE_DEVICE_UID point
 to missing services at the moment of the registration. The reverse order is
 used when the services are unregistered. Function services are
 unregistered last after Device services.
 
 The Function service should be registered only under the function
 class hierarchy. Other classes can be used if there are no ambiguous
 representations. For example, an ambiguous representation can be a function
 registered under two independent function classes like BinarySwitch
 and Meter. In this example, both functions support the same property
 state with different meaning.
 getPropertyMetadata(String propertyName) method cannot determinate
 which property is requested. It can be BinarySwitch state or
 Meter state.
 
 To simplify the generic function discovery, the Function interface
 must be used for the service registration. In this way, the generic
 applications can easily find all services, which are functions in the service
 registry. Because of this rule, this registration is not allowed:
 
 context.registerService(MeterV1.class.getName(), this, regProps);
 
If the implementation would like to mark that there is a function, but no specific function interface exists, the registration can be:
 context.registerService(Function.class.getName(), this, regProps);
 
Note that such functions usually don't have operations and properties.
The function properties must be integrated according to these rules:
- Getter methods must be available for all properties with
 PropertyMetadata.ACCESS_READABLEaccess.
- Getter method must return a subclass of FunctionData.
- Setter methods must be available for all properties with
 PropertyMetadata.ACCESS_WRITABLEaccess.
- 
 Setter methods can be any combination of:
 - Setter method which accepts a subclass of FunctionData.
- 
 Setter method which accepts the values used by the FunctionDatasubclass, if there are no equal types.
 - 
 There is MyFunctionDatabean withBigDecimalvalue for adataproperty. Valid setters aresetData(MyFunctionData data)andsetData(BigDecimal data).
- 
 There is MySecondFunctionDatabean withBigDecimalprefix andBigDecimalsuffix for adataproperty. The prefix and suffix are using equal types and we cannot have a setter with the values used byMySecondFunctionData. The only one possible setter issetData(MySecondFunctionData data).
 
- Setter method which accepts a subclass of 
- No methods are required for properties with
 PropertyMetadata.ACCESS_EVENTABLEaccess.
The accessor method names must be defined according JavaBeans specification.
The function operations are java methods, which cannot override the property accessor methods. They can have zero or more parameters and zero or one return value.
Operation arguments and function properties are restricted by the same set of rules. The data type can be one of the following types:
- Java primitive type or corresponding reference type.
- java.lang.String.
- Numerical type i.e. the type which extends java.lang.Number. The numerical type must follow these conventions:- The type must provide a public static method called valueOfthat returns an instance of the given type and takes a singleStringargument or a public constructor which takes a singleStringargument.
- 
 The Stringargument from the previous bullet can be provided bytoString()method of the instance.
 
- The type must provide a public static method called 
- Beans, but the beans properties must use those rules. Java Beans are defined in JavaBeans specification.
- 
 java.util.Maps. The keys can bejava.lang.String. The values of a single type follow these rules.
- Arrays of defined types.
 The properties metadata is accessible with
 getPropertyMetadata(String). The operations metadata is accessible
 with getOperationMetadata(String).
 
In order to provide common behavior, all functions must follow a set of common rules related to the implementation of their setters, getters, operations and events:
- The setter method must be executed synchronously. If the underlying protocol can return response to the setter call, it must be awaited. It simplifies the property value modifications and doesn't require asynchronous callback.
- The operation method must be executed synchronously. If the underlying protocol can return an operation confirmation or response, they must be awaited. It simplifies the operation execution and doesn't require asynchronous callback.
- The getter must return the last know cached property value. The device implementation is responsible to keep that value up to date. It'll speed up the applications when the function property values are collected. The same cached value can be shared between a few requests instead of a few calls to the real device.
- The function operations, getters and setters must not override
 java.lang.Objectand this interface methods.
- 
Field SummaryFieldsModifier and TypeFieldDescriptionstatic final StringThe service property value contains the function description.static final StringThe service property value contains the device unique identifier.static final StringThe service property value contains the function operation names.static final StringThe service property value contains the function property names.static final StringThe service property value contains the reference function unique identifiers.static final StringThe service property value contains the function type.static final StringThe service property value contains the function unique identifier.static final StringThe service property value contains the function version.
- 
Method SummaryModifier and TypeMethodDescriptiongetOperationMetadata(String operationName) Provides metadata about the function operation.getPropertyMetadata(String propertyName) Provides metadata about the function property.getServiceProperty(String propKey) Returns the current value of the specified property.String[]Returns an array with all function service property keys.
- 
Field Details- 
SERVICE_UIDThe service property value contains the function unique identifier. It's a mandatory property. The value type isjava.lang.String. To simplify the unique identifier generation, the property value must follow the rule:function UID ::= device-id ':' function-id function UID - function unique identifier device-id - the value of the Device.SERVICE_UIDDevice service propertyfunction-id - function identifier in the scope of the device If the function is not bound to a device, the function unique identifier can be device independent. - See Also:
 
- 
SERVICE_TYPEThe service property value contains the function type. It's an optional property. For example, the sensor function can have different types like temperature, pressure, etc. The value type isjava.lang.String.Organizations that want to use function types that do not clash with OSGi Working Group defined types should prefix their types in own namespace. The type doesn't mandate specific function interface. It can be used with different functions. - See Also:
 
- 
SERVICE_VERSIONThe service property value contains the function version. That version can point to specific implementation version and vary in the different vendor implementations. It's an optional property. The value type isjava.lang.String.- See Also:
 
- 
SERVICE_DEVICE_UIDThe service property value contains the device unique identifier. The function belongs to this device. It's an optional property. The value type isjava.lang.String.- See Also:
 
- 
SERVICE_REFERENCE_UIDSThe service property value contains the reference function unique identifiers. It's an optional property. The value type isjava.lang.String[]. It can be used to represent different relationships between the functions.- See Also:
 
- 
SERVICE_DESCRIPTIONThe service property value contains the function description. It's an optional property. The value type isjava.lang.String.- See Also:
 
- 
SERVICE_PROPERTY_NAMESThe service property value contains the function property names. It's an optional property. The property is missing when there are no function properties and property must be set when there are function properties. The value type isjava.lang.String[]. It's not possible to exist two or more function properties with the same name.- See Also:
 
- 
SERVICE_OPERATION_NAMESThe service property value contains the function operation names. It's an optional property. The property is missing when there are no function operations and property must be set when there are function operations. The value type isjava.lang.String[]. It's not possible to exist two or more function operations with the same name i.e. the operation overloading is not allowed.- See Also:
 
 
- 
- 
Method Details- 
getPropertyMetadataProvides metadata about the function property.This method must continue to return the property metadata after the function service has been unregistered. - Parameters:
- propertyName- The function property name, for which metadata is requested.
- Returns:
- The property metadata for the given property name. nullif the property metadata is not available.
- Throws:
- IllegalArgumentException- If the function property with the specified name is not available.
 
- 
getOperationMetadataProvides metadata about the function operation.This method must continue to return the operation metadata after the function service has been unregistered. - Parameters:
- operationName- The function operation name, for which metadata is requested.
- Returns:
- The operation metadata for the given operation name. nullif the operation metadata is not available.
- Throws:
- IllegalArgumentException- If the function operation with the specified name is not available.
 
- 
getServicePropertyReturns the current value of the specified property. The method will return the same value asServiceReference.getProperty(String)for the service reference of this function.This method must continue to return property values after the device function service has been unregistered. - Parameters:
- propKey- The property key.
- Returns:
- The property value or nullif the property key cannot be mapped to a value.
 
- 
getServicePropertyKeysString[] getServicePropertyKeys()Returns an array with all function service property keys. The method will return the same value asServiceReference.getPropertyKeys()for the service reference of this function. The result cannot benull.- Returns:
- An array with all function service property keys, cannot be
         null.
 
 
-