297 lines
9.9 KiB
Markdown
297 lines
9.9 KiB
Markdown
# Bird-lg-go
|
|
|
|
An alternative implementation for [bird-lg](https://github.com/sileht/bird-lg) written in Go. Both frontend and backend (proxy) are implemented, and can work with either the original Python implementation or the Go implementation.
|
|
|
|
> The code on master branch no longer support BIRDv1. Branch "bird1" is the last version that supports BIRDv1.
|
|
|
|
## Table of Contents
|
|
|
|
* [Bird-lg-go](#bird-lg-go)
|
|
* [Table of Contents](#table-of-contents)
|
|
* [Frontend](#frontend)
|
|
* [Proxy](#proxy)
|
|
* [Advanced Features](#advanced-features)
|
|
* [API](#api)
|
|
* [Request fields](#request-fields)
|
|
* [Response fields (when type is summary)](#response-fields-when-type-is-summary)
|
|
* [Fields for apiSummaryResultPair](#fields-for-apisummaryresultpair)
|
|
* [Fields for SummaryRowData](#fields-for-summaryrowdata)
|
|
* [Example response](#example-response)
|
|
* [Response fields (when type is bird, traceroute or whois)](#response-fields-when-type-is-bird-traceroute-or-whois)
|
|
* [Fields for apiGenericResultPair](#fields-for-apigenericresultpair)
|
|
* [Example response](#example-response-1)
|
|
* [Telegram Bot Webhook](#telegram-bot-webhook)
|
|
* [Example of setting the webhook](#example-of-setting-the-webhook)
|
|
* [Supported commands](#supported-commands)
|
|
* [Credits](#credits)
|
|
* [License](#license)
|
|
|
|
Created by [gh-md-toc](https://github.com/ekalinin/github-markdown-toc)
|
|
|
|
## Frontend
|
|
|
|
The frontend directory contains the code for the web frontend, where users see BGP states, do traceroutes and whois, etc. It's a replacement for "lg.py" in original bird-lg project.
|
|
|
|
Features implemented:
|
|
|
|
- Show peering status (`show protocol` command)
|
|
- Query route (`show route for ...`, `show route where net ~ [ ... ]`)
|
|
- Whois and traceroute
|
|
- Work with both Python proxy (lgproxy.py) and Go proxy (proxy dir of this project)
|
|
- Visualize AS paths as picture (bgpmap feature)
|
|
|
|
Usage: all configuration is done via commandline parameters or environment variables, no config file.
|
|
|
|
| Parameter | Environment Variable | Description |
|
|
| --------- | -------------------- | ----------- |
|
|
| --servers | BIRDLG_SERVERS | server name prefixes, separated by comma |
|
|
| --domain | BIRDLG_DOMAIN | server name domain suffixes |
|
|
| --listen | BIRDLG_LISTEN | address bird-lg is listening on (default ":5000") |
|
|
| --proxy-port | BIRDLG_PROXY_PORT | port bird-lgproxy is running on (default 8000) |
|
|
| --whois | BIRDLG_WHOIS | whois server for queries (default "whois.verisign-grs.com") |
|
|
| --dns-interface | BIRDLG_DNS_INTERFACE | dns zone to query ASN information (default "asn.cymru.com") |
|
|
| --title-brand | BIRDLG_TITLE_BRAND | prefix of page titles in browser tabs (default "Bird-lg Go") |
|
|
| --navbar-brand | BIRDLG_NAVBAR_BRAND | brand to show in the navigation bar (default "Bird-lg Go") |
|
|
|
|
Example: the following command starts the frontend with 2 BIRD nodes, with domain name "gigsgigscloud.dn42.lantian.pub" and "hostdare.dn42.lantian.pub", and proxies are running on port 8000 on both nodes.
|
|
|
|
./frontend --servers=gigsgigscloud,hostdare --domain=dn42.lantian.pub --proxy-port=8000
|
|
|
|
Example: the following docker-compose.yml entry does the same as above, but by starting a Docker container:
|
|
|
|
services:
|
|
bird-lg:
|
|
image: xddxdd/bird-lg-go
|
|
container_name: bird-lg
|
|
restart: always
|
|
environment:
|
|
- BIRDLG_SERVERS=gigsgigscloud,hostdare
|
|
- BIRDLG_DOMAIN=dn42.lantian.pub
|
|
ports:
|
|
- "5000:5000"
|
|
|
|
Demo: https://lg.lantian.pub
|
|
|
|
## Proxy
|
|
|
|
The proxy directory contains the code for the "proxy" for bird commands and traceroutes. It's a replacement for "lgproxy.py" in original bird-lg project.
|
|
|
|
Features implemented:
|
|
|
|
- Sending queries to BIRD
|
|
- Sending "restrict" command to BIRD to prevent unauthorized changes
|
|
- Executing traceroute command on Linux, FreeBSD and OpenBSD
|
|
- Source IP restriction
|
|
|
|
Usage: all configuration is done via commandline parameters or environment variables, no config file.
|
|
|
|
| Parameter | Environment Variable | Description |
|
|
| --------- | -------------------- | ----------- |
|
|
| --allowed | ALLOWED_IPS | IPs allowed to access this proxy, separated by commas. Don't set to allow all IPs. (default "") |
|
|
| --bird | BIRD_SOCKET | socket file for bird, set either in parameter or environment variable BIRD_SOCKET (default "/var/run/bird/bird.ctl") |
|
|
| --listen | BIRDLG_LISTEN | listen address, set either in parameter or environment variable BIRDLG_LISTEN (default ":8000") |
|
|
|
|
Example: start proxy with default configuration, should work "out of the box" on Debian 9 with BIRDv1:
|
|
|
|
./proxy
|
|
|
|
Example: start proxy with custom bird socket location:
|
|
|
|
./proxy --bird /run/bird.ctl
|
|
|
|
Example: the following docker-compose.yml entry does the same as above, but by starting a Docker container:
|
|
|
|
bird-lgproxy:
|
|
image: xddxdd/bird-lgproxy-go
|
|
container_name: bird-lgproxy
|
|
restart: always
|
|
volumes:
|
|
- "/run/bird.ctl:/var/run/bird/bird.ctl"
|
|
ports:
|
|
- "192.168.0.1:8000:8000"
|
|
|
|
You can use source IP restriction to increase security. You should also bind the proxy to a specific interface and use an external firewall/iptables for added security.
|
|
|
|
## Advanced Features
|
|
|
|
### API
|
|
|
|
The frontend provides an API for running BIRD/traceroute/whois queries.
|
|
|
|
API Endpoint: `https://your.frontend.com/api/` (the last slash must not be omitted!)
|
|
|
|
Requests are sent as POSTS with JSON bodies.
|
|
|
|
#### Request fields
|
|
|
|
| Name | Type | Value |
|
|
| ---- | ---- | -------- |
|
|
| `servers` | array of `string` | List of servers to be queried |
|
|
| `type` | `string` | Can be `summary`, `bird`, `traceroute` or `whois` |
|
|
| `args` | `string` | Arguments to be passed, see below |
|
|
|
|
Argument examples for each type:
|
|
|
|
- `summary`: `args` is ignored. Recommended to set to empty string.
|
|
- `bird`: `args` is the command to be passed to bird, e.g. `show route for 8.8.8.8`
|
|
- `traceroute`: `args` is the traceroute target, e.g. `8.8.8.8` or `google.com`
|
|
- `whois`: `args` is the whois target, e.g. `8.8.8.8` or `google.com`
|
|
|
|
Example request:
|
|
|
|
```json
|
|
{
|
|
"servers": [
|
|
"alpha"
|
|
],
|
|
"type": "bird",
|
|
"args": "show route for 8.8.8.8"
|
|
}
|
|
```
|
|
|
|
#### Response fields (when `type` is `summary`)
|
|
|
|
| Name | Type | Value |
|
|
| ---- | ---- | -------- |
|
|
| `error` | `string` | Error message when something is wrong. Empty when everything is good |
|
|
| `result` | array of `apiSummaryResultPair` | See below |
|
|
|
|
##### Fields for `apiSummaryResultPair`
|
|
|
|
| Name | Type | Value |
|
|
| ---- | ---- | -------- |
|
|
| `server` | `string` | Name of the server |
|
|
| `data` | array of `SummaryRowData` | Summaries of the server, see below |
|
|
|
|
##### Fields for `SummaryRowData`
|
|
|
|
All fields below is 1:1 correspondent to the output of `birdc show protocols`.
|
|
|
|
| Name | Type |
|
|
| ---- | ---- |
|
|
| `name` | `string` |
|
|
| `proto` | `string` |
|
|
| `table` | `string` |
|
|
| `state` | `string` |
|
|
| `since` | `string` |
|
|
| `info` | `string` |
|
|
|
|
##### Example response
|
|
|
|
Request:
|
|
```json
|
|
{
|
|
"servers": [
|
|
"alpha"
|
|
],
|
|
"type": "summary",
|
|
"args": ""
|
|
}
|
|
```
|
|
|
|
Response:
|
|
|
|
```json
|
|
{
|
|
"error": "",
|
|
"result": [
|
|
{
|
|
"server": "alpha",
|
|
"data": [
|
|
{
|
|
"name": "bgp1",
|
|
"proto": "BGP",
|
|
"table": "---",
|
|
"state": "start",
|
|
"since": "2021-01-15 22:40:01",
|
|
"info": "Active Socket: Operation timed out"
|
|
},
|
|
{
|
|
"name": "bgp2",
|
|
"proto": "BGP",
|
|
"table": "---",
|
|
"state": "start",
|
|
"since": "2021-01-03 08:15:48",
|
|
"info": "Established"
|
|
}
|
|
]
|
|
}
|
|
]
|
|
}
|
|
```
|
|
|
|
#### Response fields (when `type` is `bird`, `traceroute` or `whois`)
|
|
|
|
| Name | Type | Value |
|
|
| ---- | ---- | -------- |
|
|
| `error` | `string` | Error message, empty when everything is good |
|
|
| `result` | array of `apiGenericResultPair` | See below |
|
|
|
|
##### Fields for `apiGenericResultPair`
|
|
|
|
| Name | Type | Value |
|
|
| ---- | ---- | -------- |
|
|
| `server` | `string` | Name of the server; is empty when type is `whois` |
|
|
| `data` | `string` | Result from the server |
|
|
|
|
##### Example response
|
|
|
|
Request:
|
|
|
|
```json
|
|
{
|
|
"servers": [
|
|
"alpha"
|
|
],
|
|
"type": "bird",
|
|
"args": "show status"
|
|
}
|
|
```
|
|
|
|
Response:
|
|
|
|
```json
|
|
{
|
|
"error": "",
|
|
"result": [
|
|
{
|
|
"server": "alpha",
|
|
"data": "BIRD v2.0.7-137-g61dae32b\nRouter ID is 1.2.3.4\nCurrent server time is 2021-01-17 04:21:14.792\nLast reboot on 2021-01-03 08:15:48.494\nLast reconfiguration on 2021-01-17 00:49:10.573\nDaemon is up and running\n"
|
|
}
|
|
]
|
|
}
|
|
```
|
|
|
|
### Telegram Bot Webhook
|
|
|
|
The frontend can act as a Telegram Bot webhook endpoint, to add BGP route/traceroute/whois lookup functionality to your tech group.
|
|
|
|
There is no configuration necessary on the frontend, just start it up normally.
|
|
|
|
Set your Telegram Bot webhook URL to `https://your.frontend.com/telegram/alpha+beta+gamma`, where `alpha+beta+gamma` is the list of servers to be queried on Telegram commands, separated by `+`.
|
|
|
|
You may omit `alpha+beta+gamma` to use all your servers, but it is not recommended when you have lots of servers, or the message would be too long and hard to read.
|
|
|
|
#### Example of setting the webhook
|
|
|
|
```bash
|
|
curl "https://api.telegram.org/bot${BOT_TOKEN}/setWebhook?url=https://your.frontend.com:5000/telegram/alpha+beta+gamma"
|
|
```
|
|
|
|
#### Supported commands
|
|
|
|
- `path`: Show bird's ASN path to target IP
|
|
- `route`: Show bird's preferred route to target IP
|
|
- `trace`: Traceroute to target IP/domain
|
|
- `whois`: Whois query
|
|
|
|
## Credits
|
|
|
|
- Everyone who contributed to this project (see Contributors section on the right)
|
|
- Mehdi Abaakouk for creating [the original bird-lg project](https://github.com/sileht/bird-lg)
|
|
- [Bootstrap](https://getbootstrap.com/) as web UI framework
|
|
|
|
## License
|
|
|
|
GPL 3.0
|