rksync

package module
v1.0.1-rc1 Latest Latest
Warning

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

Go to latest
Published: Apr 28, 2019 License: Apache-2.0 Imports: 22 Imported by: 0

README

CloudChain RKSync

Build Status codecov Go Report Card

CloucChain rksync is a distributed file synchronization protocol. It securely synchronizes files between specified network members. Each of these network members has a digital identity encapsulated in an X.509 digital certificate. All network members constitute a private "subnet" called channel. Channel specifies all authorized network members and the files that need to be synchronized. Files can only be synchronized between network members joining the same channel.

A channel is created by a network member, the creator is called leader. Only leader can add other network members to the channel, or specify files that need to be synchronized. The channel information is synchronized between all network members through the gossip protocol.

Any non-leader node will randomly selects a neighboring node for file data synchronization. The node periodically ask the neighbor node for file updates. and receives updated data for the file from the node if the file has been updated.

Goals

Rksync is inspired by Hyperledger fabric block data synchronization algorithm. Here are the goals:

  1. Security

    First of all, protecting the user's data is paramount. Regardless of our other goals we must never allow the user's data to be susceptible to eavesdropping or modification by unauthorized parties.

  2. Easy

    A high-level interface designed to reduce the work of implementing file transfer in your application.

  3. High availability

    Component failures are the norm rather than the exception, therefor, fault tolerance and automatic recovery must be integral to the system.

  4. Automatic

    User interaction should be required only when absolutely necessary.

Install

go get -u github.com/rkcloudchain/rksync

Example

First, you need to start the rksync service:

package main

import (
    "net"

    "github.com/rkcloudchain/rksync"
    "github.com/rkcloudchain/rksync/config"
)

func main() {
    cfg := &config.Config{
        HomeDir: "/pth/to/home/directory",
        Gossip: &config.GossipConfig{
            FileSystem:     &MyFileSystem{},
            BootstrapPeers: []string{"localhost:8053"},
            Endpoint:       "localhost:9053",
        },
        Identity: &config.IdentityConfig{
            ID: "nodeID",
        },
    }

    lis, err := net.Listen("tcp", "0.0.0.0:9053")
    if err != nil {
        panic(err)
    }

    srv, err := rksync.Serve(lis, cfg)
    if err != nil {
        panic(err)
    }
    defer srv.Stop()
}
Note
  1. You need to implement the FileSystem interface yourself

    // FileSystem enables the rksync to communicate with file system.
    type FileSystem interface {
        // Create creates the named file
        Create(chainID, filename string, metadata []byte, leader bool) (File, error)
    
        // OpenFile opens a file using the given flags and the given mode.
        OpenFile(chainID, filename string, metadata []byte, flag int, perm os.FileMode, leader bool) (File, error)
    
        // Stat returns a FileInfo describing the named file.
        Stat(chainID, filename string, metadata []byte, leader bool) (os.FileInfo, error)
    }
    
    // File represents a file in the filesystem
    type File interface {
        io.Closer
        io.ReaderAt
        io.Writer
    }
    
  2. The x.509 certificate file representing the digital identity should be placed in the HomeDir directory.

    The directory structure is:

    /HomeDir
      /csp
        /signcerts // Store public key certificate
        /keystore  // Store private key
        /cacerts   // Store trusted CA certificates
    
  3. BootstrapPeers

    The seed node list needs to be added to the BootstrapPeers configuration item. This configuration of all nodes should be consistent.

Once the service is started, you can do the corresponding operation:

  • CreateChannel

    err = srv.CreateChannel("testchannel", []common.FileSyncInfo{
        common.FileSyncInfo{Path: "file1.txt", Mode: "Append", Metadata: []byte{...}},
        common.FileSyncInfo{Path: "file2.txt", Mode: "Append", Metadata: []byte{...}},
    })
    
  • AddMemberToChan

    err = srv.AddMemberToChan("testchannel", "node2ID", node2Cert)
    
  • AddFileToChan

    err = srv.AddFileToChan("testchannel", "file3.txt", "Append", []byte{...})
    

Current State

RKSync is still in development and the API may be changed. Therefore, we do not guarantee the backward compatibility of the library for the time being.

License

RKSync is under the Apache 2.0 license. See the LICENSE file for details.

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Server

type Server struct {
	// contains filtered or unexported fields
}

Server encapsulates rksync component

func Serve

func Serve(l net.Listener, cfg *config.Config) (*Server, error)

Serve creates a rksync service instance

func (*Server) AddFileToChan

func (srv *Server) AddFileToChan(chainID string, files []*common.FileSyncInfo) error

AddFileToChan adds a file to the channel

func (*Server) AddMemberToChan

func (srv *Server) AddMemberToChan(chainID string, nodeID string, cert *x509.Certificate) error

AddMemberToChan adds a member to the channel

func (*Server) CloseChannel

func (srv *Server) CloseChannel(chainID string) error

CloseChannel closes an channel

func (*Server) CreateChannel

func (srv *Server) CreateChannel(chainID string, files []*common.FileSyncInfo) error

CreateChannel creates a channel

func (*Server) RemoveFileWithChan

func (srv *Server) RemoveFileWithChan(chainID string, filenames []string) error

RemoveFileWithChan removes file contained in the channel

func (*Server) RemoveMemberWithChan

func (srv *Server) RemoveMemberWithChan(chainID string, nodeID string, cert *x509.Certificate) error

RemoveMemberWithChan removes member contained in the channel

func (*Server) Stop

func (srv *Server) Stop()

Stop the rksync service

Directories

Path Synopsis
tests

Jump to

Keyboard shortcuts

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