Skip to content

Commit 8c79bb3

Browse files
Da YuDa Yu
Da Yu
authored and
Da Yu
committed
v2.0
1 parent 7343ea2 commit 8c79bb3

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

72 files changed

+5345
-2886
lines changed

.DS_Store

0 Bytes
Binary file not shown.

README.md

+30-199
Original file line numberDiff line numberDiff line change
@@ -1,221 +1,52 @@
1-
# Overview
21

3-
Filscan is a blockchain browser for Filecoin, which can be used to view Filecoin blockchain data, including querying addresses, messages information, block heights, miner information, token information, etc.
2+
# Filscan_Lotus - LotusExplorer
43

5-
# Table of Contents
6-
- [Overview](#overview)
7-
- [Table of Contents](#table-of-contents)
8-
- [Front-End](#front-end)
9-
- [Recommended Browser](#recommended-browser)
10-
- [User Guide](#user-guide)
11-
- [Comments](#comments)
12-
- [Site Map](#site-map)
13-
- [Home Page](#home-page)
14-
- [Tipset Page](#tipset-page)
15-
- [Mining Page](#mining-page)
16-
- [Token Metrics](#token-metrics)
17-
- [Peer Map](#peer-map)
18-
- [Install](#install)
19-
- [Environmental requirements](#environmental-requirements)
20-
- [Install Dependencies](#install-dependencies)
21-
- [Compiles and hot-reloads for development](#compiles-and-hot-reloads-for-development)
22-
- [API Environment Configuration](#api-environment-configuration)
23-
- [Build](#build)
24-
- [Lints and fixes files](#lints-and-fixes-files)
25-
- [Customize configuration](#customize-configuration)
26-
- [Back-End](#back-end)
27-
- [Build and Install](#build-and-install)
28-
- [Environment](#environment)
29-
- [System Require](#system-require)
30-
- [Build](#build-1)
31-
- [Configuration](#configuration)
32-
- [Run](#run)
33-
- [API Document](#api-document)
4+
## 运行
5+
#### 环境:
6+
golang >= v1.13
347

35-
# Front-End
8+
mongo >= v4.2
369

37-
## Recommended Browser
10+
系统环境 linux 或 mac 暂不支持windows
3811

39-
For the best experience with the Filscan, we recommend that use the latest version of a browser from this list:
12+
一个运行完备的lotus节点
4013

41-
•       Microsoft Edge
14+
以及编译lotus需要的其他依赖
4215

43-
•       Mozilla Firefox
44-
45-
•       Google Chrome/Chromium
46-
47-
•       Apple Safari
48-
49-
## User Guide
50-
51-
### Comments
52-
53-
**Active Miner:** the active miner is the miner that has made sector in the last 24 hours.
54-
55-
**Active Peer:** the active peer is the node that has sent messages in the last 24 hours.
56-
57-
### Site Map
58-
59-
<p align="center">
60-
<img width="100%" style="max-width:1200px" hspace="10" border="2" src="img/site-map.png">
61-
</p>
62-
63-
### Home Page
64-
65-
<p align="center">
66-
<img width="100%" style="max-width:1200px" hspace="10" border="2" src="img/home-page.png">
67-
</p>
68-
69-
You will get the latest chain status of Filecoin Blockchain, include the latest block&message table, the Tipset chain chart.
70-
71-
**Search Bar:**
72-
73-
It is convenient for users to query the blockchain data. User can query detail information about Address, Tipset Height, Block Hash, Message ID, Peer Id by search bar.
74-
75-
**Navigation Bar:**
76-
77-
It is an easy way to access the page you are interested in.
78-
79-
**Chain status:**
80-
81-
Shows the latest chain status.
82-
83-
**The latest Blocks & Messages:**
84-
85-
Shows the latest Blocks info & messages on chain.
86-
87-
**BlockChain structure chart:**
88-
89-
Shows the chain structure of the Filecoin.
90-
91-
### Tipset Page
92-
93-
<p align="center">
94-
<img width="100%" style="max-width:1200px" hspace="10" border="2" src="img/tipset-page.png">
95-
</p>
96-
97-
In this page user will see the chain struct and if click the block in the tipset, the block detail info will appear.
98-
99-
### Mining Page
100-
101-
**Active Storage Miners:**
102-
103-
The chart shows the count of active miners in different periods.
104-
105-
**Evolution of Top Miners for Miners For Proven Power:**
106-
107-
<p align="center">
108-
<img width="100%" style="max-width:1200px" hspace="10" border="2" src="img/mining-page.png">
109-
</p>
110-
111-
The chart shows the Proven power of the top miners in different time periods.
112-
113-
**Miner List**
114-
115-
<p align="center">
116-
<img width="100%" style="max-width:1200px" hspace="10" border="2" src="img/miner-list.png">
117-
</p>
118-
119-
the table shows some miner key info, some of columns can be sorted. User can choose periods to show different data.
120-
121-
### Token Metrics
122-
123-
<p align="center">
124-
<img width="100%" style="max-width:1200px" hspace="10" border="2" src="img/token-metrics.png">
125-
</p>
126-
127-
The page displays the block reward and pledged amount of FIL tokens.
128-
129-
### Peer Map
130-
131-
<p align="center">
132-
<img width="100%" style="max-width:1200px" hspace="10" border="2" src="img/peer-map.png">
133-
</p>
134-
135-
This page shows the peer’s location on the map.
136-
137-
## Install
138-
139-
### Environmental requirements
140-
141-
- required: Node.js(https://nodejs.org/en/)
142-
143-
- optional : Yarn (https://yarnpkg.com/)
144-
145-
### Install Dependencies
146-
```
147-
yarn install or npm install 
148-
```
149-
### Compiles and hot-reloads for development
150-
```
151-
yarn serve or npm run serve
152-
```
153-
### API Environment Configuration
154-
155-
By default, the profiles are in the root directory of the project. You can modify the value of **VUE_APP_BASE_URL** to change the server address.
156-
157-
**Example:**
158-
159-
If you want to change the server address, you can open the file .env.development. Then you will see the default value of **VUE_APP_BASE_URL** is "http://192.168.1.2:8700/v0/filscan", modify it according to your actual server address. Please notice that you should run "yarn serve" or "npm run serve" to apply this change.
160-
161-
### Build
162-
```
163-
yarn build:pro or npm run build:pro
164-
```
165-
### Lints and fixes files
166-
```
167-
yarn lint or npm run lint
168-
```
169-
### Customize configuration
170-
171-
See Configuration Reference(https://cli.vuejs.org/config/).
172-
173-
# Back-End
174-
175-
## Build and Install
176-
177-
### Environment
178-
179-
- golang >= v1.13
180-
- mongo >= v4.2
181-
- lotus >= v0.2.7
182-
183-
### System Require
184-
185-
- Linux or Mac OS
186-
187-
### Build
188-
```
16+
```cassandraql
18917
git clone (githuburl)
190-
19118
cd Backend
192-
19319
make build-lotus
194-
195-
go build
20+
go build
19621
```
197-
### Configuration
22+
此时应生成 filscan_lotus 可执行文件
19823

199-
Edit app.conf in path /conf and set the correct parameter
200-
```
201-
mongoHost = "127.0.0.1:27017"
24+
#### 配置
20225

26+
打开 conf下app.conf文件
27+
```cassandraql
28+
mongoHost = "127.0.0.1:27017"
20329
mongoUser = "root"
204-
20530
mongoPass = "admin"
31+
mongoDB = "filscan"
32+
lotusGetWay="192.168.1.111:1234"
33+
```
34+
配置mongo服务,以及lotus节点IP(注意:lotus节点1234端口默认不对外开放需自行配置)
20635

207-
mongoDB   = "filscan"
36+
#### 运行
20837

209-
lotusGetWay="192.168.1.1:1234"
210-
```
211-
### Run
38+
运行目录结构
39+
```cassandraql
40+
|-- conf
41+
|-- app.conf
42+
|-- filscan_lotus
21243
213-
Make sure mongo and lotus is active, and run the filscan_lotus
21444
```
45+
运行指令
46+
```cassandraql
21547
./filscan_lotus
216-
```
217-
The application will check lotus and mongo’s status. The application will stop if got any error from them. If application start success, it will work until sync all data down from lotus. 
48+
```
21849

219-
## API Document
50+
运行启动将会检查mondo以及lotus连通性。连接失败系统将终止启动。
22051

221-
Check document [here](Filscan_Interface_v1.0.md)
52+
若检测成功系统将正常启动,第一启动需要同步链上数据,请耐心等待。

conf/app.conf

+2-1
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
appname = filscan_lotus
2-
httpport = 8701
2+
httpport = 8700
33

44
listenAdd = "0.0.0.0"
55

@@ -14,6 +14,7 @@ syncChain= 10
1414

1515
# tipset 队列cash大小
1616
tipsetQueueSize = 50
17+
tipset_cache_size = 10
1718

1819
# LotusBaseInformation 缓存时间 s
1920
lotusBaseInformationCash = 5

controllers/define.go

+25-38
Original file line numberDiff line numberDiff line change
@@ -3,7 +3,7 @@ package controllers
33
import (
44
"context"
55
"crypto/md5"
6-
"filscan_lotus/controllers/filscaner"
6+
"filscan_lotus/filscaner"
77
"filscan_lotus/filscanproto"
88
"filscan_lotus/models"
99
"fmt"
@@ -25,8 +25,8 @@ var UserTokenMap map[string]*vcode_t
2525
var ps = fmt.Sprintf
2626
var RedisClient *redis.Client
2727
var SidLife int64
28-
var TipsetQueue *SliceEntry
29-
var filscanerInst *filscaner.Filscaner
28+
var TipsetQueue0 *SliceEntry
29+
var flscaner *filscaner.Filscaner
3030

3131
var conf = beego.AppConfig.String
3232
var Logger *zap.SugaredLogger
@@ -36,6 +36,7 @@ var lotusBaseInformation *LotusBaseInformation
3636
var peerPointCash *PeerPointCash
3737
var avgBlockTimeCash *AvgBlockTimeCash
3838
var avgBlockSizeCash *AvgBlockSizeCash
39+
var totalPowerCash *TotalPowerCash
3940

4041
type LotusBaseInformation struct {
4142
TipsetHeight uint64
@@ -48,6 +49,13 @@ type LotusBaseInformation struct {
4849
CashTime int64
4950
}
5051

52+
type TotalPowerCash struct {
53+
StorageCapacity float64
54+
Data []*filscanproto.TotalPowerGraphical
55+
Time int64
56+
CashTime int64
57+
}
58+
5159
type PeerPointCash struct {
5260
PeerPoint []*filscanproto.PeerPoint
5361
Time int64
@@ -73,16 +81,12 @@ type AvgBlockSizeCash struct {
7381
CashTime int64
7482
}
7583

76-
type TotalPowerCash struct {
77-
//BlockTime []*filscanproto.Blocktime
78-
Time int64
79-
}
80-
8184
type Recv struct {
8285
Code int
8386
Msg string
8487
Data interface{}
8588
}
89+
8690
type vcode_t struct {
8791
code string
8892
lasttime int64
@@ -93,16 +97,20 @@ func Firstinit() {
9397
//OriginInit()
9498
BeegoInit()
9599
LotusInit()
96-
MongoDBInit()
100+
models.Db_init(beego.AppConfig)
97101
models.TimenowInit()
98102
LoggerInit()
99-
//MysqlInit()
103+
// MysqlInit()
100104
ArgInit()
101105
UpdatePeers()
102106
UpdateAllAccount()
103107
return
104108
}
105109

110+
func SetFilscaner(filscaner *filscaner.Filscaner) {
111+
flscaner = filscaner
112+
}
113+
106114
func Run() {
107115
go FirstSynLotus()
108116
}
@@ -160,36 +168,15 @@ func ArgInit() {
160168
HomeCashTime, _ := strconv.ParseInt(homeGraphicalCash, 10, 64)
161169
avgBlockTimeCash = &AvgBlockTimeCash{CashTime: HomeCashTime}
162170
avgBlockSizeCash = &AvgBlockSizeCash{CashTime: HomeCashTime}
171+
totalPowerCash = &TotalPowerCash{CashTime: HomeCashTime}
163172

164-
err, inst := filscaner.NewInstance(context.TODO(), LotusApi)
165-
if err != nil {
166-
panic(ps("filscaner.NewInstance fail:%v", err.Error()))
167-
}
168-
filscanerInst = inst
169-
}
170-
171-
func MongoDBInit() {
172-
host := conf("mongoHost")
173-
user := conf("mongoUser")
174-
pass := conf("mongoPass")
175-
mongoDB := conf("mongoDB")
176-
mgosession := models.GetGlobalSession(host, user, pass, mongoDB)
177-
_, err := mgosession.DatabaseNames()
178-
if err != nil {
179-
panic(ps("mongoInit fail:%v", err))
173+
if false {
174+
inst, err := filscaner.NewInstance(context.TODO(), "./conf/app.conf", LotusApi)
175+
if err != nil {
176+
panic(ps("filscaner.NewInstance fail:%v", err.Error()))
177+
}
178+
flscaner = inst
180179
}
181-
models.DB = mongoDB
182-
log("mongoInit success dbName=%v", models.DB)
183-
184-
models.Create_block_index()
185-
models.Create_block_reward_index()
186-
187-
models.Create_tipset_index()
188-
models.Create_peer_index()
189-
models.Create_msg_index()
190-
models.Create_block_index()
191-
models.Create_account_index()
192-
models.Create_Tipset_Rewards_Index()
193180
}
194181

195182
func LotusInit() {

0 commit comments

Comments
 (0)