FIBOS入坑指南——本地开发环境搭建

FIBOS是什么?

FIBOS 是一个结合 FIBJS 以及 EOS 的 JavaScript 的运行平台,它使得 EOS 提供可编程性,并容许使用 JavaScript 编写智能合约。FIBOS 平台的出现让第三代 EOS 智能合约编程变得简单、快捷!其项目官网为 https://fibos.io/html

简单地说,你能够在 FIBOS 这个平台上,使用 JS 语言来发行Token、控制区块节点运行、以及编写、部署、调用智能合约等操做,相比 EOS 使用 C/C++ 开发部署智能合约,具备更低的开发门槛。node

FIBOS 能够运行在 Mac OS X,Linux 和 FreeBSD 系统中,因此要基于 FIBOS 平台开发区块链应用,首先得确保你的操做系统是这三种之一,而且已经安装好 node.js 和 npm ,相关的安装教程自行网上寻找便可。git

一、快速安装稳定版的FIBOS

在终端中执行如下命令便可,版本更新也是使用这条命令。github

curl -s https://fibos.io/download/installer.sh | sh

若是安装成功,在终端输入 fibos 将出现以下图。
FIBOS 安装成功npm

二、一键安装开发环境

因为区块链的复杂性,不论是 EOS 仍是 FIBOS 搭建开发环境都比较繁琐,不过 FIBOS 官方已经提供了一个一键搭建本地开发环境的工具,咱们执行如下命令将其从 GitHub 下载下来。编程

git clone https://github.com/FIBOSIO/fib-testnet.git

接着进入 fib-testnet 文件夹,执行安装相关的包依赖便可,依次执行如下两条命令,以下图。json

cd fib-testnet
npm install

安装相关依赖包

能够先尝试启动一下,在 fib-testnet 目录执行如下命令,若是成功,将会开始出块,以下图。浏览器

fibos index.js dev

图片描述

大概在40秒后,BP同步节点开始运行,此时执行如下命令,或在浏览器输入 http://127.0.0.1:8801/v1/chain/get_info 得到当前区块的信息。在本出块终端按 Ctrl+C 或新开一个终端中执行 killall fibos 便可关闭 FIBOS 节点运行,固然,咱们目前先不关闭着,下面还要用。dom

curl http://127.0.0.1:8801/v1/chain/get_info

查看出块信息

三、建立一些密钥

在 FIBOS 或 EOS 中,一个有效的帐户,须要绑定至少一个公钥,所以,咱们在建立开发帐户以前,须要先建立一些密钥对。在 fib-testnet 文件夹中,新建一个 init 文件夹,而后再新建一个 generate.js 文件,输入如下JS代码。curl

var FIBOS = require('fibos.js');

var priKey, pubKey;

for (var i=0; i<3; i++) {
    priKey = FIBOS.modules.ecc.randomKeySync();
    pubKey = FIBOS.modules.ecc.privateToPublic(priKey);
    console.notice('\n私钥: '+priKey);
    console.notice('公钥: '+pubKey+'\n');
}

而后打开一个新的终端,进入 fib-testnet/init/ 文件夹中,执行 fibos generate.js ,便可以下图得到随机生成的3组密钥对。

生成3组密钥对

四、建立一些帐号,并转入一些 FO Token

有效的 FIBOS 帐户名和 EOS 相似,都必须是由 12345.abcdefghijklmnopqrstuvwxyz 组成,且长度小于等于12个字符串。其中小于12个字符串的帐户名由系统的智能合约控制,须要竞价得到。为了方便,咱们这里使用12个字符串长度做为帐户名,分别是 computer11十一、computer11十二、computer1113,同时分别对应以上三组密钥对。

进入 fib-testnet/init/ 文件夹中,新建一个 init.js 文件,输入如下 JS 代码,用于建立3个帐户,密钥对最好自行修改一下。

