Skip to content

pioz/bulldog

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Bulldog

logo

Bulldog is an amazing hunting dog that checks for you a list of URLs and warns you by email if one of them returns a http code that is not 200.

Installation

Install it yourself

$ go get github.com/pioz/bulldog
$ cd $GOPATH/src/github.com/pioz/bulldog
$ go build
$ ./bulldog -v

or ⬇️ download and install the .deb package with

$ dpkg -i bulldog_0.2.1-1_amd64.deb

Usage

Bulldog loads a list of URLs and for each of them executes a GET http request. If the request fails or returns a different http code than 200, it will send you an email to alert you. When the list is over it starts to sleep for a while and then restarts the controls.

Bulldog uses a configuration file with various options:

[time]
# After checking the entire list of URLs sleep for these seconds.
s=60
# After checking the entire list of URLs and at least a check fail sleep for
# these seconds. Usually this time is greater to not warn you continuously.
se=600
# Http request timeout. If the timeout is reached the check is to be considered
# as failed.
t=10
[logging]
# Log file path. If empty logs on stdout.
logfile=/var/log/bulldog.log
# Disables logs.
quiet=false
[email]
# Gmail account. If this is present send email using the gmail smtp server. Use
# -pass flag to specify the gmail account password. If this flag is empty send
# email using `mail` command line program.
gmail=account@gmail.com
# Gmail account password. Only relevant when using -gmail flag.
pass=pa$$w0rd
# When a check fails send an email on this email address. If is empty the email
# alert is disabled.
to=your@email.com
[urls]
# Comma-separated list of URLs to check.
urls=http://google.com,http://twitter.com/

To unleash Bulldog run the follow command:

$ bulldog -config /path/to/config/file

You can pass also the config file options as command arguments:

$ bulldog -urls http://google.com -to your@email.com -s 10

You can also perform a check on the list only once and then exit (status code 1 if at least one check fails):

$ bulldog -urls http://google.com,http://twitter.com -1

For the complete list of command line arguments:

$ bulldog -h

init.d script

Instruction here.

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/pioz/bulldog.

License

The package is available as open source under the terms of the GPL License.