[IOT-1089] Merge remote-tracking branch 'origin/master' into generic-java
authorGeorge Nash <george.nash@intel.com>
Mon, 5 Dec 2016 21:54:53 +0000 (13:54 -0800)
committerGeorge Nash <george.nash@intel.com>
Mon, 5 Dec 2016 22:36:25 +0000 (14:36 -0800)
Change-Id: Ie98be4802e7cb9ceacc9b159f4b99e84ed87f27a
Signed-off-by: George Nash <george.nash@intel.com>
1  2 
java/iotivity-android/src/main/java/org/iotivity/base/OcPlatform.java
java/iotivity-linux/src/main/java/org/iotivity/base/OcPlatform.java
java/jni/JniOcPlatform.cpp
java/jni/JniOcPlatform.h
java/jni/JniOcProvisioning.cpp
resource/csdk/connectivity/api/cautilinterface.h
resource/csdk/connectivity/inc/caadapterutils.h
resource/csdk/connectivity/src/adapter_util/caadapterutils.c
service/easy-setup/mediator/richsdk/android/EasySetupCore/src/main/jni/Android.mk
service/notification/android/notification-service/src/main/jni/Android.mk
service/resource-container/src/ResourceContainerImpl.cpp

index 9a3e010,0000000..2548e0c
mode 100644,000000..100644
--- /dev/null
@@@ -1,949 -1,0 +1,978 @@@
 +/*
 + *******************************************************************
 + *
 + * Copyright 2015 Intel Corporation.
 + *
 + *-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
 + *
 + * Licensed under the Apache License, Version 2.0 (the "License");
 + * you may not use this file except in compliance with the License.
 + * You may obtain a copy of the License at
 + *
 + *      http://www.apache.org/licenses/LICENSE-2.0
 + *
 + * Unless required by applicable law or agreed to in writing, software
 + * distributed under the License is distributed on an "AS IS" BASIS,
 + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 + * See the License for the specific language governing permissions and
 + * limitations under the License.
 + *
 + *-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
 + */
 +
 +package org.iotivity.base;
 +
 +import org.iotivity.ca.CaInterface;
 +
 +import java.util.EnumSet;
 +import java.util.Iterator;
 +import java.util.List;
 +
 +/**
 + * This class contains the main entrance/functionality of the product. To set a custom
 + * configuration, the implementer must make a call to OcPlatform.Configure before the first usage
 + * of a method in this class.
 + */
 +public final class OcPlatform {
 +
 +    static {
 +        System.loadLibrary("oc_logger");
 +        System.loadLibrary("octbstack");
 +        System.loadLibrary("oc");
 +        System.loadLibrary("ocstack-jni");
 +    }
 +
 +    /**
 +     * Default interface
 +     */
 +    public static final String DEFAULT_INTERFACE = "oic.if.baseline";
 +
 +    /**
 +     * Used in discovering (GET) links to other resources of a collection
 +     */
 +    public static final String LINK_INTERFACE = "oic.if.ll";
 +
 +    /**
 +     * Used in GET, PUT, POST, DELETE methods on links to other resources of a collection
 +     */
 +    public static final String BATCH_INTERFACE = "oic.if.b";
 +
 +    /**
 +     * Used in GET, PUT, POST methods on links to other remote resources of a group
 +     */
 +    public static final String GROUP_INTERFACE = "oic.mi.grp";
 +
 +    public static final String WELL_KNOWN_QUERY = "/oic/res";
 +    public static final String WELL_KNOWN_DEVICE_QUERY = "/oic/d";
 +    public static final String WELL_KNOWN_PLATFORM_QUERY = "/oic/p";
 +    public static final int DEFAULT_PRESENCE_TTL = 60;
 +    public static final String PRESENCE_URI = "/oic/ad";
 +
 +    private static volatile boolean sIsPlatformInitialized = false;
 +    private static QualityOfService sPlatformQualityOfService = QualityOfService.NA;
 +
++    private static volatile boolean sIsStopPlatform = false;
++
 +    private OcPlatform() {
 +    }
 +
 +    /**
 +     * API for setting the configuration of the OcPlatform.
 +     * <p>
 +     * Note: Any calls made to this AFTER the first call to OcPlatform.Configure will have no affect
 +     * </p>
 +     *
 +     * @param platformConfig platform configuration
 +     */
 +    public synchronized static void Configure(PlatformConfig platformConfig) {
++        if (sIsStopPlatform)
++        {
++            OcPlatform.start();
++            sIsStopPlatform = false;
++        }
++
 +        if (!sIsPlatformInitialized) {
 +            CaInterface.initialize();
 +
 +            sPlatformQualityOfService = platformConfig.getQualityOfService();
 +
 +            OcPlatform.configure(
 +                    platformConfig.getServiceType().getValue(),
 +                    platformConfig.getModeType().getValue(),
 +                    platformConfig.getIpAddress(),
 +                    platformConfig.getPort(),
 +                    platformConfig.getQualityOfService().getValue(),
 +                    platformConfig.getSvrDbPath()
 +            );
 +
 +            sIsPlatformInitialized = true;
 +        }
 +    }
 +
 +    private static native void configure(int serviceType,
 +                                         int modeType,
 +                                         String ipAddress,
 +                                         int port,
 +                                         int qualityOfService,
 +                                         String dbPath);
 +
 +    /**
++     * API for stop all process of the OcPlatform.
++     * All of threads and memory will be terminated by this API.
++     * Iotivity Core can be started again through Configure(PlatformConfig platformConfig) API.
++     * Both Configure and Shutdown API is filtering for duplicated calling even while processing.
++     * <p>
++     * Note: This API is for both server and client side.
++     * </p>
++     */
++    public synchronized static void Shutdown() {
++        if (!sIsStopPlatform)
++        {
++            OcPlatform.stop();
++            sIsStopPlatform = true;
++            sIsPlatformInitialized = false;
++        }
++    }
++
++    private static native void stop();
++    private static native void start();
++
++    /**
 +     * API for notifying base that resource's attributes have changed.
 +     * <p>
 +     * Note: This API is for server side only.
 +     * </p>
 +     *
 +     * @param ocResourceHandle resource handle of the resource
 +     * @throws OcException if failure
 +     */
 +    public static void notifyAllObservers(
 +            OcResourceHandle ocResourceHandle) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.notifyAllObservers0(ocResourceHandle);
 +    }
 +
 +    private static native void notifyAllObservers0(
 +            OcResourceHandle ocResourceHandle) throws OcException;
 +
 +    /**
 +     * API for notifying base that resource's attributes have changed.
 +     * <p>
 +     * Note: This API is for server side only.
 +     * </p>
 +     *
 +     * @param ocResourceHandle resource handle of the resource
 +     * @param qualityOfService the quality of communication
 +     * @throws OcException if failure
 +     */
 +    public static void notifyAllObservers(
 +            OcResourceHandle ocResourceHandle,
 +            QualityOfService qualityOfService) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.notifyAllObservers1(ocResourceHandle, qualityOfService.getValue());
 +    }
 +
 +    private static native void notifyAllObservers1(
 +            OcResourceHandle ocResourceHandle,
 +            int qualityOfService) throws OcException;
 +
 +    /**
 +     * API for notifying only specific clients that resource's attributes have changed.
 +     * <p>
 +     * Note: This API is for server side only.
 +     * </p>
 +     *
 +     * @param ocResourceHandle    resource handle of the resource
 +     * @param ocObservationIdList These set of ids are ones which which will be notified upon
 +     *                            resource change.
 +     * @param ocResourceResponse  OcResourceResponse object used by app to fill the response for
 +     *                            this resource change
 +     * @throws OcException if failure
 +     */
 +    public static void notifyListOfObservers(
 +            OcResourceHandle ocResourceHandle,
 +            List<Byte> ocObservationIdList,
 +            OcResourceResponse ocResourceResponse) throws OcException {
 +        OcPlatform.initCheck();
 +
 +        byte[] idArr = new byte[ocObservationIdList.size()];
 +        Iterator<Byte> it = ocObservationIdList.iterator();
 +        int i = 0;
 +        while (it.hasNext()) {
 +            idArr[i++] = (byte) it.next();
 +        }
 +
 +        OcPlatform.notifyListOfObservers2(
 +                ocResourceHandle,
 +                idArr,
 +                ocResourceResponse);
 +    }
 +
 +    private static native void notifyListOfObservers2(
 +            OcResourceHandle ocResourceHandle,
 +            byte[] ocObservationIdArray,
 +            OcResourceResponse ocResourceResponse) throws OcException;
 +
 +    /**
 +     * API for notifying only specific clients that resource's attributes have changed.
 +     * <p>
 +     * Note: This API is for server side only.
 +     * </p>
 +     *
 +     * @param ocResourceHandle    resource handle of the resource
 +     * @param ocObservationIdList These set of ids are ones which which will be notified upon
 +     *                            resource change.
 +     * @param ocResourceResponse  OcResourceResponse object used by app to fill the response for
 +     *                            this resource change
 +     * @param qualityOfService    the quality of communication
 +     * @throws OcException if failure
 +     */
 +    public static void notifyListOfObservers(
 +            OcResourceHandle ocResourceHandle,
 +            List<Byte> ocObservationIdList,
 +            OcResourceResponse ocResourceResponse,
 +            QualityOfService qualityOfService) throws OcException {
 +        OcPlatform.initCheck();
 +
 +        byte[] idArr = new byte[ocObservationIdList.size()];
 +        Iterator<Byte> it = ocObservationIdList.iterator();
 +        int i = 0;
 +        while (it.hasNext()) {
 +            idArr[i++] = (byte) it.next();
 +        }
 +
 +        OcPlatform.notifyListOfObservers3(
 +                ocResourceHandle,
 +                idArr,
 +                ocResourceResponse,
 +                qualityOfService.getValue()
 +        );
 +    }
 +
 +    private static native void notifyListOfObservers3(
 +            OcResourceHandle ocResourceHandle,
 +            byte[] ocObservationIdArray,
 +            OcResourceResponse ocResourceResponse,
 +            int qualityOfService) throws OcException;
 +
 +    /**
 +     * API for Service and Resource Discovery
 +     * <p>
 +     * Note: This API is for client side only.
 +     * </p>
 +     *
 +     * @param host                    Host Address of a service to direct resource discovery query.
 +     *                                If empty, performs multicast resource discovery query
 +     * @param resourceUri             name of the resource. If null or empty, performs search for all
 +     *                                resource names
 +     * @param connectivityTypeSet     Set of types of connectivity. Example: IP
 +     * @param onResourceFoundListener Handles events, success states and failure states.
 +     * @throws OcException if failure
 +     */
 +    public static void findResource(
 +            String host,
 +            String resourceUri,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnResourceFoundListener onResourceFoundListener) throws OcException {
 +        OcPlatform.initCheck();
 +
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +
 +        OcPlatform.findResource0(
 +                host,
 +                resourceUri,
 +                connTypeInt,
 +                onResourceFoundListener
 +        );
 +    }
 +
 +    private static native void findResource0(
 +            String host,
 +            String resourceUri,
 +            int connectivityType,
 +            OnResourceFoundListener onResourceFoundListener) throws OcException;
 +
 +    /**
 +     * API for Service and Resource Discovery.
 +     * <p>
 +     * Note: This API is for client side only.
 +     * </p>
 +     *
 +     * @param host                    Host IP Address of a service to direct resource discovery query.
 +     *                                If empty, performs multicast resource discovery query
 +     * @param resourceUri             name of the resource. If null or empty, performs search for all
 +     *                                resource names
 +     * @param connectivityTypeSet     Set of types of connectivity. Example: IP
 +     * @param onResourceFoundListener Handles events, success states and failure states.
 +     * @param qualityOfService        the quality of communication
 +     * @throws OcException if failure
 +     */
 +    public static void findResource(
 +            String host,
 +            String resourceUri,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnResourceFoundListener onResourceFoundListener,
 +            QualityOfService qualityOfService) throws OcException {
 +        OcPlatform.initCheck();
 +
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +
 +        OcPlatform.findResource1(host,
 +                resourceUri,
 +                connTypeInt,
 +                onResourceFoundListener,
 +                qualityOfService.getValue()
 +        );
 +    }
 +
 +    private static native void findResource1(
 +            String host,
 +            String resourceUri,
 +            int connectivityType,
 +            OnResourceFoundListener onResourceFoundListener,
 +            int qualityOfService) throws OcException;
 +
 +    /**
 +     * API for Device Discovery
 +     *
 +     * @param host                  Host IP Address. If null or empty, Multicast is performed.
 +     * @param deviceUri             Uri containing address to the virtual device
 +     * @param connectivityTypeSet   Set of types of connectivity. Example: IP
 +     * @param onDeviceFoundListener Handles events, success states and failure states.
 +     * @throws OcException if failure
 +     */
 +    public static void getDeviceInfo(
 +            String host,
 +            String deviceUri,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnDeviceFoundListener onDeviceFoundListener) throws OcException {
 +        OcPlatform.initCheck();
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +        OcPlatform.getDeviceInfo0(
 +                host,
 +                deviceUri,
 +                connTypeInt,
 +                onDeviceFoundListener
 +        );
 +    }
 +
 +    private static native void getDeviceInfo0(
 +            String host,
 +            String deviceUri,
 +            int connectivityType,
 +            OnDeviceFoundListener onDeviceFoundListener) throws OcException;
 +
 +    /**
 +     * API for Device Discovery
 +     *
 +     * @param host                  Host IP Address. If null or empty, Multicast is performed.
 +     * @param deviceUri             Uri containing address to the virtual device
 +     * @param connectivityTypeSet   Set of types of connectivity. Example: IP
 +     * @param onDeviceFoundListener Handles events, success states and failure states.
 +     * @param qualityOfService      the quality of communication
 +     * @throws OcException if failure
 +     */
 +    public static void getDeviceInfo(
 +            String host,
 +            String deviceUri,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnDeviceFoundListener onDeviceFoundListener,
 +            QualityOfService qualityOfService) throws OcException {
 +        OcPlatform.initCheck();
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +        OcPlatform.getDeviceInfo1(
 +                host,
 +                deviceUri,
 +                connTypeInt,
 +                onDeviceFoundListener,
 +                qualityOfService.getValue()
 +        );
 +    }
 +
 +    private static native void getDeviceInfo1(
 +            String host,
 +            String deviceUri,
 +            int connectivityType,
 +            OnDeviceFoundListener onDeviceFoundListener,
 +            int qualityOfService) throws OcException;
 +
 +    /**
 +     * API for Platform Discovery
 +     *
 +     * @param host                    Host IP Address. If null or empty, Multicast is performed.
 +     * @param platformUri             Uri containing address to the platform
 +     * @param connectivityTypeSet     Set of types of connectivity. Example: IP
 +     * @param onPlatformFoundListener Handles events, success states and failure states.
 +     * @throws OcException if failure
 +     */
 +
 +    public static void getPlatformInfo(
 +            String host,
 +            String platformUri,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnPlatformFoundListener onPlatformFoundListener) throws OcException {
 +        OcPlatform.initCheck();
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +        OcPlatform.getPlatformInfo0(
 +                host,
 +                platformUri,
 +                connTypeInt,
 +                onPlatformFoundListener
 +        );
 +    }
 +
 +    private static native void getPlatformInfo0(
 +            String host,
 +            String platformUri,
 +            int connectivityType,
 +            OnPlatformFoundListener onPlatformInfoFoundListener) throws OcException;
 +
 +    /**
 +     * API for Platform Discovery
 +     *
 +     * @param host                    Host IP Address. If null or empty, Multicast is performed.
 +     * @param platformUri             Uri containing address to the platform
 +     * @param connectivityTypeSet     Set of types of connectivity. Example: IP
 +     * @param onPlatformFoundListener Handles events, success states and failure states.
 +     * @param qualityOfService        the quality of communication
 +     * @throws OcException if failure
 +     */
 +
 +    public static void getPlatformInfo(
 +            String host,
 +            String platformUri,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnPlatformFoundListener onPlatformFoundListener,
 +            QualityOfService qualityOfService) throws OcException {
 +        OcPlatform.initCheck();
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +        OcPlatform.getPlatformInfo1(
 +                host,
 +                platformUri,
 +                connTypeInt,
 +                onPlatformFoundListener,
 +                qualityOfService.getValue()
 +        );
 +    }
 +
 +    private static native void getPlatformInfo1(
 +            String host,
 +            String platformUri,
 +            int connectivityType,
 +            OnPlatformFoundListener onPlatformFoundListener,
 +            int qualityOfService) throws OcException;
 +
 +    /**
 +     * This API registers a resource with the server
 +     * <p/>
 +     * Note: This API applies to server & client side.
 +     * </P>
 +     *
 +     * @param ocResource The instance of OcResource with all data filled
 +     * @return resource handle
 +     * @throws OcException if failure
 +     */
 +    public static OcResourceHandle registerResource(
 +            OcResource ocResource) throws OcException {
 +        OcPlatform.initCheck();
 +        return OcPlatform.registerResource0(ocResource);
 +    }
 +
 +    private static native OcResourceHandle registerResource0(
 +            OcResource ocResource) throws OcException;
 +
 +    /**
 +     * This API registers a resource with the server NOTE: This API applies to server side only.
 +     * <p/>
 +     * Note: This API applies to server side only.
 +     * </P>
 +     *
 +     * @param resourceUri         The URI of the resource. Example: "a/light"
 +     * @param resourceTypeName    The resource type. Example: "light"
 +     * @param resourceInterface   The resource interface (whether it is collection etc).
 +     * @param entityHandler       entity handler.
 +     * @param resourcePropertySet indicates the property of the resource
 +     * @return resource handle
 +     * @throws OcException if failure
 +     */
 +    public static OcResourceHandle registerResource(
 +            String resourceUri,
 +            String resourceTypeName,
 +            String resourceInterface,
 +            EntityHandler entityHandler,
 +            EnumSet<ResourceProperty> resourcePropertySet) throws OcException {
 +        OcPlatform.initCheck();
 +
 +        int resProperty = 0;
 +
 +        for (ResourceProperty prop : ResourceProperty.values()) {
 +            if (resourcePropertySet.contains(prop))
 +                resProperty |= prop.getValue();
 +        }
 +
 +        return OcPlatform.registerResource1(resourceUri,
 +                resourceTypeName,
 +                resourceInterface,
 +                entityHandler,
 +                resProperty);
 +    }
 +
 +    private static native OcResourceHandle registerResource1(
 +            String resourceUri,
 +            String resourceTypeName,
 +            String resourceInterface,
 +            EntityHandler entityHandler,
 +            int resourceProperty) throws OcException;
 +
 +    /**
 +     * Register Device Info
 +     *
 +     * @param ocDeviceInfo object containing all the device specific information
 +     * @throws OcException if failure
 +     */
 +    public static void registerDeviceInfo(
 +            OcDeviceInfo ocDeviceInfo) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.registerDeviceInfo0(
 +                ocDeviceInfo.getDeviceName()
 +        );
 +    }
 +
 +    private static native void registerDeviceInfo0(
 +            String deviceName
 +    ) throws OcException;
 +
 +    /**
 +     * Register Platform Info
 +     *
 +     * @param ocPlatformInfo object containing all the platform specific information
 +     * @throws OcException if failure
 +     */
 +    public static void registerPlatformInfo(
 +            OcPlatformInfo ocPlatformInfo) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.registerPlatformInfo0(
 +                ocPlatformInfo.getPlatformId(),
 +                ocPlatformInfo.getManufacturerName(),
 +                ocPlatformInfo.getManufacturerUrl(),
 +                ocPlatformInfo.getModelNumber(),
 +                ocPlatformInfo.getDateOfManufacture(),
 +                ocPlatformInfo.getPlatformVersion(),
 +                ocPlatformInfo.getOperatingSystemVersion(),
 +                ocPlatformInfo.getHardwareVersion(),
 +                ocPlatformInfo.getFirmwareVersion(),
 +                ocPlatformInfo.getSupportUrl(),
 +                ocPlatformInfo.getSystemTime()
 +        );
 +    }
 +
 +    private static native void registerPlatformInfo0(
 +            String platformId, String manufacturerName, String manufacturerUrl,
 +            String modelNumber, String dateOfManufacture, String platformVersion,
 +            String operatingSystemVersion, String hardwareVersion, String firmwareVersion,
 +            String supportUrl, String systemTime
 +    ) throws OcException;
 +
 +    /**
 +     * This API unregisters a resource with the server NOTE: This API applies to server side only.
 +     *
 +     * @param ocResourceHandle This is the resource handle which we which to unregister from the
 +     *                         server
 +     * @throws OcException if failure
 +     */
 +    public static void unregisterResource(
 +            OcResourceHandle ocResourceHandle) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.unregisterResource0(ocResourceHandle);
 +    }
 +
 +    private static native void unregisterResource0(
 +            OcResourceHandle ocResourceHandle) throws OcException;
 +
 +
 +    /**
 +     * Add a resource to a collection resource
 +     *
 +     * @param ocResourceCollectionHandle handle to the collection resource
 +     * @param ocResourceHandle           handle to resource to be added to the collection resource
 +     * @throws OcException if failure
 +     */
 +    public static void bindResource(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            OcResourceHandle ocResourceHandle) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.bindResource0(ocResourceCollectionHandle, ocResourceHandle);
 +    }
 +
 +    private static native void bindResource0(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            OcResourceHandle ocResourceHandle) throws OcException;
 +
 +    /**
 +     * Add multiple resources to a collection resource.
 +     *
 +     * @param ocResourceCollectionHandle handle to the collection resource
 +     * @param ocResourceHandleList       reference to list of resource handles to be added to the
 +     *                                   collection resource
 +     * @throws OcException if failure
 +     */
 +    public static void bindResources(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            List<OcResourceHandle> ocResourceHandleList) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.bindResources0(
 +                ocResourceCollectionHandle,
 +                ocResourceHandleList.toArray(
 +                        new OcResourceHandle[ocResourceHandleList.size()])
 +        );
 +    }
 +
 +    private static native void bindResources0(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            OcResourceHandle[] ocResourceHandleArray) throws OcException;
 +
 +    /**
 +     * Unbind a resource from a collection resource.
 +     *
 +     * @param ocResourceCollectionHandle handle to the collection resource
 +     * @param ocResourceHandle           resource handle to be unbound from the collection resource
 +     * @throws OcException if failure
 +     */
 +    public static void unbindResource(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            OcResourceHandle ocResourceHandle) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.unbindResource0(ocResourceCollectionHandle, ocResourceHandle);
 +    }
 +
 +    private static native void unbindResource0(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            OcResourceHandle ocResourceHandle) throws OcException;
 +
 +    /**
 +     * Unbind resources from a collection resource.
 +     *
 +     * @param ocResourceCollectionHandle Handle to the collection resource
 +     * @param ocResourceHandleList       List of resource handles to be unbound from the collection
 +     *                                   resource
 +     * @throws OcException if failure
 +     */
 +    public static void unbindResources(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            List<OcResourceHandle> ocResourceHandleList) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.unbindResources0(
 +                ocResourceCollectionHandle,
 +                ocResourceHandleList.toArray(
 +                        new OcResourceHandle[ocResourceHandleList.size()])
 +        );
 +    }
 +
 +    private static native void unbindResources0(
 +            OcResourceHandle ocResourceCollectionHandle,
 +            OcResourceHandle[] ocResourceHandleArray) throws OcException;
 +
 +    /**
 +     * Binds a type to a particular resource
 +     *
 +     * @param ocResourceHandle handle to the resource
 +     * @param resourceTypeName new typename to bind to the resource
 +     * @throws OcException if failure
 +     */
 +    public static void bindTypeToResource(
 +            OcResourceHandle ocResourceHandle,
 +            String resourceTypeName) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.bindTypeToResource0(ocResourceHandle, resourceTypeName);
 +    }
 +
 +    private static native void bindTypeToResource0(
 +            OcResourceHandle ocResourceHandle,
 +            String resourceTypeName) throws OcException;
 +
 +    /**
 +     * Binds an interface to a particular resource
 +     *
 +     * @param ocResourceHandle      handle to the resource
 +     * @param resourceInterfaceName new interface to bind to the resource
 +     * @throws OcException if failure
 +     */
 +    public static void bindInterfaceToResource(
 +            OcResourceHandle ocResourceHandle,
 +            String resourceInterfaceName) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.bindInterfaceToResource0(ocResourceHandle, resourceInterfaceName);
 +    }
 +
 +    private static native void bindInterfaceToResource0(
 +            OcResourceHandle ocResourceHandle,
 +            String resourceInterfaceName) throws OcException;
 +
 +    /**
 +     * Start Presence announcements.
 +     *
 +     * @param ttl time to live in seconds
 +     * @throws OcException if failure
 +     */
 +    public static void startPresence(int ttl) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.startPresence0(ttl);
 +    }
 +
 +    private static native void startPresence0(int ttl) throws OcException;
 +
 +    /**
 +     * Stop Presence announcements.
 +     *
 +     * @throws OcException if failure
 +     */
 +    public static void stopPresence() throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.stopPresence0();
 +    }
 +
 +    private static native void stopPresence0() throws OcException;
 +
 +    /**
 +     * Subscribes to a server's presence change events. By making this subscription, every time a
 +     * server adds/removes/alters a resource, starts or is intentionally stopped
 +     *
 +     * @param host                The IP address/addressable name of the server to subscribe to
 +     * @param connectivityTypeSet Set of types of connectivity. Example: IP
 +     * @param onPresenceListener  listener that will receive notifications/subscription events
 +     * @return a handle object that can be used to identify this subscription request. It can be
 +     * used to unsubscribe from these events in the future
 +     * @throws OcException if failure
 +     */
 +    public static OcPresenceHandle subscribePresence(
 +            String host,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnPresenceListener onPresenceListener) throws OcException {
 +        OcPlatform.initCheck();
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +        return OcPlatform.subscribePresence0(
 +                host,
 +                connTypeInt,
 +                onPresenceListener
 +        );
 +    }
 +
 +    private static native OcPresenceHandle subscribePresence0(
 +            String host,
 +            int connectivityType,
 +            OnPresenceListener onPresenceListener) throws OcException;
 +
 +    /**
 +     * Subscribes to a server's presence change events. By making this subscription, every time a
 +     * server adds/removes/alters a resource, starts or is intentionally stopped
 +     *
 +     * @param host                The IP address/addressable name of the server to subscribe to
 +     * @param resourceType        a resource type specified as a filter for subscription events.
 +     * @param connectivityTypeSet Set of types of connectivity. Example: IP
 +     * @param onPresenceListener  listener that will receive notifications/subscription events
 +     * @return a handle object that can be used to identify this subscription request. It can be
 +     * used to unsubscribe from these events in the future
 +     * @throws OcException if failure
 +     */
 +    public static OcPresenceHandle subscribePresence(
 +            String host,
 +            String resourceType,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            OnPresenceListener onPresenceListener) throws OcException {
 +        OcPlatform.initCheck();
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +        return OcPlatform.subscribePresence1(
 +                host,
 +                resourceType,
 +                connTypeInt,
 +                onPresenceListener);
 +    }
 +
 +    private static native OcPresenceHandle subscribePresence1(
 +            String host,
 +            String resourceType,
 +            int connectivityType,
 +            OnPresenceListener onPresenceListener) throws OcException;
 +
 +    /**
 +     * Unsubscribes from a previously subscribed server's presence events. Note that you may for
 +     * a short time still receive events from the server since it may take time for the
 +     * unsubscribe to take effect.
 +     *
 +     * @param ocPresenceHandle the handle object provided by the subscribePresence call that
 +     *                         identifies this subscription
 +     * @throws OcException if failure
 +     */
 +    public static void unsubscribePresence(
 +            OcPresenceHandle ocPresenceHandle) throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.unsubscribePresence0(ocPresenceHandle);
 +    }
 +
 +    private static native void unsubscribePresence0(
 +            OcPresenceHandle ocPresenceHandle) throws OcException;
 +
 +    /**
 +     * Creates a resource proxy object so that get/put/observe functionality can be used without
 +     * discovering the object in advance. Note that the consumer of this method needs to provide
 +     * all of the details required to correctly contact and observe the object. If the consumer
 +     * lacks any of this information, they should discover the resource object normally.
 +     * Additionally, you can only create this object if OcPlatform was initialized to be a Client
 +     * or Client/Server.
 +     *
 +     * @param host                a string containing a resolvable host address of the server holding
 +     *                            the resource
 +     * @param uri                 the rest of the resource's URI that will permit messages to be
 +     *                            properly routed.
 +     *                            Example: /a/light
 +     * @param connectivityTypeSet Set of types of connectivity. Example: IP
 +     * @param isObservable        a boolean containing whether the resource supports observation
 +     * @param resourceTypeList    a collection of resource types implemented by the resource
 +     * @param interfaceList       a collection of interfaces that the resource supports/implements
 +     * @return new resource object
 +     * @throws OcException if failure
 +     */
 +    public static OcResource constructResourceObject(
 +            String host,
 +            String uri,
 +            EnumSet<OcConnectivityType> connectivityTypeSet,
 +            boolean isObservable,
 +            List<String> resourceTypeList,
 +            List<String> interfaceList) throws OcException {
 +        OcPlatform.initCheck();
 +        int connTypeInt = 0;
 +
 +        for (OcConnectivityType connType : OcConnectivityType.values()) {
 +            if (connectivityTypeSet.contains(connType))
 +                connTypeInt |= connType.getValue();
 +        }
 +        return OcPlatform.constructResourceObject0(
 +                host,
 +                uri,
 +                connTypeInt,
 +                isObservable,
 +                resourceTypeList.toArray(new String[resourceTypeList.size()]),
 +                interfaceList.toArray(new String[interfaceList.size()])
 +        );
 +    }
 +
 +    private static native OcResource constructResourceObject0(
 +            String host,
 +            String uri,
 +            int connectivityType,
 +            boolean isObservable,
 +            String[] resourceTypes,
 +            String[] interfaces) throws OcException;
 +
 +    /**
 +     * Allows application entity handler to send response to an incoming request.
 +     *
 +     * @param ocResourceResponse resource response
 +     * @throws OcException if failure
 +     */
 +    public static void sendResponse(OcResourceResponse ocResourceResponse)
 +            throws OcException {
 +        OcPlatform.initCheck();
 +        OcPlatform.sendResponse0(ocResourceResponse);
 +    }
 +
 +    private static native void sendResponse0(OcResourceResponse ocResourceResponse)
 +            throws OcException;
 +
 +    /**
 +     * An OnResourceFoundListener can be registered via the OcPlatform.findResource call.
 +     * Event listeners are notified asynchronously
 +     */
 +    public interface OnResourceFoundListener {
 +        public void onResourceFound(OcResource resource);
 +    }
 +
 +    /**
 +     * An OnDeviceFoundListener can be registered via the OcPlatform.getDeviceInfo call.
 +     * Event listeners are notified asynchronously
 +     */
 +    public interface OnDeviceFoundListener {
 +        public void onDeviceFound(OcRepresentation ocRepresentation);
 +    }
 +
 +    /**
 +     * An OnPlatformFoundListener can be registered via the OcPlatform.getPlatformInfo call.
 +     * Event listeners are notified asynchronously
 +     */
 +    public interface OnPlatformFoundListener {
 +        public void onPlatformFound(OcRepresentation ocRepresentation);
 +    }
 +
 +    /**
 +     * An OnPresenceListener can be registered via the OcPlatform.subscribePresence call.
 +     * Event listeners are notified asynchronously
 +     */
 +    public interface OnPresenceListener {
 +        public void onPresence(OcPresenceStatus ocPresenceStatus, int nonce, String hostAddress);
 +    }
 +
 +    /**
 +     * An EntityHandler can be registered via the OcPlatform.registerResource call.
 +     * Event listeners are notified asynchronously
 +     */
 +    public interface EntityHandler {
 +        public EntityHandlerResult handleEntity(OcResourceRequest ocResourceRequest);
 +    }
 +
 +    private static void initCheck() {
 +        if (!sIsPlatformInitialized) {
 +            throw new IllegalStateException("OcPlatform must be configured by making a call to " +
 +                    "OcPlatform.Configure before any other API calls are permitted");
 +        }
 +    }
 +
 +    /**
 +     * Gets platform quality of service
 +     *
 +     * @return quality of service
 +     */
 +    public static QualityOfService getPlatformQualityOfService() {
 +        OcPlatform.initCheck();
 +        return sPlatformQualityOfService;
 +    }
 +}
