AdapterControlPort_Pki.partC 2.74 KB
Newer Older
Yann Garcia's avatar
Yann Garcia committed
#include <TTCN3.hh>

#include "LibItsPki_TestSystem.hh"

Yann Garcia's avatar
Yann Garcia committed
#include "loggers.hh"
#include "registration.hh"

#include "pki_layer.hh"
Yann Garcia's avatar
Yann Garcia committed

//=============================================================================
namespace LibItsPki__TestSystem {

  AdapterControlPkiPort::AdapterControlPkiPort(const char *par_port_name)
    : AdapterControlPkiPort_BASE(par_port_name), _params()
Yann Garcia's avatar
Yann Garcia committed
  {
    loggers::get_instance().log("AdapterControlPkiPort::AdapterControlPkiPort");
  AdapterControlPkiPort::~AdapterControlPkiPort()
  void AdapterControlPkiPort::set_parameter(const char * parameter_name, const char * parameter_value)
Yann Garcia's avatar
Yann Garcia committed
  {
    loggers::get_instance().log("AdapterControlPkiPort::set_parameter: %s=%s", parameter_name, parameter_value);
  /*void AdapterControlPkiPort::Handle_Fd_Event(int fd, boolean is_readable,
Yann Garcia's avatar
Yann Garcia committed
    boolean is_writable, boolean is_error) {}*/

  void AdapterControlPkiPort::Handle_Fd_Event_Error(int /*fd*/)
  void AdapterControlPkiPort::Handle_Fd_Event_Writable(int /*fd*/)
  void AdapterControlPkiPort::Handle_Fd_Event_Readable(int /*fd*/)
  /*void AdapterControlPkiPort::Handle_Timeout(double time_since_last_call) {}*/
Yann Garcia's avatar
Yann Garcia committed

  void AdapterControlPkiPort::user_map(const char * system_port)
Yann Garcia's avatar
Yann Garcia committed
  {
    loggers::get_instance().log(">>> AdapterControlPkiPort::user_map: %s", system_port);
  void AdapterControlPkiPort::user_unmap(const char * system_port)
Yann Garcia's avatar
Yann Garcia committed
  {
    loggers::get_instance().log(">>> AdapterControlPkiPort::user_unmap: %s", system_port);
  void AdapterControlPkiPort::user_start()
  void AdapterControlPkiPort::user_stop()
  void AdapterControlPkiPort::outgoing_send(const LibItsPki__TypesAndValues::AcPkiPrimitive& send_par)
Yann Garcia's avatar
Yann Garcia committed
  {
    loggers::get_instance().log_msg(">>> AdapterControlPkiPort::outgoing_send: ", send_par);
Yann Garcia's avatar
Yann Garcia committed
    
    // Register this object for AdapterControlPkiPort
Yann Garcia's avatar
Yann Garcia committed
    pki_layer* p = registration<pki_layer>::get_instance().get_item(std::string("PKI"));
Yann Garcia's avatar
Yann Garcia committed
    if (p != NULL) {
      loggers::get_instance().log("AdapterControlPkiPort::outgoing_send: Got PKI layer %p", p);
Yann Garcia's avatar
Yann Garcia committed
      LibItsPki__TypesAndValues::AcPkiResponse response;
      response.result() = BOOLEAN(false);
Yann Garcia's avatar
Yann Garcia committed
      if (send_par.ischosen(LibItsPki__TypesAndValues::AcPkiPrimitive::ALT_acSetSecurityData)) {
        loggers::get_instance().log("AdapterControlPkiPort::outgoing_send: AcSetSecurityData");
Yann Garcia's avatar
Yann Garcia committed
        p->set_pki_keys(send_par.acSetSecurityData());
        response.result() = BOOLEAN(true);
Yann Garcia's avatar
Yann Garcia committed
      }
      // Send response
      loggers::get_instance().log_msg("AdapterControlPkiPort::outgoing_send: Send response: ", response);
Yann Garcia's avatar
Yann Garcia committed
      incoming_message(response);
    } else {
      loggers::get_instance().error("AdapterControlPkiPort::outgoing_send: pkiPort not registered");
Yann Garcia's avatar
Yann Garcia committed
    }
  }

} /* end of namespace */