channel-transfer

command module
v0.0.5 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 12, 2024 License: MIT Imports: 30 Imported by: 0

README

Channel-transfer

Go Report Card Go Reference GitHub License

Go Verify Build Security vulnerability scan GitHub go.mod Go version (branch) GitHub Tag

TOC

Description

Channel transfer service #channel#hlf#offchain#go#golang#transfer#asset#application#off#swap#

Architecture

State transitions graph

flowchart TD
    A[Create TransferFrom - Transfer From] --> B{TimeOut?}
    A --> I[Creation error, insufficient funds]
    I --> K[/ERROR/]
    B -->|Yes| E[Cancel TransferFrom]
    E --> M[/CANCEL/]
    B -->|No| D[Create TransferTo - Transfer To - Commit TransferTo]
    D --> L[/SUCCESS/]
    D --> J[Commit TransferFrom]
    J --> F[Delete TransferTo]
    F --> C[Delete TransferFrom]

Create TransferFrom - Transfer record creating in HLF state, tokens are holding. This record will be deleted. If transfer record is missing, then either it was never created, or the transfer was successfully completed or cancelled - details should be available th the Fabric ledger.

TransferTo - must be different from TransferFrom to avoid confusion.

"Transfer" is performed sequentially. Tokens are already held on channel FROM, which means now it's necessary to make a transfer in channel TO. When "Transfer" operation is completed, the records of TransferFrom and TransferTo will be marked accordingly. After TransferTo is completed, the result may be returned to client. Now the records should be deleted: first TransferTo, and only after that TransferFrom.

Open API

Service provides OpenAPI(Swagger) functionality. Methods and request formats is available here

Scaling

Scaling not developed yet.

Dependencies

  • HLF
  • Redis
  • Vault (optional)

Build

Go
go build -ldflags="-X 'main.AppInfoVer={Version}'"
Docker

Connection profile

It is important to set reasonable timeouts in a connection profile

connection.yaml:

name: basic-network
version: 1.0.0
client:
  organization: anoideapen

  logging:
    level: info

  connection:
    timeout:
      peer:
        endorser: '300'
      orderer: '300'

  peer:
    timeout:
      response: 5s
      connection: 3s
      discovery:
        # Expiry period for discovery service greylist filter
        # The channel client will greylist peers that are found to be offline
        # to prevent re-selecting them in subsequent retries.
        # This interval will define how long a peer is greylisted
        greylistExpiry: 1s
      registrationResponse: 10s
    orderer:
      timeout:
        connection: 3s
        response: 5s
    global:
      timeout:
        query: 5s
        execute: 5s
        resmgmt: 5s
      cache:
        connectionIdle: 30s
        eventServiceIdle: 2m
        channelConfig: 60s
        channelMembership: 10s
        
  credentialStore:
    #...
  tlsCerts:
    #...

channels:
  #...
organizations:
  #...
orderers:
  #...
peers:
  #...

Run

./channel-transfer -c=config.yaml

or

export CHANNEL_TRANSFER_CONFIG="config.yaml" && ./channel-transfer

or create file config.yaml next to the channel-transfer executable
or create file /etc/config.yaml

Also, it is possible to override values from config by env variables with CHANNEL_TRANSFER_ prefix

export CHANNEL_TRANSFER_REDISSTOR_PASSWORD=123456 &&
export CHANNEL_TRANSFER_VAULTCRYPTOSETTINGS_VAULTAUTHPATH="v1/auth/kubernetes/login" &&
./channel-transfer -c=config.yaml

Development

Utils
protodep up
Protobuf
buf generate proto -o proto 
Code generation
swagger generate client -f proto/service.swagger.json -t test/integration

Tests

Unit tests
# Run unit tests
go test -count 1 -race ./...
Integration tests

No

License

Apache-2.0

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
pkg
data
Package data contains primitives for working with an object that stores data used in other parts of the library.
Package data contains primitives for working with an object that stores data used in other parts of the library.
hlf
transfer/mock
Package mock is a generated GoMock package.
Package mock is a generated GoMock package.
Package proto is a reverse proxy.
Package proto is a reverse proxy.
test
integration Module

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL