Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/abhinavs/blockr
Command line tool to block websites that distract you and activate focus mode.
https://github.com/abhinavs/blockr
Last synced: about 2 months ago
JSON representation
Command line tool to block websites that distract you and activate focus mode.
- Host: GitHub
- URL: https://github.com/abhinavs/blockr
- Owner: abhinavs
- License: mit
- Created: 2020-07-27T12:41:23.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2022-06-02T04:05:55.000Z (over 2 years ago)
- Last Synced: 2024-05-02T00:17:03.178Z (8 months ago)
- Language: Ruby
- Size: 24.4 KB
- Stars: 7
- Watchers: 3
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE.txt
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# blockr
blockr is a command line tool to help you easily block websites, and unblock them when you need them. It modifies /etc/hosts file and add appropriate configuration.
In today’s world though it is difficult to permanently block websites because they are quite useful too. And hence, blockr lets you activate and deactivate focus mode, so that you are able to access blocked websites when you are relaxing.
## Installation
You can install blockr using following command
```
$ sudo gem install blockr
```## Usage/Commands
### block (shortcut b or -b)
Use this command to block any website you want. It can take one or more websites as input, just separate them by space.
Please take care to add the exact website URL you want to block - a few websites add www as a subdomain and to block them you will have to add that to in the name of the website.**examples**
```
$ # block youtube
$ sudo blockr block www.youtube.com$ # use shortcut -b to block youtube
$ sudo blockr -b www.youtube.com$ # block multiple websites in one shot
$ sudo blockr -b www.facebook.com www.youtube.com$ # take care to provide exact URLs you want to block
$ sudo blockr -b www.facebook.com m.facebook.com
```### unblock (shortcut u or -u)
Use this command to unblock any website you have previously blocked using blockr. It can take one or more space separated websites as input.It is a safe command, and does not return error if website was not blocked.
**examples**
```
$ # unblock youtube
$ sudo blockr unblock www.youtube.com$ # use shortcut -u to unblock youtube
$ sudo blockr -u www.youtube.com$ # unblock multiple websites in one shot
$ sudo blockr -u www.facebook.com www.youtube.com$ # take care to provide exact URLs you want to unblock
$ sudo blockr -u www.facebook.com m.facebook.com
```### activate (shortcut a or -a)
Use this command to activate focus mode. This is a sort of shortcut to block all the websites you have added to blockr and remove all the distracting websites.**examples**
```
$ # activate focus mode
$ sudo blockr -activate$ # use shortcut -a to activate focus mode
$ sudo blockr -a
```### deactivate (shortcut d or -d)
Use this command to deactivate focus mode. This unblocks all the websites you have added to blockr.**examples**
```
$ # deactivate focus mode
$ sudo blockr deactivate$ # use shortcut -d to deactivate focus mode
$ sudo blockr -d
```### help (or -h)
Use this command to know more about blockr commands. You can also use this command with other commands to get command specific help.**examples**
```
$ # see all blockr commands
$ sudo blockr help$ # get help with respect to a particular command
$ sudo blockr activate -h
```**Please Note**
* Given we are modifying /etc/hosts file, you will have to run blockr as an administrator or as a root user.
* blockr also uses special markers to identify changes done by it, so please don’t manually update entries added by blockr, use blockr commands instead.
* blockr at the moment clears DNS cache for Apple's OSX systems. Please see [this link](http://www.abhinav.co/clear-dns-cache.html) to find out command specific to your platform.### TODO
* Write tests
* Persist blocked & unlocked settings with activate & deactivate commands
* Test it on Linux
* Port it on Windows## Development
After checking out the repo, run `bin/setup` to install dependencies. Then, run `rake spec` to run the tests. You can also run `bin/console` for an interactive prompt that will allow you to experiment.
To install this gem onto your local machine, run `bundle exec rake install`. To release a new version, update the version number in `version.rb`, and then run `bundle exec rake release`, which will create a git tag for the version, push git commits and tags, and push the `.gem` file to [rubygems.org](https://rubygems.org).
## Contributing
Bug reports and pull requests are welcome on GitHub at https://github.com/abhinavs/blockr. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the [code of conduct](https://github.com/abhinavs/blockr/blob/master/CODE_OF_CONDUCT.md).
## Code of Conduct
Everyone interacting in the blockr project's codebases, issue trackers, chat rooms and mailing lists is expected to follow the [code of conduct](https://github.com/abhinavs/blockr/blob/master/CODE_OF_CONDUCT.md).
## Copyright
Copyright (c) 2020 Abhinav Saxena. See [MIT License](LICENSE.txt) for further details.