Simple merge
Simple merge
Simple merge
@@@ -252,39 -289,36 +259,67 @@@ bool CACheckJNIException(JNIEnv *env)
   */
  void CADeleteGlobalReferences();
  
 +#ifdef __ANDROID__
 +/**
 + * To set context of JNI Application.
 + * This must be called by the Android API before CA Initialization.
 + * @param[in]   env         JNI interface pointer.
 + * @param[in]   context     context object.
 + */
 +void CANativeJNISetContext(JNIEnv *env, jobject context);
 +
 +/**
 + * To set Activity to JNI.
 + * This must be called by the Android API before CA Initialization.
 + * @param[in]   env         JNI Environment pointer.
 + * @param[in]   activity    Activity object.
 + */
 +void CANativeSetActivity(JNIEnv *env, jobject activity);
 +
 +/**
 + * To get context.
 + * Called by adapters to get Application context.
 + * @return  context object.
 + */
 +jobject CANativeJNIGetContext();
 +
 +/**
 + * To get Activity.
 + * Called from adapters to get Activity.
 + * @return  Activity object.
 + */
 +jobject *CANativeGetActivity();
 +#endif
  #endif
  
+ #ifndef WITH_ARDUINO
+ /**
+  * print send state in the adapter.
+  * @param[in]   adapter          transport adapter type.
+  * @param[in]   addr             remote address.
+  * @param[in]   port             port.
+  * @param[in]   sentLen          sent data length.
+  * @param[in]   isSuccess        sent state.
+  * @param[in]   message          detailed message.
+  */
+ void CALogSendStateInfo(CATransportAdapter_t adapter,
+                         const char *addr, uint16_t port, ssize_t sentLen,
+                         bool isSuccess, const char* message);
+ /**
+  * print adapter state in the adapter.
+  * @param[in]   adapter          transport adapter type.
+  * @param[in]   state            adapter state.
+  */
+ void CALogAdapterStateInfo(CATransportAdapter_t adapter, CANetworkStatus_t state);
+ /**
+  * print adapter type name in the adapter.
+  * @param[in]   adapter          transport adapter type.
+  */
+ void CALogAdapterTypeInfo(CATransportAdapter_t adapter);
+ #endif
  #ifdef __cplusplus
  } /* extern "C" */
  #endif
@@@ -233,21 -258,29 +233,21 @@@ JavaVM *CANativeJNIGetJavaVM(
      return g_jvm;
  }
  
 -void CANativeSetActivity(JNIEnv *env, jobject activity)
 +void CADeleteGlobalReferences(JNIEnv *env)
  {
 -    OIC_LOG_V(DEBUG, CA_ADAPTER_UTILS_TAG, "CANativeSetActivity");
 -
 -    if (!activity)
 +#ifdef __ANDROID__
 +    if (g_Context)
      {
 -        OIC_LOG(ERROR, CA_ADAPTER_UTILS_TAG, "activity is null");
 -        return;
 +        (*env)->DeleteGlobalRef(env, g_Context);
 +        g_Context = NULL;
      }
  
 -    if (!g_Activity)
 -    {
 -        g_Activity = (*env)->NewGlobalRef(env, activity);
 -    }
 -    else
 +    if (g_Activity)
      {
 -        OIC_LOG(INFO, CA_ADAPTER_UTILS_TAG, "activity is already set");
 +        (*env)->DeleteGlobalRef(env, g_Activity);
 +        g_Activity = NULL;
      }
- #endif
 -}
 -
 -jobject *CANativeGetActivity()
 -{
 -    return g_Activity;
++#endif //__ANDROID__
  }
  
  jmethodID CAGetJNIMethodID(JNIEnv *env, const char* className,
      return jni_midID;
  }
  
 -void CADeleteGlobalReferences(JNIEnv *env)
