Cosmos.Contabilidad.Mensajeria 0.0.3

dotnet add package Cosmos.Contabilidad.Mensajeria --version 0.0.3
                    
NuGet\Install-Package Cosmos.Contabilidad.Mensajeria -Version 0.0.3
                    
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="Cosmos.Contabilidad.Mensajeria" Version="0.0.3" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Cosmos.Contabilidad.Mensajeria" Version="0.0.3" />
                    
Directory.Packages.props
<PackageReference Include="Cosmos.Contabilidad.Mensajeria" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Cosmos.Contabilidad.Mensajeria --version 0.0.3
                    
#r "nuget: Cosmos.Contabilidad.Mensajeria, 0.0.3"
                    
#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.
#:package Cosmos.Contabilidad.Mensajeria@0.0.3
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Cosmos.Contabilidad.Mensajeria&version=0.0.3
                    
Install as a Cake Addin
#tool nuget:?package=Cosmos.Contabilidad.Mensajeria&version=0.0.3
                    
Install as a Cake Tool

Cosmos.Contabilidad.Mensajeria

Extensiones de Wolverine para integrarse con el sub-dominio de Contabilidad del ERP Cosmos. Configura la publicación de hechos económicos y la recepción de resultados de contabilización sobre RabbitMQ.

Si solo necesitas los contratos (sin Wolverine), usa el paquete Cosmos.Contabilidad.Contratos.

Instalación

dotnet add package Cosmos.Contabilidad.Mensajeria

Configuración

En las WolverineOptions del servicio productor (OXP, CXC, Tesorería, etc.):

options.HabilitarContabilidad("MiServicio-From-Contabilidad");

Esto configura:

  1. La publicación de HechoEconomicoCreado a la cola de Contabilidad (Contabilidad-HechosEconomicos) con Outbox durable. Se publica directo a la cola —no al exchange— para evitar el echo hacia la propia cola de resultados.
  2. La suscripción al exchange de Contabilidad para recibir HechoEconomicoContabilizado y HechoEconomicoRechazado.

Ejemplo de uso

// Program.cs del sub-dominio productor
builder.Host.UsarWolverineParaComandos(
    typeof(IDominioAssemblyMarker).Assembly,
    connectionString, "MiSchema",
    builder.Environment.IsDevelopment(),
    options =>
    {
        options.HabilitarRabbitMq("RabbitMQ");
        options.HabilitarOutbox(serviceName, typeof(IContratosAssemblyMarker).Assembly);
        options.HabilitarInbox();

        // Una línea para conectarse con Contabilidad
        options.HabilitarContabilidad("MiServicio-From-Contabilidad");
    }
);
// En el handler que causa el hecho económico
using Cosmos.Contabilidad.Contratos.ServicioDeTraduccion.Eventos;
using Cosmos.Contabilidad.Contratos.ServicioDeTraduccion.Modelos;
using Cosmos.Types;

var origen = new Origen(
    ReferenciaOrigen: "oxp-comercio-123/causada",
    SubDominioOrigen: "OXP",
    DocumentoFuente: "FAC-5678",
    ReferenciaHechoRelacionado: null);

var transaccion = new ContextoTransaccion(
    TipoTransaccion: "causacion_gasto",
    Empresa: new Empresa("31", "900123456", "Cosmos SAS"),
    Moneda: Moneda.COP,
    Fecha: DateTime.UtcNow);

var lineas = new List<LineaTraduccion>
{
    new(
        new ConceptoEconomico("gasto", "HONORARIOS", 1_000_000m),
        new DatosTercero("Nike", "NIT", "900123456"),
        UnidadOrganizacional: "VTA-001")
};

await publicEventSender.PublishAsync(new HechoEconomicoCreado(origen, transaccion, lineas));
// Consumer para recibir el resultado de contabilización [R17]
public class HechoContabilizadoConsumer
    : ICommandHandlerAsync<HechoEconomicoContabilizado>
{
    public Task HandleAsync(HechoEconomicoContabilizado evento, CancellationToken ct)
    {
        // evento.Origen.ReferenciaOrigen → identifica la transacción de origen
        // evento.ReferenciaDestino       → consecutivo del asiento en SincoA&F
        // evento.Destino                 → libro/sistema destino donde quedó el asiento
        return Task.CompletedTask;
    }
}

Métodos de extensión

Método Uso
HabilitarContabilidad(nombreCola) Conveniencia para el único servicio del subdominio que publica y escucha (el backend persistente). Equivale a PublicarHaciaContabilidad() + EscucharRespuestasContabilidad(nombreCola).
PublicarHaciaContabilidad() Solo publica hechos económicos. Úsalo en los servicios de borde (MCP, gRPC, etc.) que no deben reaccionar a los resultados. Es seguro invocarlo en varios servicios a la vez (varios productores hacia una misma cola).
EscucharRespuestasContabilidad(nombreCola) Solo escucha los resultados (HechoEconomicoContabilizado/HechoEconomicoRechazado). Debe invocarlo un solo servicio del subdominio: con la misma cola, varios servicios compiten por cada mensaje; con colas distintas, lo duplican (el exchange es fanout).

Dependencias

Paquete Propósito
Cosmos.Contabilidad.Contratos Contratos del sub-dominio de Contabilidad.
WolverineFx.RabbitMQ Transporte RabbitMQ para Wolverine.

Licencia

Software propietario © 2026 Sincosoft. Todos los derechos reservados.

Product Compatible and additional computed target framework versions.
.NET net10.0 is compatible.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
0.0.3 138 6/22/2026
0.0.3-beta.2 107 6/4/2026
0.0.3-beta.1 69 6/2/2026
0.0.2 96 6/2/2026
0.0.1 226 4/24/2026