https://github.com/valueof/bland
Self-hosted bookmarks
https://github.com/valueof/bland
Last synced: 9 months ago
JSON representation
Self-hosted bookmarks
- Host: GitHub
- URL: https://github.com/valueof/bland
- Owner: valueof
- Created: 2022-09-04T04:41:53.000Z (almost 4 years ago)
- Default Branch: main
- Last Pushed: 2022-10-23T01:23:16.000Z (over 3 years ago)
- Last Synced: 2025-03-01T14:43:16.627Z (over 1 year ago)
- Language: Go
- Size: 1.63 MB
- Stars: 3
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Bland
It's like del.icio.us of the past but you can host it yourself!

## Quick Start
Create a new build:
```sh
make
```
Switch to the new directory and setup the database. This will create a new SQLite database file (bland.db) including all the necessary tables:
```sh
cd ./build
./bland -db ~/db/bland.db -setup
```
Now you can run the server:
```sh
./bland -db ~/db/bland.db -addr localhost:9999
```
Note that the database file is _outside_ the build directory. This is because `make` removes everything in the build directory on each run so keeping your database file in there is just asking for trouble.
## Development
To start a development server run this:
```sh
go run . -dev -db bland.db -addr localhost:9999
```
If you have [nodemon](https://nodemon.io/) installed you can watch for changes and reload the server automatically:
```sh
nodemon --exec go run . -dev -db bland.db -addr localhost:9999 --signal SIGTERM --ext html,go
```
## Optional
### Import from Pinboard
If you, like me, have a JSON file with data from Pinboard you can import it into your database while setting it up:
```sh
./bland -db bland.db -setup -seed /path/to/pinboard_export.json
```
### Run Bland in the background
For longer running instances I highly recommend running Bland as a background service and putting it behind a reverse proxy server such as [Nginx](https://www.nginx.com/) or [Caddy](https://caddyserver.com).
#### On Ubuntu Linux
First, create a new file in the `/lib/systemd/system` directory named `bland.service` and make it something like this (this assumes your `build` directory is in `/home/anton/srv/bland` and your database file is `/home/anton/db/bland.db`):
```
[Unit]
Description=bland
[Service]
Type=simple
Restart=always
RestartSec=5s
WorkingDirectory=/home/anton/srv/bland
ExecStart=/home/anton/srv/bland/bland -addr localhost:9999 -db /home/anton/db/bland.db
StandardOutput=journal
StandardError=journal
[Install]
WantedBy=multi-user.target
```
Save this file. You can now start Bland in the background by running:
```sh
sudo service bland start
```
You can now put Bland behind a reverse proxy server. If you have [Caddy installed](https://caddyserver.com/docs/getting-started) it's as simple as adding this to your Caddyfile:
```
myblanddomain.ts.net {
reverse_proxy localhost:9999
}
```
If you want to use Nginx, check out this excellent guide from DigitalOcean: [How To Deploy a Go Web Application Using Nginx on Ubuntu](https://www.digitalocean.com/community/tutorials/how-to-deploy-a-go-web-application-using-nginx-on-ubuntu-18-04).
Enjoy!