+ bool CACheckJNIException(JNIEnv *env)
+ {
+     if ((*env)->ExceptionCheck(env))
+     {
+         (*env)->ExceptionDescribe(env);
+         (*env)->ExceptionClear(env);
+         return true;
+     }
+     return false;
+ }
 +#ifdef __ANDROID__
 +void CANativeJNISetContext(JNIEnv *env, jobject context)
  {
 -    if (g_Context)
 +    OIC_LOG_V(DEBUG, CA_ADAPTER_UTILS_TAG, "CANativeJNISetContext");
 +
 +    if (!context)
      {
 -        (*env)->DeleteGlobalRef(env, g_Context);
 -        g_Context = NULL;
 +        OIC_LOG(ERROR, CA_ADAPTER_UTILS_TAG, "context is null");
 +        return;
      }
  
 -    if (g_Activity)
 +    if (!g_Context)
      {
 -        (*env)->DeleteGlobalRef(env, g_Activity);
 -        g_Activity = NULL;
 +        g_Context = (*env)->NewGlobalRef(env, context);
 +    }
 +    else
 +    {
 +        OIC_LOG(INFO, CA_ADAPTER_UTILS_TAG, "context is already set");
      }
  }
 -#endif
 +
 +jobject CANativeJNIGetContext()
 +{
 +    return g_Context;
 +}
 +
 +void CANativeSetActivity(JNIEnv *env, jobject activity)
 +{
 +    OIC_LOG_V(DEBUG, CA_ADAPTER_UTILS_TAG, "CANativeSetActivity");
 +
 +    if (!activity)
 +    {
 +        OIC_LOG(ERROR, CA_ADAPTER_UTILS_TAG, "activity is null");
 +        return;
 +    }
 +
 +    if (!g_Activity)
 +    {
 +        g_Activity = (*env)->NewGlobalRef(env, activity);
 +    }
 +    else
 +    {
 +        OIC_LOG(INFO, CA_ADAPTER_UTILS_TAG, "activity is already set");
 +    }
 +}
 +
 +jobject *CANativeGetActivity()
 +{
 +    return g_Activity;
 +}
