#include "hello.h" #ifdef HAVE_UNISTD_H #include #endif #ifdef _WINDOWS #include #endif #include using namespace SL3CM; using namespace std; int main (int argc, char *argv[]) { CORBA::ORB_var orb = CORBA::ORB_init (argc, argv); CORBA::Object_var obj = orb->resolve_initial_references ("TransportSecurity::SecurityManager"); TransportSecurity::SecurityManager_var secman = TransportSecurity::SecurityManager::_narrow(obj); assert(!CORBA::is_nil(secman)); TransportSecurity::CredentialsCurator_var curator = secman->credentials_curator(); obj = orb->resolve_initial_references("SL3TLS::ArgBuilderFactory"); SL3AQArgs::ArgBuilderFactory_var fact = SL3AQArgs::ArgBuilderFactory::_narrow(obj); assert(!CORBA::is_nil(fact)); SL3TLS::OpenSSLConfigArgBuilder_var builder = SL3TLS::OpenSSLConfigArgBuilder::_narrow (fact->create_arg_builder(SL3CM::CU_InitiateOnly)); assert(!CORBA::is_nil(builder)); builder->add_tcpip_initiator_options("localhost", 8789, 8799, 0); builder->add_tls_initiator_options("ca_cert.pem", "c_cert.pem", "c_key.pem"); builder->add_initiator_verify_depth(1); SL3AQArgs::Argument_var arg = builder->reap_args(); TransportSecurity::CredentialsAcquirer_ptr acquirer = curator->acquire_credentials(arg); TransportSecurity::OwnCredentials_ptr creds = acquirer->get_credentials(TRUE); CORBA::String_var id = creds->creds_id(); //cerr << "id: " << id.in() << endl; TransportSecurity::OwnCredentials_ptr c2 = curator->get_own_credentials(id.in()); //cerr << "c2id: " << c2->creds_id() << endl; MICOSL3Utils::PP::print_own_credentials(&wcout, c2); obj = orb->resolve_initial_references("SL3TCPIP::ArgBuilderFactory"); SL3AQArgs::ArgBuilderFactory_var fact2 = SL3AQArgs::ArgBuilderFactory::_narrow(obj); assert(!CORBA::is_nil(fact2)); SL3TCPIP::TCPIPArgBuilder_var builder2 = SL3TCPIP::TCPIPArgBuilder::_narrow (fact2->create_arg_builder(SL3CM::CU_InitiateOnly)); assert(!CORBA::is_nil(builder2)); builder2->add_tcpip_initiator_options("localhost", 15345, 15354, 0); SL3AQArgs::Argument_ptr arg2 = builder2->reap_args(); TransportSecurity::CredentialsAcquirer_ptr acquirer2 = curator->acquire_credentials(arg2); TransportSecurity::OwnCredentials_ptr creds2 = acquirer2->get_credentials(TRUE); CORBA::String_var id2 = creds2->creds_id(); //cerr << "id2: " << id2.in() << endl; TransportSecurity::OwnCredentials_ptr c3 = curator->get_own_credentials(id2.in()); //cerr << "c3id: " << c3->creds_id() << endl; MICOSL3Utils::PP::print_own_credentials(&wcout, c3); /* * IOR is in hello.ref in the local directory */ char pwd[256], uri[300]; sprintf (uri, "file://%s/hello.ref", getcwd(pwd, 256)); /* * Bind to Hello World server */ CORBA::Object_var obj2 = orb->string_to_object (uri); HelloWorld_var hello = HelloWorld::_narrow (obj2); if (CORBA::is_nil (hello)) { printf ("oops: could not locate HelloWorld server\n"); exit (1); } TransportSecurity::TargetCredentials_var tcreds1 = secman->get_target_credentials(hello); wcout << endl; wcout << "Target credentials:" << endl; MICOSL3Utils::PP::print_target_credentials(&wcout, tcreds1); hello->hello (); TransportSecurity::TargetCredentials_var tcreds2 = secman->get_target_credentials(hello); orb->destroy(); return 0; }