var config_dev = require('../common/config_dev.json');
var fibossystems = require('../common/fibossystems');
var systems = require('../common/systems');
var config = require('../config.json');
var FIBOS = require('fibos.js');

// 你能够在如下 accounts 这个对象里,增长或修改本身喜欢的FIBOS帐户,密钥对最好自行修改一下
var accounts = {
    "computer1111": {
        "priKey": "5K3HGUKEwapH1GFrHjhtgr5sbqkLnFHrZL3ddR6v7FgrYetnQ2a",
        "pubKey": "FO5Xx9fdHUgCEe5huzedVGE2PTewhVsdNCcTg3cNeWN6KPVRF738"
    },
    "computer1112": {
        "priKey": "5JiU8Tzgv87Wx79mrmdkGjbaom1eAqxTQeGSoC63sziQ8eexRA8",
        "pubKey": "FO5Au67waA8UN9xfieK3KPGSX2jRzRRvFNvPhsBvtejGcXbA8UwG"
    },
    "computer1113": {
        "priKey": "5J5i5mtXep7fdHNYWjP9XpoZ2srFgE24r1GTHvTt9sU1BMPqby3",
        "pubKey": "FO6UYUU63Q4rFsbFV8KQLQivYyyUmU45fiCdv1D8nouXicooSsqr"
    }
};

function initClient(_keyProvider, _httpEndpoint, _chainId) {
    return FIBOS({
        chainId: config.chainId,
        keyProvider: _keyProvider || null,
        httpEndpoint: _httpEndpoint || config_dev.httpEndpoint,
        logger: {
            log: null,
            error: null
        }
    });
}

var client, res, ctx;

client = initClient(systems.concat(fibossystems).map(function(d) {
    return d.private_key;
}));

// 建立帐户
client.transactionSync(tr => {
    for (account in accounts) {
        // 建立帐户
        tr.newaccount({
            creator: 'fibos',
            name: account,
            owner: accounts[account].pubKey,
            active: accounts[account].pubKey
        }, {
            authorization: 'fibos'
        });

        // 购买内存
        tr.buyrambytes({
            payer: 'fibos',
            receiver: account,
            bytes: 1024 * 1024 * 2
        }, {
            authorization: 'fibos'
        });

        // 抵押 FO 得到 NET、CPU 资源
        tr.delegatebw({
            from: 'fibos',
            receiver: account,
            stake_net_quantity: '100.0000 FO',
            stake_cpu_quantity: '100.0000 FO',
            transfer: 1
        }, {
            authorization: 'fibos'
        });

        console.notice('created '+account);      
    }

},{
    authorization: 'fibos'
});

console.notice('');

// 转 10000.0000 FO 到一些帐户中
ctx = client.contractSync('eosio.token');

for (account in accounts) {
    ctx.extransferSync('fibos', account, '10000.0000 FO@eosio', 'FO to '+account, {
        authorization: 'fibos'
    });   

    console.notice('extransfer 10000.0000 FO@eosio to '+account);
}

console.notice('');

进入 fib-testnet/init/ 文件夹中,执行 fibos init.js ,以下图,即完成 computer11十一、computer11十二、computer1113 帐户的建立,同时每一个帐户拥有 10000 FO 余额了,能够用来作各种转帐、兑换测试。若是出错,须要查看一下本地 fibos 节点是否正在运行,在浏览器输入 http://127.0.0.1:8801/v1/chain/get_info

建立3个帐户

五、后记(完)

至此,本地的 FIBOS 开发环境基本搭建完成,若是你想试试在本地环境编写、部署、调用智能合约,能够参考 FIBOS 官方开发文档,固然,后续有时间,我也会把在 FIBOS 智能合约开发过程当中踩到的坑写写。若是想了解 FIBOS 主网是如何启动的,启动顺序是怎样一个过程,节点编程时遇到的问题,那么这个 fib-testnet/lib 文件夹下的内容很值得你去研究。

相关文章
相关标签/搜索