replace : iotivity -> iotivity-sec
[platform/upstream/iotivity.git] / resource / csdk / security / SConscript
index f1adb9c..964cdd1 100644 (file)
 ##
 
 Import('env')
+import os
 
 lib_env = env.Clone()
-SConscript(env.get('SRC_DIR') + '/resource/third_party_libs.scons', 'lib_env')
+SConscript('#resource/third_party_libs.scons', 'lib_env')
 
 libocsrm_env = lib_env.Clone()
 
-target_os = env.get('TARGET_OS')
+target_os = libocsrm_env.get('TARGET_OS')
 # As in the source code, it includes arduino Time library (C++)
 # It requires compile the .c with g++
 if target_os == 'arduino':
-       libocsrm_env.Replace(CC = env.get('CXX'))
-       libocsrm_env.Replace(CFLAGS = env.get('CXXFLAGS'))
+       libocsrm_env.Replace(CC = libocsrm_env.get('CXX'))
+       libocsrm_env.Replace(CFLAGS = libocsrm_env.get('CXXFLAGS'))
 
 ######################################################################
 # Build flags
 ######################################################################
+with_upstream_libcoap = libocsrm_env.get('WITH_UPSTREAM_LIBCOAP')
+if with_upstream_libcoap == '1':
+       # For bring up purposes only, we manually copy the forked version to where the unforked version is downloaded.
+       libocsrm_env.AppendUnique(CPPPATH = ['#extlibs/libcoap/libcoap/include'])
+else:
+       # For bring up purposes only, the forked version will live here.
+       libocsrm_env.AppendUnique(CPPPATH = ['../connectivity/lib/libcoap-4.1.1/include'])
+
 libocsrm_env.PrependUnique(CPPPATH = [
                '../../../extlibs/cjson/',
-#              '../../../extlibs/tinydtls/',
                '../logger/include',
-               '../ocrandom/include',
+               '../../c_common/ocrandom/include',
                '../stack/include',
                '../stack/include/internal',
                '../../oc_logger/include',
-               '../connectivity/lib/libcoap-4.1.1',
                '../connectivity/external/inc',
+               '../connectivity/common/inc',
                '../connectivity/inc',
                '../connectivity/api',
                '../security/include',
                '../security/include/internal',
+               '../security/provisioning/include'
                ])
 
-if target_os not in ['arduino', 'windows', 'winrt']:
-       libocsrm_env.AppendUnique(CPPDEFINES  = ['WITH_POSIX'])
-       libocsrm_env.AppendUnique(CFLAGS = ['-std=c99'])
-       libocsrm_env.AppendUnique(CPPDEFINES = ['HAVE_STRINGS_H'])
-
-if target_os not in ['windows', 'winrt']:
-       libocsrm_env.AppendUnique(CFLAGS = ['-Wall'])
+if target_os not in ['arduino', 'windows']:
+       libocsrm_env.AppendUnique(CPPDEFINES  = ['WITH_POSIX', '_GNU_SOURCE'])
+       libocsrm_env.AppendUnique(CFLAGS = ['-std=c99', '-Wall'])
 
-libocsrm_env.AppendUnique(LIBPATH = [env.get('BUILD_DIR')])
-libocsrm_env.AppendUnique(LIBS = ['coap', 'm'])
+libocsrm_env.AppendUnique(LIBPATH = [libocsrm_env.get('BUILD_DIR')])
+libocsrm_env.AppendUnique(LIBS = ['coap'])
 
 if target_os == 'arduino':
        libocsrm_env.AppendUnique(CPPDEFINES = ['NDEBUG', 'WITH_ARDUINO'])
-else:
+elif target_os not in ['windows', 'msys_nt']:
        libocsrm_env.AppendUnique(CFLAGS = ['-fPIC'])
+       libocsrm_env.AppendUnique(LIBS = ['m'])
+
+if target_os in ['windows', 'msys_nt']:
+       libocsrm_env.AppendUnique(LIBPATH = [os.path.join(libocsrm_env.get('BUILD_DIR'), 'resource', 'oc_logger')])
 
 if target_os in ['darwin', 'ios']:
        libocsrm_env.AppendUnique(CPPDEFINES = ['_DARWIN_C_SOURCE'])