- #endif
++#endif //__ANDROID__
++#endif //JAVA__
+ #ifndef WITH_ARDUINO
+ void CALogAdapterStateInfo(CATransportAdapter_t adapter, CANetworkStatus_t state)
+ {
+     OIC_LOG(DEBUG, CA_ADAPTER_UTILS_TAG, "CALogAdapterStateInfo");
+     OIC_LOG(DEBUG, ANALYZER_TAG, "=================================================");
+     CALogAdapterTypeInfo(adapter);
+     if (CA_INTERFACE_UP == state)
+     {
+         OIC_LOG(DEBUG, ANALYZER_TAG, "adapter status is changed to CA_INTERFACE_UP");
+     }
+     else
+     {
+         OIC_LOG(DEBUG, ANALYZER_TAG, "adapter status is changed to CA_INTERFACE_DOWN");
+     }
+     OIC_LOG(DEBUG, ANALYZER_TAG, "=================================================");
+ }
+ void CALogSendStateInfo(CATransportAdapter_t adapter,
+                         const char *addr, uint16_t port, ssize_t sentLen,
+                         bool isSuccess, const char* message)
+ {
+     OIC_LOG(DEBUG, CA_ADAPTER_UTILS_TAG, "CALogSendStateInfo");
+     OIC_LOG(DEBUG, ANALYZER_TAG, "=================================================");
+     if (true == isSuccess)
+     {
+         OIC_LOG_V(DEBUG, ANALYZER_TAG, "Send Success, sent length = [%d]", sentLen);
+     }
+     else
+     {
+         OIC_LOG_V(DEBUG, ANALYZER_TAG, "Send Failure, error message  = [%s]",
+                   message != NULL ? message : "no message");
+     }
+     CALogAdapterTypeInfo(adapter);
+     OIC_LOG_V(DEBUG, ANALYZER_TAG, "Address = [%s]:[%d]", addr, port);
+     OIC_LOG(DEBUG, ANALYZER_TAG, "=================================================");
+ }
+ void CALogAdapterTypeInfo(CATransportAdapter_t adapter)
+ {
+     switch(adapter)
+     {
+         case CA_ADAPTER_IP:
+             OIC_LOG(DEBUG, ANALYZER_TAG, "Transport Type = [OC_ADAPTER_IP]");
+             break;
+         case CA_ADAPTER_TCP:
+             OIC_LOG(DEBUG, ANALYZER_TAG, "Transport Type = [OC_ADAPTER_TCP]");
+             break;
+         case CA_ADAPTER_GATT_BTLE:
+             OIC_LOG(DEBUG, ANALYZER_TAG, "Transport Type = [OC_ADAPTER_GATT_BTLE]");
+             break;
+         case CA_ADAPTER_RFCOMM_BTEDR:
+             OIC_LOG(DEBUG, ANALYZER_TAG, "Transport Type = [OC_ADAPTER_RFCOMM_BTEDR]");
+             break;
+         default:
+             OIC_LOG_V(DEBUG, ANALYZER_TAG, "Transport Type = [%d]", adapter);
+             break;
+     }
+ }
  #endif