/** * 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; }