CL.STRUCTURES 2.5.0

dotnet add package CL.STRUCTURES --version 2.5.0
NuGet\Install-Package CL.STRUCTURES -Version 2.5.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="CL.STRUCTURES" Version="2.5.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add CL.STRUCTURES --version 2.5.0
#r "nuget: CL.STRUCTURES, 2.5.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install CL.STRUCTURES as a Cake Addin
#addin nuget:?package=CL.STRUCTURES&version=2.5.0

// Install CL.STRUCTURES as a Cake Tool
#tool nuget:?package=CL.STRUCTURES&version=2.5.0

Acerca de CL.STRUCTURES

Contiene todas aquellas estructuras que se han considerado estandar en todos los procesos que pueden presentar las aplicaciones.

¿Qué resuelve?

Cada vez que tenemos que lidiar con la creación de esctructuras de datos, como clases, interfaces, exisite un conjunto de estos que son muy similiar en cuanto comportamiento y al no existir un estandar los desarrolladores declaran clases como por ejemplo user o User y con las propiedades Nombre o nombre, incluso en inglés Name o name. La idea con este nuget es poder agrupar todas estas estructuras para que en la mayoría de proyectos tengamos esta consistencia al momento de implementar nuevas funcionalidades.

Resumen de versión

Cambios (Changes)

  • Nueva estructuras agregadas para el manejo de procesamiento por lotes.
  • Nueva estructuras agregadas para el manejo de respuestas de SL sin necesidad de mapeo a un objeto.

Clases

Response<T>

  • T Data: Va a contener la información que deseamos retornar.
  • System.String Message: Variable opcional para indicar algún evento que queramos comunicar.
  • Reponse(): Contructor base de la base
  • Reponse(System.Exception): Contructor que nos permite de manera automática mapear una excepción y retornarla al ui.

Usada generalmente para contener tanto la información como el detalle de un error que queramos indicar.

Ejemplo:

// Este método retorna un objeto de tipo Context<T>, pero se accede a la propiedad response al final
var user = Execute<User, AppContext, System.Int16>("spGetUserById", 5).Response;

Context<T>

  • CL.STRUCTURES.CLASSES.Response<T> Response: Objeto genérico que contiene la información a retornar.
  • System.Net.HttpStatusCode Code: Estatus de la petición tras haber sido ejecutada.

Esta clase representa el estado final de una transacción que hayamos intentado hacer en nuestro backend, la cual debe ser evaluda según el código http.

Ejemplo:

// Este método retorna un objeto de tipo context
var user = Execute<User, AppContext, System.Int16>("spGetUserById", 5);

BatchRequest

  • Cl.Structures.Classes.ServiceLayer.BatchRequest BatchRequest: Objeto que almacenara la transacción a realizar en un lote.

Esta clase representa la transaccion que vamos ajecutar en el lote creado en SL.

Ejemplo:

var request = new BatchRequest(){ Id = 1, Verb = GET, ChangeSet = 1, Url = "Items('B001'')",Content=""

UnmappedResponse

  • Cl.Structures.Classes.ServiceLayer.UnmappedResponse unmappedResponse: Objeto que almacena la respuesta de SL en formato String

Ejemplo:

CLContext<UnmappedResponse> oClContext = await oSLRequestObject.SendAsync<UnmappedResponse>();

Interfaces

ICLMaster

Usada para definir límites en funciones, por ejemplo en contraints

Ejemplo:

// Usada en una función para indicar que solo podemos usar objetos que implementes esta interfaz
where V : CL.STRUCTURES.INTERFACES.ICLMaster

ICLInclude

Usada para indicar que se deben incluir los elementos según en el contexto en el que se use.

Ejemplo:

// Incluyendo la propiedad "Id" en la la lista.
var users = Execute<User, AppContext, CL.STRUCTURES.INTERFACES.ICLInclude>("spGetUsers", user, new System.String[] { "Id" });

ICLExclude

Usada para indicar que se deben excluir los elementos según en el contexto en el que se use.

Ejemplo:

// Excluyendo la propiedad "Id" en la lista.
// var users= Execute<User, AppContext, CL.STRUCTURES.INTERFACES.ICLExclude>("spGetUsers", user, new System.String[] { "Id" });

Enums

EmailDomains

Nos permite conocer los dominios que podría procesar una aplicación

Ejemplo:

// Uso del enum
var valor = CL.STRUCTURES.Enums.EmailDomains.Gmail;

DaysOfWeek

Contiene los días de la semana, el primer día es el Domingo.

Ejemplo:

// Uso del enum
var valor = CL.STRUCTURES.Enums.DaysOfWeek.Su;

UdfType

Nos informa sobre el tipo de datos que permiten los UDFs.

Ejemplo:

// Uso del enum
var valor = CL.STRUCTURES.Enums.UdfType.Numeric;

ObjectStatus

Indica el estado en el que se encuentra un objeto.

Ejemplo:

// Uso del enum
var valor = CL.STRUCTURES.Enums.ObjectStatus.Stashed;

ObjectTypes

Representa todos los objetos que sap puede manejar a nivel del sdk.

Ejemplo:

// Uso del enum
var valor = CL.STRUCTURES.Enums.ObjectTypes.Items;

Clavis Consultores ©

Product Compatible and additional computed target framework versions.
.NET Framework net462 is compatible.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (6)

Showing the top 5 NuGet packages that depend on CL.STRUCTURES:

Package Downloads
CL.COMMON

Conjunto de librerías a modo de utilidades

CL.DB

Servicios para facilitar la manipulacion de las bases de datos

CL.SL

Librería que permite interactuar con service layer

CL.AUTH

Servicios para recuperacion y cambio de contraseñas

CL.UDFS

Implementación de udfs dinámicos

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.5.0 68 6/11/2024
2.4.0 95 4/18/2024
2.3.0 121 3/1/2024
2.2.2 108 1/26/2024
2.2.1 89 1/19/2024
2.2.0 287 11/28/2023
2.1.4 142 9/18/2023
2.1.3 158 7/27/2023
2.1.2 162 5/16/2023
2.1.1 106 5/16/2023
2.1.0 180 5/3/2023
2.0.0 200 4/11/2023
1.0.8 290 2/20/2023
1.0.7 222 2/17/2023
1.0.6 232 2/10/2023
1.0.5 251 1/31/2023
1.0.4 244 1/31/2023
1.0.2 255 1/25/2023
1.0.1 262 1/19/2023
1.0.0 409 1/18/2023