/**
  * Devuelve un objeto WSF con la configuracion de certificados ssl existente o null
  * @param string $proyecto
  * @param string $servicio
  * @throws toba_error
  * @return WSSecurityToken
  */
 static function get_ws_token($proyecto, $servicio)
 {
     $security_token = null;
     self::get_modelo_proyecto($proyecto);
     $ini_conf = toba_modelo_servicio_web::get_ini_cliente(self::$modelo_proyecto, $servicio);
     $directorio = toba_instancia::instancia()->get_path_instalacion_proyecto($proyecto) . "/servicios_cli/{$servicio}";
     //Directorio perteneciente al servicio
     //Busco los datos para los certificados en el archivo perteneciente al servicio
     if (!is_null($ini_conf) && $ini_conf->existe_entrada('certificado')) {
         chdir($directorio);
         $config = $ini_conf->get_datos_entrada('certificado');
         //Cargo las claves y armo el objeto WSF
         if (!file_exists($config['clave_cliente'])) {
             throw new toba_error("El archivo " . $config['clave_cliente'] . " no existe");
         }
         $clave_cliente = ws_get_key_from_file($config['clave_cliente']);
         if (!file_exists($config['cert_cliente'])) {
             throw new toba_error("El archivo " . $config['cert_cliente'] . " no existe");
         }
         $cert_cliente = ws_get_cert_from_file($config['cert_cliente']);
         if (!file_exists($config['cert_servidor'])) {
             throw new toba_error("El archivo " . $config['cert_servidor'] . " no existe");
         }
         $cert_server = ws_get_cert_from_file($config['cert_servidor']);
         $security_token = new WSSecurityToken(array("privateKey" => $clave_cliente, "receiverCertificate" => $cert_server, "certificate" => $cert_cliente));
     }
     return $security_token;
 }
 function complementar_datos($datos)
 {
     $conf_final = array();
     $proyecto = $this->get_modelo_proyecto();
     $clave_privada = 'No hay archivo para la clave privada del proyecto';
     if (toba_modelo_servicio_web::existe_archivo_certificado($proyecto)) {
         $clave_privada = toba_modelo_servicio_web::path_clave_privada($proyecto);
     }
     //Tengo que agarrar los archivos ini de configuracion.
     foreach ($datos as $dato) {
         $id_servicio = $dato['servicio_web'];
         $conf_inicial = toba_modelo_servicio_web::get_ini_cliente($proyecto, $id_servicio);
         //Intento obtener la info del archivo de configuracion
         if ($conf_inicial->existe_entrada('conexion')) {
             $to = $conf_inicial->get('conexion', 'to');
             $conf_final[$id_servicio] = array_merge($dato, array('param_to' => $to, 'link_to' => "<a href='{$to}'> {$to} </a>"));
         } else {
             $conf_final[$id_servicio] = $dato;
         }
         if ($conf_inicial->existe_entrada('certificado', 'cert_servidor')) {
             $conf_final[$id_servicio]['cert_file'] = basename($conf_inicial->get('certificado', 'cert_servidor'));
         }
         $conf_final[$id_servicio]['clave_privada'] = $clave_privada;
     }
     return $conf_final;
 }