-       libocsrm_env.AppendUnique(LIBPATH = [env.get('BUILD_DIR')])
+       libocsrm_env.AppendUnique(LIBPATH = [libocsrm_env.get('BUILD_DIR')])
        libocsrm_env.AppendUnique(LIBS = ['coap'])
 
-if not env.get('RELEASE'):
+if env.get('LOGGING'):
        libocsrm_env.AppendUnique(CPPDEFINES = ['TB_LOG'])
 
+if env.get('MULTIPLE_OWNER') == '1':
+       libocsrm_env.AppendUnique(CPPDEFINES=['MULTIPLE_OWNER'])
+
 ######################################################################
 # Source files and Targets
 ######################################################################
@@ -85,25 +97,52 @@ OCSRM_SRC = 'src/'
 libocsrm_src = [
        OCSRM_SRC + 'secureresourcemanager.c',
        OCSRM_SRC + 'resourcemanager.c',
-    OCSRM_SRC + 'aclresource.c',
-    OCSRM_SRC + 'amaclresource.c',
+       OCSRM_SRC + 'aclresource.c',
+       OCSRM_SRC + 'verresource.c',
+       OCSRM_SRC + 'amaclresource.c',
+       OCSRM_SRC + 'amsmgr.c',
        OCSRM_SRC + 'pstatresource.c',
        OCSRM_SRC + 'doxmresource.c',
        OCSRM_SRC + 'credresource.c',
-       OCSRM_SRC + 'svcresource.c',
+       OCSRM_SRC + 'pconfresource.c',
+       OCSRM_SRC + 'dpairingresource.c',
        OCSRM_SRC + 'policyengine.c',
        OCSRM_SRC + 'psinterface.c',
        OCSRM_SRC + 'srmresourcestrings.c',
        OCSRM_SRC + 'srmutility.c',
        OCSRM_SRC + 'iotvticalendar.c',
-       OCSRM_SRC + 'base64.c'
+       OCSRM_SRC + 'base64.c',
+       OCSRM_SRC + 'directpairing.c'
        ]
 
-libocsrm = libocsrm_env.StaticLibrary('libocsrm', libocsrm_src)
+if libocsrm_env.get('SECURED') == '1':
+       libocsrm_src = libocsrm_src + [OCSRM_SRC + 'oxmpincommon.c', OCSRM_SRC + 'pbkdf2.c']
+       libocsrm_src = libocsrm_src + [OCSRM_SRC + 'crlresource.c', OCSRM_SRC + 'pkix_interface.c']
+       libocsrm_src = libocsrm_src + [OCSRM_SRC + 'oxmverifycommon.c']
+       libocsrm_src = libocsrm_src + [OCSRM_SRC + 'psiutils.c'] # TODO : need for secure psi
+
+if target_os in ['windows', 'msys_nt']:
+       libocsrm_src  = libocsrm_src + [OCSRM_SRC + 'strptime.c']
+
+
+libocsrm_src.extend(env['cbor_files'])
+
+# Insert a hack for Arduino, whose compiler may not support all defines expected
+# by tinycbor
+if target_os in ['arduino']:
+       libocsrm_env.AppendUnique(CPPDEFINES = ['INT64_MAX=0x7FFFFFFFFFFFFFFF'])
+
+libocsrm_conf = Configure(libocsrm_env)
+if libocsrm_conf.CheckFunc('strptime'):
+       libocsrm_conf.env.AppendUnique(CPPDEFINES = ['HAVE_STRPTIME'])
+libocsrm_env = libocsrm_conf.Finish()
+
+libocsrm = libocsrm_env.StaticLibrary('ocsrm', libocsrm_src)
 
-libocsrm_env.InstallTarget(libocsrm, 'libocsrm')
-libocsrm_env.UserInstallTargetLib(libocsrm, 'libocsrm')
+libocsrm_env.InstallTarget(libocsrm, 'ocsrm')
 
-if env.get('SECURED') == '1':
-        SConscript('provisioning/SConscript')
+if target_os in ['linux', 'android', 'tizen', 'msys_nt', 'windows', 'ios'] and libocsrm_env.get('SECURED') == '1':
+       SConscript('provisioning/SConscript')
 
+if target_os in ['linux'] and libocsrm_env.get('SECURED') == '1':
+       SConscript('tool/SConscript')