GitXplorerGitXplorer
l

blockr

public
1 stars
0 forks
11 issues

Commits

List of commits on branch master.
Unverified
aa0fe4f5045b75430cf67e48552060221bdad95e

Dont allow unblock

llavelle committed 5 years ago
Unverified
c9bdec292d9ddf11dca68c722d8800481d6ad381

idea

llavelle committed 5 years ago
Unverified
87675bea55e48b64c64dcb38f134397519e3b7d2

Move types to devdeps

llavelle committed 6 years ago
Unverified
f0ffb9c792586ec43885c37141ebeecbeae2b32a

Fix json parse error and exec path

llavelle committed 6 years ago
Unverified
52afec9c76db66e882e2ebcbed25c6299f1e13f6

Add json5 to readme

llavelle committed 6 years ago
Unverified
c9cb93ee37329cfb5734c67697aab6351bd4a9fa

new idea

llavelle committed 6 years ago

README

The README file for this repository.

Blockr

Block distracting sites from the command line

Features

I built this as a replacement for SelfControl. It has the following features:

  • Cross platform (MacOS and Linux).
  • Configurable with a human-readable and editable JSON file instead of plists.
  • Easily unblock a single site (sometimes a site like Reddit, Twitter or Medium does have a useful article you want to read at work, but you don't want to unblock everything).
  • Command line interface instead of GUI.
  • Runs indefinitely until you turn it off, rather than having to re-run it every 24 hours.
  • Offers an easier way to authenticate as root, which is needed for editing the hosts file.

Install

yarn global add blockr

Usage

Start by creating the file ~/blockr.json. You can use the file in this repo as a starting point. It should contain a single hosts key containing the URLs of sites you would like to block. This file can use JSON5 syntax, including comments and trailing commas.

Activate

Run blockr to block all of the sites in your config file.

Deactivate

Run blockr unblock to remove the block. Run blockr unblock [sitename] to unblock a particular site.

Authenticating

Blockr works by editing the hosts file at /etc/hosts. This requires root access. You can acheive this by running sudo blockr, however this will require you to type your password every time you use it.

You can also provide your sudo password via a flag, like blockr --password hunter2. If you're worried about security, use a command line password manager like 1Password to echo the password. Using a literal is not recommended as your password will then be saved your shell history.

Syncing config file

You can easily sync your config file in two ways: via a symlink, or a flag. First create your blockr.json somewhere else like ~/code/dotfiles/blockr.json. Then you can point to it

Via a symlink: run ln -s $HOME/code/dotfiles/blockr.json $HOME/blockr.json

Via a flag: use blockr --config-file $HOME/code/dotfiles/blockr.json. You could also put this in an alias so you don't have to type it every time.

Planned features

  • Temporarily unblocking a site for 10 minutes or something.
  • Require a one minute delay and a re-confirmation before unblocking.
  • Configure schedules when the block should be applied.
  • Show stats on how many times you've unblocked each site.
  • Run a background process to put back the block if the user tries to delete it by editing /etc/hosts directly, like SelfControl does.
  • Strict mode that prevents you from running blockr unblock for a certain period of time.
  • Groups of sites to block eg "social" or "news"
  • Support multiple URLs for one site, eg. bbc.co.uk and bbc.com

License

MIT