OpenAPI | Client

TsgcOpenAPI_Client es un componente no visual que encapsula los principales métodos y propiedades para realizar solicitudes HTTP a partir de una especificación OpenAPI.

 

Cada interfaz OpenAPI creada con sgcOpenAPI Parser tiene 2 métodos

 

  1. GetOpenAPIClient: es una función singleton que devuelve una instancia de la clase principal; si no existe, la crea automáticamente.
  2. FreeOpenAPIClient: libera la clase principal si ha sido creada.

 

Ejemplo

Use Abstractapi para recuperar la localización de una dirección IP.


GetOpenAPIClient.Retrieve_the_location_of_an_IP_address('your api', '80.258.15.2');

 

 

Autenticación

 

TLSOptions

Permite configurar cómo conectarse a servidores seguros SSL/TLS usando el protocolo HTTP/1

 

ALPNProtocols: lista de los protocolos ALPN que se enviarán al servidor.

RootCertFile: ruta al archivo de certificado raíz.

CertFile: ruta al archivo de certificado.

KeyFile: ruta al archivo de clave del certificado.

Password: si el certificado está protegido con contraseña, configúrela aquí.

VerifyCertificate: si se debe verificar el certificado, habilite esta propiedad.

VerifyDepth: es una propiedad Integer que representa el número máximo de enlaces permitidos al realizar la verificación del certificado X.509.

Version: por defecto utiliza TLS 1.0; si el servidor requiere una versión TLS superior, puede seleccionarse aquí.

IOHandler: seleccione qué biblioteca utilizará para la conexión mediante TLS.

iohOpenSSL: utiliza la biblioteca OpenSSL y es la opción predeterminada para los componentes Indy. Requiere desplegar las bibliotecas OpenSSL para win32/win64.

iohSChannel: utiliza Secure Channel, que es un protocolo de seguridad implementado por Microsoft para Windows, no requiere desplegar bibliotecas OpenSSL. Solo funciona en Windows 32/64 bits.

OpenSSL_Options: configuración de las bibliotecas OpenSSL.

APIVersion: permite definir qué API de OpenSSL se utilizará.

oslAPI_1_0: utiliza API 1.0 de OpenSSL, la última versión compatible con Indy

oslAPI_1_1: utiliza la API 1.1 de OpenSSL, requiere nuestra biblioteca Indy personalizada y permite usar las bibliotecas OpenSSL 1.1.1 (con soporte para TLS 1.3).

oslAPI_3_0: usa la API 3.0 de OpenSSL, requiere nuestra biblioteca Indy personalizada y permite usar las bibliotecas OpenSSL 3.0.0 (con soporte TLS 1.3).

LibPath: aquí puede configurar dónde se encuentran las bibliotecas openSSL

oslpNone: es el valor predeterminado; las bibliotecas openSSL deben estar en la misma carpeta donde se encuentra el binario o en una ruta conocida.

oslpDefaultFolder: establece automáticamente la ruta de openSSL donde deben ubicarse las bibliotecas para todas las personalidades del IDE.

oslpCustomFolder: si esta es la opción seleccionada, defina la ruta completa en la propiedad LibPathCustom.

LibPathCustom: cuando LibPath = oslpCustomFolder, defina aquí la ruta completa donde se encuentran las bibliotecas openSSL.

UnixSymLinks: habilita o deshabilita la carga de SymLinks en sistemas Unix (por defecto está habilitado, excepto en OSX64):

oslsSymLinksDefault: están habilitados por defecto excepto en OSX64 (tras MacOS Monterey, falla al intentar cargar la biblioteca sin versión.).

oslsSymLinksLoadFirst: Cargar los SymLinks antes de intentar cargar las bibliotecas de versión.

oslsSymLinksLoad: Cargar SymLinks después de intentar cargar las bibliotecas de versión.

oslsSymLinksDontLoad: no carga los SymLinks.

SChannel_Options: permite usar un certificado del almacén de certificados de Windows.

CertHash: es el Hash del certificado. Puede encontrar el Hash del certificado ejecutando un comando dir en powershell.

CipherList: aquí puede establecer qué cifrados se utilizarán (separados por ":"). Ejemplo: CALG_AES_256:CALG_AES_128

CertStoreName: el nombre del almacén donde se guarda el certificado. Seleccione una de las siguientes opciones:

scsnMY (el predeterminado)

scsnCA

scsnRoot

scsnTrust

CertStorePath: la ruta del almacén donde se guarda el certificado. Seleccione una de las siguientes:

scspStoreCurrentUser (el valor predeterminado)

scspStoreLocalMachine

 

 

 

Opciones de proxy

Use esta propiedad para configurar las conexiones a través de un proxy.

 

Enabled: establézcalo en true para habilitar las conexiones a través de proxy.

Host: Dirección del servidor proxy

Port: Puerto del servidor proxy

UserName/Password: Autenticación para conectarse al proxy, solo si es necesario.

ProxyType: se admiten los siguientes proxies:

Registro

Si la propiedad Log está habilitada, guarda los mensajes del socket en un archivo de registro especificado, lo que resulta útil para la depuración.

 

Log: actívelo si desea guardar las solicitudes HTTP en un archivo de texto.

LogFileName: ruta completa al nombre del archivo.

 

Propiedades

Otras propiedades que se pueden usar para personalizar el cliente OpenAPI:

 

EncodeBodyAsUTF8: si está habilitado, el cuerpo JSON se codifica como UTF8 (de forma predeterminada false).

 

 

Eventos

A continuación encontrará la lista de eventos que puede gestionar al usar el cliente OpenAPI.

 

 

OnBeforeRequest

 

Este evento se invoca antes de que se realice la solicitud HTTP. Permite personalizar los nombres de parámetros, encabezados, seguridad... A continuación se muestra un ejemplo de cómo reemplazar el nombre de algunos parámetros.

 


procedure OnBeforeRequestEvent(Sender: TObject; const aRequest: TsgcOpenAPIRequest);
var
  i: Integer;
  oParameter: TsgcOpenAPIParameter;
begin
  for i := 0 to aRequest.Parameters.Count - 1 do
  begin
    oParameter := aRequest.Parameters[i];
    if oParameter._Name = 'meta-modified-from' then
      oParameter._name := 'eventDateTime-from';
    if oParameter._Name = 'meta-modified-to' then
      oParameter._name := 'eventDateTime-to';
  end;
end;

OnUpload

 

Este evento se llama cuando se carga un archivo; puede usar este evento para conocer el progreso de la carga.

 

OnDownload

 

Este evento se llama cuando se descarga un archivo; puede usarlo para conocer el progreso de la descarga.

 

OnSSLVerifyPeer

 

Si la verificación del certificado está habilitada, en este evento puede verificar y decidir si acepta el certificado del servidor.

 

OnSSLGetHandler

 

Este evento se genera antes de crear el controlador SSL; aquí puede crear su propio controlador SSL (debe heredar de TIdServerIOHandlerSSLBase o TIdIOHandlerSSLBase) y establecer las propiedades necesarias.

 

OnSSLAfterCreateHandler

 

Si no se ha creado ningún objeto SSL personalizado, se crea por defecto utilizando el controlador OpenSSL. Puede acceder a las propiedades del controlador SSL y modificarlas si es necesario.