DownloaderV3.Destination 1.0.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package DownloaderV3.Destination --version 1.0.0                
NuGet\Install-Package DownloaderV3.Destination -Version 1.0.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="DownloaderV3.Destination" Version="1.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DownloaderV3.Destination --version 1.0.0                
#r "nuget: DownloaderV3.Destination, 1.0.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 DownloaderV3.Destination as a Cake Addin
#addin nuget:?package=DownloaderV3.Destination&version=1.0.0

// Install DownloaderV3.Destination as a Cake Tool
#tool nuget:?package=DownloaderV3.Destination&version=1.0.0                

DownloaderV3.Destination

DownloaderV3.Destination is the core module responsible for managing the database context that stores and processes downloaded data within the DownloaderV3 system. This component is built on top of Entity Framework Core and provides a flexible structure for managing blockchain-related data. While the current implementation uses a database context, this may evolve in the future to accommodate other storage mechanisms or contexts.

Features

  • Extensible Database Context: The BaseDestination class acts as the foundation for managing data across different blockchain networks. It can be extended for custom use cases.
  • Entity Management: Includes several key models (Chain, ChainInfo, DownloaderSettings, DownloaderMapping) that structure the blockchain data and downloading settings.
  • EF Core Integration: Fully integrated with Entity Framework Core, allowing for robust database operations.
  • Configurable: Easily configure database entities and extend them as needed for specific data processing requirements.

Getting Started

  • .NET 8.0 or later
  • Entity Framework Core 7.0 or later

Installation

Clone the repository and add it to your solution:

git clone https://github.com/The-Poolz/DownloaderV3.git

Or, if you've packaged it as a NuGet package:

dotnet add package DownloaderV3.Destination

Usage

BaseDestination

BaseDestination is the foundation database context that stores blockchain network data, downloading settings, and event mappings. It is not intended to be used directly but should be extended to introduce custom logic and database configurations that fit specific events or use cases.

You can create your own derived context from BaseDestination and customize it as needed.

Key Entities

Chain: Stores information about different blockchain networks (ChainId, Name, RPC Connection). ChainInfo: Holds specific details about the blockchain (block speed, warning time, etc.). DownloaderSettings: Manages configuration for each download job (e.g., contract address, event hash, starting block, etc.). DownloaderMapping: Defines the mapping of events and how to decode and process them from blockchain logs.

Event Models with [ResponseModel]

When integrating event-specific data, models for these events must be marked with the [ResponseModel] attribute. This allows the system to recognize and process the event data correctly.

using DownloaderV3.Destination.Models;

[ResponseModel]
public class SwapParty : Base
{
    public string TxHash { get; set; } = null!;
    public long BlockHeight { get; set; }
    public string SenderAddress { get; set; } = null!;
    public decimal Amount { get; set; }
}

Adding the Event Model to Your Destination

After creating your event model, you'll need to update your custom destination context to include the new model.

Example: Creating an Event Model To create a model that captures event data (e.g., SwapParty event), you need to define the class with the [ResponseModel] attribute and inherit from the base class Base.

public class CustomDestination : BaseDestination
{
    public CustomDestination(DbContextOptions<CustomDestination> options)
        : base(options) { }

    // Adding the SwapParty event model
    public DbSet<SwapParty> SwapParties { get; set; } = null!;
}

Configuring the Event in the Database

For the event to be captured and processed, it must be added to the DownloaderSettings in the database, specifying details such as the event hash and response model.

Example:

{
  "ChainId": 56,
  "ContractAddress": "0x123...",
  "EventHash": "0xabc...",
  "ResponseType": "SwapParty",
  "StartingBlock": 1000000,
  "EndingBlock": 2000000,
  "Active": true,
  "UrlSet": "https://api.covalenthq.com",
  "MaxBatchSize": 10000,
  "MaxPageNumber": 1000,
  "Key": "1234567890"
}

Example Code

  1. Extending BaseDestination:

To use BaseDestination, you need to create a new context by extending it. Here�s an example of how to do that:

using DownloaderV3.Destination;
using Microsoft.EntityFrameworkCore;

public class CustomDestination : BaseDestination
{
    public CustomDestination(DbContextOptions<CustomDestination> options)
        : base(options) { }

    // You can add more entities or override existing ones here
    public DbSet<CustomEntity> CustomEntities { get; set; } = null!;
}
  1. Configure and Use Your Custom Context:

After extending BaseDestination, you can use the custom context in your application:

Example of Entity Configuration:

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
    base.OnModelCreating(modelBuilder); // Inherits BaseDestination configurations

    modelBuilder.Entity<CustomEntity>(entity =>
    {
        entity.HasKey(e => e.Id);
        entity.Property(e => e.Name).HasMaxLength(100);
        // Add your additional configurations here
    });
}

Contributing

We welcome contributions! Please feel free to submit issues, fork the repository, and send pull requests.

License

This project is licensed under the MIT License. For more information, please check the LICENSE file in the repository.


This version reflects that BaseDestination cannot be used directly and requires extension.

Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (2)

Showing the top 2 NuGet packages that depend on DownloaderV3.Destination:

Package Downloads
DownloaderV3.Source.CovalentDocument

The module for fetching, decoding, and saving blockchain event data using Covalent API in the DownloaderV3 system.

DownloaderV3.DataBase

DownloaderV3 DataBase

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.0.1 125 10/14/2024
1.0.0 264 9/26/2024

Release Notes for DownloaderV3.Destination v1.0.1: