Cl.Core.Sl
1.5.4
dotnet add package Cl.Core.Sl --version 1.5.4
NuGet\Install-Package Cl.Core.Sl -Version 1.5.4
<PackageReference Include="Cl.Core.Sl" Version="1.5.4" />
paket add Cl.Core.Sl --version 1.5.4
#r "nuget: Cl.Core.Sl, 1.5.4"
// Install Cl.Core.Sl as a Cake Addin #addin nuget:?package=Cl.Core.Sl&version=1.5.4 // Install Cl.Core.Sl as a Cake Tool #tool nuget:?package=Cl.Core.Sl&version=1.5.4
Acerca de Cl.Core.Sl
Conjunto de funcionalidades que nos permiten conectarnos a service layer e interactuar con los distintos procesos que este nos ofrece.
¿Qué resuelve?
La gestión de las configuraciones requeridas para poder interactuar con SAP a traves de service layer.
A su vez nos brinda una serie de extensiones para faciliar el control de operaciones post, patch y get.
Resumen de versión
Correcciones (Fixes)
- Se corrige un error que ocurria al enviar peticiones post que no fuesen adjuntos
Implementaciones
- Se agrega la funcionalidad de enviar adjuntos a SAP por medio de SL
- Se actualizan los README de structures y Sl para mejorar la compresion de los nuevos flujos implementados
Rutinas de extensión
Consultas con service layer
Permite consumir una vista expuesta de service layer. Obtiene todos los registros sin aplicar ningún filtro.
Detalles de implementación
Extiende a: Cl.Core.Structures.Classes.PresentationEntities.ClUserContext
Función: Get : Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Ejemplo:
// La función ConfigurarContexto conecta a la base de datos y obtiene licencia, series, entre otros. Crear su propia función que realice este proceso.
ClUserContext oClUserContext = ConfigurarContext();
// En la siguiente línea podemos ver como la extensión nos devuelve el objeto configurado
// Importante tomar en cuenta que el objeto oClUserContext debe tener completa la variable Resource con el nombre de la vista de sap
SLRequestObject oSLRequestObject = oClUserContext.Get();
¿Y ahora cómo envío mi objeto recién configurado a service layer?
Consultas con service layer
Permite consumir vistas usando un modelo para mapearlo hacia ciertos filtros en el query string.
Detalles de implementación
Extiende a: Cl.Core.Structures.Classes.PresentationEntities.ClUserContext
Función: Get : Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Parámetros:
- TObject _target(Opcional): Objecto que va a ser reemplazado en el query string. Si no se pasa este objeto el mapeador va a buscar en el diccionario de items de la sessión algún objeto expuesto mediante Cl.Core.Common.ActionFilters.QueryStringExposer
Ejemplo:
// Las siguientes instrucciones usualmente
// estarán en el Process.cs
// La función FuncionQueConfiguraObjeto se conecta
// a la base de datos app y obtiene credenciales de sap
ClUserContext oClUserContext = FuncionQueConfiguraObjeto();
// En la siguiente línea podemos ver como la extensión nos devuelve el objeto configurado
// Importante tomar en cuenta que el objeto oClUserContext debe tener completa la variable Resource con el nombre de la vista de sap.
SLRequestObject oSLRequestObject = oClUserContext.Get();
¿Y ahora cómo envío mi objeto recién configurado a service layer?
Consultas paginadas con service layer
Nos permite realizar consultas a vistas expuestas de service layer implementando un mecanismo de paginación integrado con service layer
Detalles de implementación
- En nuestro WebApi.Config antes de habilitar el cors en la línea "config.EnableCors(corsAttr);" tenemos que llamar a "corsAttr.ClHeadersSetter();". Esto con la idea de poder exponer los encabezados que nos brindan el contexto sobre el estado de la paginación.
- Es requerido que en cada endpoint que represente nuestra consulta agregar la anotación [EnablePagination]
- Se deben agregar los siguientes encabezados: cl-sl-pagination-page: (número de página), cl-sl-pagination-page-size: (tamaño de la página)
En la respuesta de la petición se retorna una serie de encebezados que contienen los datos respectivos a la paginación solicitada.
Extiende a: Cl.Core.Structures.Classes.PresentationEntities.ClUserContext
Función: Get : Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Parámetros:
- TObject _target(Opcional): Objeto que va a ser reemplazado en el query string. Si no se pasa este objeto el mapeador va a buscar en el diccionario de items de la sessión algún objeto expuesto mediante CL.COMMON.ActionFilters.QueryStringExposer
Ejemplo:
// Las siguientes instrucciones usualmente
// estarán en el Process.cs
// La función FuncionQueConfiguraObjeto se conecta
// a la base de datos app y obtiene credenciales de sap
ClUserContext oClUserContext = FuncionQueConfiguraObjeto();
// En la siguiente línea podemos ver como la extensión nos devuelve el objeto configurado
// Importante tomar en cuenta que el objeto oClUserContext debe tener completa la variable Resource con el nombre de la vista de sap y los filtros respectivos.
SLRequestObject oSLRequestObject = oClUserContext.Get();
¿Y ahora cómo envío mi objeto recién configurado a service layer?
Crear con service layer
Para poder crear objetos con service layer es requerido configurar el contexto. Dicho contexto es el que contiene toda la información necesaria para conectarnos con service layer, especificar el objeto que ocupamos crear y tipo de operación a realizar con service layer.
Esta función nos termina devolviendo un objeto configurado listo para ser procesado.
Detalles de implementación
Extiende a: Cl.Core.Structures.Classes.PresentationEntities.ClUserContext
Función: Post : Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Parámetros:
- TObject _target: Objeto que va a ser creado en sap.
- System.String _fieldsToRemoveInHeaders(Opcional): Nombres de las propiedades que serán eliminadas de la cabecera de TObject separadas por comas. Ejemplo: "DocEntry,DocNum".
- System.String _fieldsToRemoveInLines(Opcional):Nombres de las propiedades que serán eliminadas de las líneas de TObject separadas por comas. Ejemplo: "LineNum,U_Udf". NOTA: El mapeador va a buscar una propiedad que se llama DocumentLines para realizar el proceso de eliminación de propieades
Ejemplo:
// Las siguientes instrucciones usualmente
// estarán en el Process.cs
// La función FuncionQueConfiguraObjeto se conecta
// a la base de datos app y obtiene credenciales de sap
ClUserContext oClUserContext = FuncionQueConfiguraObjeto();
// En la siguiente línea podemos ver como la extensión nos devuelve el objeto configurado
// La variable oInvoice contiene el objeto que será transaccionado con service layer
// El parámetro _fieldsToRemoveInHeaders contiene el string que presenta los datos de cabecera que serán eliminados de la variable oInvoice
SLRequestObject oSLRequestObject = oClUserContext.Post(oInvoice,_fieldsToRemoveInHeaders: "DocEntry,DocNum");
¿Y ahora cómo envío mi objeto recién configurado a service layer?
Actualizar con service layer
Para poder actualizar objetos con service layer es requerido configurar el contexto. Dicho contexto es el que contiene toda la información necesaria para conectarnos con service layer, especificar el objeto que ocupamos actualizar y tipo de operación a realizar con service layer.
Esta función nos termina devolviendo un objeto configurado listo para ser procesado.
Detalles de implementación
Extiende a: Cl.Core.Structures.Classes.PresentationEntities.ClUserContext
Función: Patch : Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Parámetros:
- TObject _target: Objeto que va a ser actualizado en sap.
- System.String _fieldsToRemoveInHeaders(Opcional): Nombres de las propiedades que serán eliminadas de la cabecera de TObject separadas por comas. Ejemplo: "DocEntry,DocNum".
- System.String _fieldsToRemoveInLines(Opcional):Nombres de las propiedades que serán eliminadas de las líneas de TObject separadas por comas. Ejemplo: "LineNum,U_Udf". NOTA: El mapeador va a buscar una propiedad que se llama DocumentLines para realizar el proceso de eliminación de propieades
Ejemplo:
// Las siguientes instrucciones usualmente
// estarán en el Process.cs
// La función FuncionQueConfiguraObjeto se conecta
// a la base de datos app y obtiene credenciales de sap
ClUserContext oClUserContext = FuncionQueConfiguraObjeto();
// Con la siguiente instrucción configuramos el objeto en modo patch
SLRequestObject oSLRequestObject = oClUserContext.Patch<Invoice>();
¿Y ahora cómo envío mi objeto recién configurado a service layer?
Enviar transacciones a service layer
Permite enviar un transacción de tipo GET, POST, PATCH
a service layer retornándonos un objeto de tipo T.
Detalles de implementación
Extiende a: Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Función: SendAsync : System.Threading.Tasks.Task<Cl.Core.Structures.Classes.Rebound.CLContext<T>>
Ejemplo:
// Las siguientes instrucciones usualmente
// estarán en el Process.cs
// La función FuncionQueConfiguraObjeto se encarga
// de agregar la información necesaria para conectar a sap
SLRequestObject oSLRequestObject = FuncionQueConfiguraObjeto();
// El generic que se le da el metodo es para indicar el eventual objeto que nos puede devolver sap
return await oSLRequestObject.SendAsync<Document>();
Consumo de Media Types
Permite enviar un transacción de tipo GET para el consumo diferentes tipos de archivos
Nota: Si ocupa un deserializador diferente puede pasarle un delegado a la función SendAsync
Posteriormente crear una solicitud interna al equipo de Dev Ops y Calidad, para solicitar la evaluación de su serializador y la inclusión respectiva al proyecto de nugets
Retorna un objeto tipo Cl.Core.Structures.Classes.Deserializers.Media<TPrimitive>
Detalles de implementación
Extiende a: Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Función: SendAsync<Cl.Core.Structures.Classes.Deserializers.Media<TPrimitive>, TPrimitive>(_deserializer: Deserializers.ReadAsBytes): System.Threading.Tasks.Task<Cl.Core.Structures.Classes.Rebound.CLContext<T>>
Ejemplo:
// Las siguientes instrucciones usualmente
// estarán en el Process.cs
// La función FuncionQueConfiguraObjeto se encarga
// de agregar la información necesaria para conectar a sap
SLRequestObject oSLRequestObject = FuncionQueConfiguraObjeto();
// Lee un stream de datos y los combierte a un array typo System.Byte. Permite consumir archivos como pdfs entre otros
// Recordar que TPrimitive es el tipo de dato genérico de nuestro media tipe, por ejemplo System.String, System.Int32
// Luego sólo debe procesar el media type según sus necesidadesreturn await oSLRequestObject.SendAsync<Cl.Core.Structure.Classes.Deserializers.Media<System.Byte[]>, System.Byte[]>(_deserializer: Deserializers.ReadAsBytes);
Respuesta de service layer sin necesidad de mappear
Permite obtener la respuesta de service layer sin necesidad de mapearla a un objeto.
Detalles de implementación
Objeto requerido: Cl.Core.Structures.Classes.ServiceLayer.UnmappedResponse
Ejemplo:
CLContext<UnmappedResponse> oClContext = await oSLRequestObject.SendAsync<UnmappedResponse>();
Enviar transacciones a service layer
Permite enviar un transacción de tipo GET, POST, PATCH, a service layer retornándonos una lista de objetos de tipo T.
Detalles de implementación
Extiende a: Cl.Core.Structures.Classes.ServiceLayer.SLRequestObject
Función: SendAsync : System.Threading.Tasks.Task<Cl.Core.Structures.Classes.Rebound.CLContext<System.Collections.Generics.List<T>>>
Ejemplo:
// Las siguientes instrucciones usualmente
// estarán en el Process.cs
// La función FuncionQueConfiguraObjeto se encarga
// de agregar la información necesaria para conectar a sap
SLRequestObject oSLRequestObject = FuncionQueConfiguraObjeto();
// El generic que se le da a el método es para
// indicar la eventual lista de objetos que nos puede devolver sap
return await oSLRequestObject.SendAsync<List<Document>>();
Procesamiento por lotes
Permite enviar un conjunto de transacciones a service layer, obtine una respuesta de tipo string en formato MINE.
Implementacion:
// Se deben crear objetos de tipo BatchRequest los cuales representan las transacciones que se enviarán a service layer
// Se debe agregar cada objeto a la lista de transacciones
// Se debe configurar el objeto SLRequestObject con la funcion BatchOperation(request)
// Se debe enviar el objeto SLRequestObject a service layer
//CLContext<UnmappedResponse> oClContext = await oSLRequestObject.SendAsync<UnmappedResponse>();
Cargar adjuntos en SAP
Permite agregar adjuntos en SAP a travez de SL recibiendo un base64.
Implementacion:
// Se debe crear una lista de objetos AttachmentRequest el cual contendrá una lista de adjuntos para enviar a SAP List<AttachmentRequest> attachmentRequestsList = addAttachmentsFunction(); // Se llama a la funcion Post para cosntruir la solicitud SLRequestObject requestModel = oClUserContext.Post(attachmentRequestsList); // Se debe enviar el objeto SLRequestObject a service layer await requestModel.SendAsync<MyRequestModel>();
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- Cl.Core.Common (>= 1.8.0-alpha)
- Cl.Core.Structures (>= 1.9.5)
- Swashbuckle.AspNetCore (>= 6.5.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Cl.Core.Sl:
Package | Downloads |
---|---|
Cl.Core.Udfs
Funcionalidades relacionadas con udfs dinámicos |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.5.4 | 103 | 12/20/2024 |
1.5.3-alpha | 69 | 12/9/2024 |
1.5.2-alpha | 79 | 12/6/2024 |
1.5.1-alpha | 73 | 11/29/2024 |
1.5.0-alpha | 79 | 11/22/2024 |
1.4.0-alpha | 234 | 8/21/2024 |
1.3.2 | 441 | 8/8/2024 |
1.3.2-alpha | 93 | 7/31/2024 |
1.3.1-alpha | 294 | 6/22/2024 |
1.3.0 | 117 | 6/11/2024 |
1.3.0-alpha | 112 | 5/31/2024 |
1.2.1 | 282 | 3/8/2024 |
1.2.1-alpha | 127 | 3/5/2024 |
1.2.0.2 | 146 | 2/16/2024 |
1.2.0.1 | 139 | 2/14/2024 |
1.2.0 | 322 | 11/28/2023 |
1.2.0-alpha | 123 | 11/17/2023 |
1.1.0 | 225 | 10/4/2023 |
1.1.0-alpha | 124 | 8/17/2023 |
1.0.0.2 | 193 | 7/7/2023 |
1.0.0.2-alpha | 98 | 8/17/2023 |
1.0.0.1 | 211 | 7/4/2023 |