PkiPort.cc 3.9 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
// This Test Port skeleton source file was generated by the
// TTCN-3 Compiler of the TTCN-3 Test Executor version CRL 113 200/5 R3A
// for U-ERICSSON\ethgry (ethgry@HU00078339) on Fri Aug 14 21:19:06 2015

// Copyright Ericsson Telecom AB 2000-2014

// You may modify this file. Complete the body of empty functions and
// add your member functions here.

#include "PkiPort.hh"
garciay's avatar
garciay committed
11
12
#include "pki_layer_factory.hh"
#include "loggers.hh"
13
14
15

namespace LibItsPki__TestSystem {

garciay's avatar
garciay committed
16
17
18
19
20
  PkiPort::PkiPort(const char *par_port_name)
    : PkiPort_BASE(par_port_name), _cfg_params(), _layer_params(), _layer(nullptr), _time_key("PkiPort::outgoing_send") {
    // Nothing to do
    
  }
21

garciay's avatar
garciay committed
22
23
24
25
26
27
28
29
  PkiPort::~PkiPort()
  {
    loggers::get_instance().log(">>> PkiPort::~PkiPort");
    
    if (_layer != nullptr) {
      delete _layer;
    }
  }
30

garciay's avatar
garciay committed
31
32
33
34
35
  void PkiPort::set_parameter(const char* parameter_name, const char* parameter_value)
  {
    loggers::get_instance().log("PkiPort::set_parameter: %s=%s", parameter_name, parameter_value);
    _cfg_params.insert(std::pair<std::string, std::string>(std::string(parameter_name), std::string(parameter_value)));
  }
36

garciay's avatar
garciay committed
37
38
  /*void PkiPort::Handle_Fd_Event(int fd, boolean is_readable,
    boolean is_writable, boolean is_error) {}*/
39

garciay's avatar
garciay committed
40
41
  void PkiPort::Handle_Fd_Event_Error(int /*fd*/)
  {
42

garciay's avatar
garciay committed
43
  }
44

garciay's avatar
garciay committed
45
46
  void PkiPort::Handle_Fd_Event_Writable(int /*fd*/)
  {
47

garciay's avatar
garciay committed
48
  }
49

garciay's avatar
garciay committed
50
51
  void PkiPort::Handle_Fd_Event_Readable(int /*fd*/)
  {
52

garciay's avatar
garciay committed
53
  }
54

garciay's avatar
garciay committed
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
  /*void PkiPort::Handle_Timeout(double time_since_last_call) {}*/

  void PkiPort::user_map(const char* system_port)
  {
    loggers::get_instance().log(">>> PkiPort::user_map: %s", system_port);
    // Build layer stack
    params::iterator it = _cfg_params.find(std::string("params"));
    if (it != _cfg_params.end()) {
      loggers::get_instance().log("PkiPort::user_map: %s", it->second.c_str());
      // Setup parameters
      params::convert(_layer_params, it->second); // TODO This _layer_params seems to be useless
      // Create layer
      _layer = layer_stack_builder::get_instance()->create_layer_stack(it->second.c_str());
      if (static_cast<pki_layer *>(_layer) == nullptr) {
        loggers::get_instance().error("PkiPort::user_map: Invalid stack configuration: %s", it->second.c_str());
      }
      static_cast<pki_layer *>(_layer)->add_upper_port(this);
    
    } else {
      loggers::get_instance().error("PkiPort::user_map: No layers defined in configuration file");
    }
  }
77

garciay's avatar
garciay committed
78
79
80
  void PkiPort::user_unmap(const char* system_port)
  {
    loggers::get_instance().log(">>> PkiPort::user_unmap: %s", system_port);
81

garciay's avatar
garciay committed
82
83
84
85
86
87
    // Reset layers
    if (_layer != nullptr) {
      delete _layer;
      _layer = nullptr;
    }
  }
88

garciay's avatar
garciay committed
89
90
91
  void PkiPort::user_start()
  {
    loggers::get_instance().log(">>> PkiPort::user_start");
92

garciay's avatar
garciay committed
93
  }
94

garciay's avatar
garciay committed
95
96
97
  void PkiPort::user_stop()
  {
    loggers::get_instance().log(">>> PkiPort::user_stop");
98

garciay's avatar
garciay committed
99
  }
100

garciay's avatar
garciay committed
101
102
103
104
105
106
107
108
109
110
  void PkiPort::outgoing_send(const EtsiTs102941TypesEnrolment::InnerEcRequest& send_par)
  {
    loggers::get_instance().log_msg(">>> PkiPort::outgoing_send: payload=", send_par);
    
    float duration;
    loggers::get_instance().set_start_time(_time_key);
    params params;
    static_cast<pki_layer *>(_layer)->sendMsg(send_par, params);
    loggers::get_instance().set_stop_time(_time_key, duration);
  }
111

garciay's avatar
garciay committed
112
113
  void PkiPort::outgoing_send(const EtsiTs102941TypesEnrolment::InnerEcResponse& send_par)
  {
114

garciay's avatar
garciay committed
115
  }
Yann Garcia's avatar
Yann Garcia committed
116

garciay's avatar
garciay committed
117
118
119
120
121
122
  void PkiPort::receiveMsg (const EtsiTs102941TypesEnrolment::InnerEcRequest& p_ind, const params& p_params) {
    loggers::get_instance().log_msg(">>> PkiPort::receive_msg: ", p_ind);
    // Sanity check
    if (!p_ind.is_bound()) {
      return;
    }
Yann Garcia's avatar
Yann Garcia committed
123

garciay's avatar
garciay committed
124
    incoming_message(p_ind);
Yann Garcia's avatar
Yann Garcia committed
125
126
  }

garciay's avatar
garciay committed
127
128
129
130
131
132
  void PkiPort::receiveMsg (const EtsiTs102941TypesEnrolment::InnerEcResponse& p_ind, const params& p_params) {
    loggers::get_instance().log_msg(">>> PkiPort::receive_msg: ", p_ind);
    // Sanity check
    if (!p_ind.is_bound()) {
      return;
    }
Yann Garcia's avatar
Yann Garcia committed
133

garciay's avatar
garciay committed
134
    incoming_message(p_ind);
Yann Garcia's avatar
Yann Garcia committed
135
136
  }

137
138
} /* end of namespace */