Salome HOME
integration modif occ pour ssl
authorPASCALE NOYRET <pascale.noyret@edf.fr>
Wed, 19 Jan 2022 09:45:23 +0000 (10:45 +0100)
committerPASCALE NOYRET <pascale.noyret@edf.fr>
Wed, 19 Jan 2022 09:45:23 +0000 (10:45 +0100)
resources/CMakeLists.txt
src/EFICAS/CMakeLists.txt
src/EFICAS/EFICAS.py
src/EFICAS/EFICAS_SalomeSessionless.py [new file with mode: 0644]

index 0983e1250f53fbb9ceef274d8a1ae0ccb65394f6..d15f955e0ad80798dbeb0557a2ceba59b45ee90b 100644 (file)
@@ -37,4 +37,5 @@ SET(EFICAS_RESOURCES_FILES
 INSTALL(FILES ${EFICAS_RESOURCES_FILES} DESTINATION ${SALOME_EFICAS_INSTALL_RES_DATA})
 
 SALOME_CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/SalomeApp.xml.in ${CMAKE_CURRENT_BINARY_DIR}/SalomeApp.xml INSTALL ${SALOME_EFICAS_INSTALL_RES_DATA})
+SALOME_CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/SalomeApp.xml.in ${CMAKE_CURRENT_BINARY_DIR}/SalomeAppSL.xml INSTALL ${SALOME_EFICAS_INSTALL_RES_DATA})
 SALOME_CONFIGURE_FILE(${CMAKE_CURRENT_SOURCE_DIR}/EFICASCatalog.xml.in ${CMAKE_CURRENT_BINARY_DIR}/EFICASCatalog.xml INSTALL ${SALOME_EFICAS_INSTALL_RES_DATA})
index f9393c87c4af89197d33d6ea81e7c10152b1c585..5f9a5279badc82c383598098be5d6e74e5c06269 100644 (file)
@@ -22,6 +22,7 @@
 # scripts / static
 SET(_bin_SCRIPTS
   EFICAS.py
+  EFICAS_SalomeSessionless.py
 )
 
 # --- rules ---
index 967973f6d9ee901d0d408cb2e6d73c8973dc5280..dfbb3b890d275c34bcc2311e9e70da6f333e0d67 100644 (file)
@@ -21,6 +21,7 @@
 import EFICAS_ORB__POA
 import SALOMEDS__POA
 import SALOME_ComponentPy
+import SALOME_Embedded_NamingService_ClientPy
 
 class SALOME_DriverPy_i(SALOMEDS__POA.Driver):
     """
@@ -85,4 +86,11 @@ class EFICAS(EFICAS_ORB__POA.EFICAS_Gen,
         SALOME_DriverPy_i.__init__( self, 'OTHER' )                    
         # On stocke dans l'attribut _naming_service, une reference sur
         # le Naming Service CORBA
-        self._naming_service=SALOME_ComponentPy.SALOME_NamingServicePy_i(self._orb)
+        #
+        emb_ns = self._contId.get_embedded_NS_if_ssl()
+        import CORBA
+        if CORBA.is_nil(emb_ns):
+            self._naming_service = SALOME_ComponentPy.SALOME_NamingServicePy_i( self._orb )
+        else:
+            self._naming_service = SALOME_Embedded_NamingService_ClientPy.SALOME_Embedded_NamingService_ClientPy(emb_ns)
+        #
diff --git a/src/EFICAS/EFICAS_SalomeSessionless.py b/src/EFICAS/EFICAS_SalomeSessionless.py
new file mode 100644 (file)
index 0000000..818289b
--- /dev/null
@@ -0,0 +1,49 @@
+#  -*- coding: iso-8859-1 -*-
+# Copyright (C) 2021  CEA/DEN, EDF R&D
+#
+# This library is free software; you can redistribute it and/or
+# modify it under the terms of the GNU Lesser General Public
+# License as published by the Free Software Foundation; either
+# version 2.1 of the License, or (at your option) any later version.
+#
+# This library is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+# Lesser General Public License for more details.
+#
+# You should have received a copy of the GNU Lesser General Public
+# License along with this library; if not, write to the Free Software
+# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
+#
+# See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
+#
+
+def buildInstance(orb):
+    from EFICAS import EFICAS
+
+    # set SSL mode, if not done yes
+    import KernelBasis
+    KernelBasis.setSSLMode(True)
+
+    # check if EFICAS is already registered
+    import KernelServices
+    try:
+        return KernelServices.RetrieveCompo("EFICAS"), orb
+    except Exception:
+        pass
+
+    # initialize and register EFICAS engine
+    import PortableServer
+    obj = orb.resolve_initial_references("RootPOA")
+    poa = obj._narrow(PortableServer.POA)
+    pman = poa._get_the_POAManager()
+    pman.activate()
+    #
+    from SALOME_ContainerPy import SALOME_ContainerPy_SSL_i
+    cont = SALOME_ContainerPy_SSL_i(orb, poa, "FactoryServer")
+    conObj = poa.id_to_reference(poa.activate_object(cont))
+    #
+    servant = EFICAS(orb, poa, conObj, "FactoryServer", "EFICAS_inst_1", "EFICAS")
+    ret = servant.getCorbaRef()
+    KernelServices.RegisterCompo("EFICAS", ret)
+    return ret, orb