Public | Automated Build

Last pushed: 2 years ago
Short Description
Fork of the project with up-to-date patches.
Full Description

This is a web frontend for a console weather application wego, using it as a backend.
You can check it at


You can access the service from a shell or from a Web browser:

$ curl
Weather for City: Paris, France

     \   /     Clear
      .-.      10 – 11 °C     
   ― (   ) ―   ↑ 11 km/h      
      `-’      10 km          
     /   \     0.0 mm         

You can specify the location, for that you want to get the weather information.
If you omit the location name, you will get the information for your current location,
based on your IP address.

$ curl
$ curl

You can also use IP-addresses (direct) or domain names (prefixed with @)
as a location specificator:

$ curl
$ curl

To get this information online, you can access the :help page:

$ curl


To install the program you need:

  1. Install external dependencies
  2. Install python dependencies used by the service
  3. Get Forecast API Key
  4. Configure wego
  5. Configure
  6. Configure HTTP-frontend service

Install external dependencies

External requirements:

To install wego you must have golang installed. After that:

go get

Install python dependencies

Python requirements:

  • ansi2html
  • Flask
  • geoip2
  • geopy
  • requests
  • gevent

You can install them using pip with this command:

pip install -r requirements.txt`

If virtualenv is used:

virtualenv ve
ve/bin/pip install -r requirements.txt
ve/bin/pip bin/

Also, you need to install the geoip2 database.
You can use a free database GeoLite2, that can be downloaded from

Get Forecast key

To get the Forecast API key, you must register here:

Configure wego

After you have the key, configure wego:

$ cat ~/.wegorc

These are the only configuration values that need to be provided, the rest will be filled out by wego automatically.


Configure the following environment variables specifing the path to the local
installation, to the GeoLite database and to the wego installation. For example:

WTTR_MYDIR = "/home/igor/"
WTTR_GEOLITE = "/home/igor/"
WTTR_WEGO = "/home/igor/go/bin/wego"

Configure HTTP-frontend service

Configure the web server, that will be used
to access the service (if you want to use a web frontend; it's recommended):

server {
    listen [::]:80;
    server_name *;
    access_log  /var/log/nginx/  main;
    error_log  /var/log/nginx/;

    location / {

        proxy_set_header   Host             $host;
        proxy_set_header   X-Real-IP        $remote_addr;
        proxy_set_header   X-Forwarded-For  $remote_addr;

        client_max_body_size       10m;
        client_body_buffer_size    128k;

        proxy_connect_timeout      90;
        proxy_send_timeout         90;
        proxy_read_timeout         90;

        proxy_buffer_size          4k;
        proxy_buffers              4 32k;
        proxy_busy_buffers_size    64k;
        proxy_temp_file_write_size 64k;

        expires                    off;
Docker Pull Command
Source Repository