mirror of
https://github.com/chubin/wttr.in
synced 2024-11-15 00:27:09 +00:00
170 lines
6 KiB
Python
170 lines
6 KiB
Python
#vim: encoding=utf-8
|
||
|
||
import gevent
|
||
from gevent.wsgi import WSGIServer
|
||
from gevent.queue import Queue
|
||
from gevent.monkey import patch_all
|
||
from gevent.subprocess import Popen, PIPE, STDOUT
|
||
patch_all()
|
||
|
||
import os
|
||
import time
|
||
import json
|
||
import glob
|
||
|
||
from flask import Flask, request, render_template, send_from_directory, Response
|
||
app = Flask(__name__)
|
||
|
||
import requests
|
||
# Disable InsecureRequestWarning "Unverified HTTPS request is being..."
|
||
from requests.packages.urllib3.exceptions import InsecureRequestWarning, InsecurePlatformWarning, SNIMissingWarning
|
||
requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
|
||
requests.packages.urllib3.disable_warnings(InsecurePlatformWarning)
|
||
requests.packages.urllib3.disable_warnings(SNIMissingWarning)
|
||
|
||
import cyrtranslit
|
||
|
||
CACHEDIR = "api-cache"
|
||
|
||
|
||
def load_translations():
|
||
"""
|
||
load all translations
|
||
"""
|
||
translations = {}
|
||
|
||
langs = ['az', 'bs', 'ca', 'cy', 'eo', 'he', 'hr', 'hy', 'id', 'is', 'it', 'ja', 'kk', 'lv', 'mk', 'nb', 'nn', 'sl', 'uz']
|
||
for f_name in langs:
|
||
f_name = 'share/translations/%s.txt' % f_name
|
||
translation = {}
|
||
lang = f_name.split('/')[-1].split('.', 1)[0]
|
||
with open(f_name, "r") as f_file:
|
||
for line in f_file:
|
||
if ':' not in line:
|
||
continue
|
||
if line.count(':') == 3:
|
||
_, trans, orig, _ = line.strip().split(':', 4)
|
||
else:
|
||
_, trans, orig = line.strip().split(':', 3)
|
||
trans = trans.strip()
|
||
orig = orig.strip()
|
||
|
||
translation[orig] = trans
|
||
translations[lang] = translation
|
||
return translations
|
||
TRANSLATIONS = load_translations()
|
||
|
||
|
||
def find_srv_for_query( path, query ):
|
||
return 'http://api.worldweatheronline.com/'
|
||
|
||
def load_content_and_headers( path, query ):
|
||
timestamp = time.strftime( "%Y%m%d%H", time.localtime() )
|
||
p = os.path.join( CACHEDIR, timestamp, path, query )
|
||
try:
|
||
return open( p, 'r' ).read(), json.loads( open( p+".headers", 'r' ).read() )
|
||
except Exception, e:
|
||
return None, None
|
||
|
||
def save_content_and_headers( path, query, content, headers ):
|
||
timestamp = time.strftime( "%Y%m%d%H", time.localtime() )
|
||
p = os.path.join( CACHEDIR, timestamp, path, query )
|
||
d = os.path.dirname( p )
|
||
if not os.path.exists( d ): os.makedirs( d )
|
||
open( p+".headers", 'w' ).write( json.dumps( headers ) )
|
||
open( p, 'w' ).write( content )
|
||
|
||
def translate(text, lang):
|
||
translated = TRANSLATIONS.get(lang, {}).get(text, text)
|
||
if text.encode('utf-8') == translated:
|
||
print "%s: %s" % (lang, text)
|
||
return translated
|
||
|
||
def cyr(to_translate):
|
||
return cyrtranslit.to_cyrillic(to_translate)
|
||
|
||
def patch_greek(original):
|
||
return original.decode('utf-8').replace(u"Ηλιόλουστη/ο", u"Ηλιόλουστη").encode('utf-8')
|
||
|
||
def add_translations(content, lang):
|
||
languages_to_translate = TRANSLATIONS.keys()
|
||
#print type(content['data']) #['current_condition'][0]['lang_xx'] = [{'value':'XXX'}]
|
||
try:
|
||
d = json.loads(content)
|
||
except Exception as e:
|
||
print "---"
|
||
print e
|
||
print "---"
|
||
|
||
try:
|
||
weather_condition = d['data']['current_condition'][0]['weatherDesc'][0]['value']
|
||
if lang in languages_to_translate:
|
||
d['data']['current_condition'][0]['lang_%s' % lang] = [{'value':translate(weather_condition, lang)}]
|
||
print translate(weather_condition, lang)
|
||
elif lang == 'sr':
|
||
d['data']['current_condition'][0]['lang_%s' % lang] = [{'value':cyr(d['data']['current_condition'][0]['lang_%s' % lang][0]['value'].encode('utf-8'))}]
|
||
elif lang == 'el':
|
||
d['data']['current_condition'][0]['lang_%s' % lang] = [{'value':patch_greek(d['data']['current_condition'][0]['lang_%s' % lang][0]['value'].encode('utf-8'))}]
|
||
elif lang == 'sr-lat':
|
||
d['data']['current_condition'][0]['lang_%s' % lang] = [{'value':d['data']['current_condition'][0]['lang_sr'][0]['value'].encode('utf-8')}]
|
||
|
||
fixed_weather = []
|
||
for w in d['data']['weather']:
|
||
fixed_hourly = []
|
||
for h in w['hourly']:
|
||
weather_condition = h['weatherDesc'][0]['value']
|
||
if lang in languages_to_translate:
|
||
h['lang_%s' % lang] = [{'value':translate(weather_condition, lang)}]
|
||
elif lang == 'sr':
|
||
h['lang_%s' % lang] = [{'value':cyr(h['lang_%s' % lang][0]['value'].encode('utf-8'))}]
|
||
elif lang == 'el':
|
||
h['lang_%s' % lang] = [{'value':patch_greek(h['lang_%s' % lang][0]['value'].encode('utf-8'))}]
|
||
elif lang == 'sr-lat':
|
||
h['lang_%s' % lang] = [{'value':h['lang_sr'][0]['value'].encode('utf-8')}]
|
||
fixed_hourly.append(h)
|
||
w['hourly'] = fixed_hourly
|
||
fixed_weather.append(w)
|
||
d['data']['weather'] = fixed_weather
|
||
|
||
content = json.dumps(d)
|
||
except Exception as e:
|
||
print e
|
||
return content
|
||
|
||
@app.route("/<path:path>")
|
||
def proxy(path):
|
||
lang = request.args.get('lang', 'en')
|
||
query_string = request.query_string
|
||
query_string = query_string.replace('sr-lat', 'sr')
|
||
content, headers = load_content_and_headers(path,query_string)
|
||
|
||
if content is None:
|
||
srv = find_srv_for_query(path, query_string)
|
||
url = '%s/%s?%s' % (srv, path, query_string)
|
||
print url
|
||
|
||
attempts = 5
|
||
while attempts:
|
||
r = requests.get(url, timeout=10)
|
||
try:
|
||
json.loads(r.content)
|
||
break
|
||
except:
|
||
attempts -= 1
|
||
|
||
headers = {}
|
||
headers['Content-Type'] = r.headers['content-type']
|
||
content = add_translations(r.content, lang)
|
||
try:
|
||
save_content_and_headers( path, query_string, content, headers )
|
||
except Exception, e:
|
||
print e
|
||
|
||
return content, 200, headers
|
||
|
||
if __name__ == "__main__":
|
||
#app.run(host='0.0.0.0', port=5001, debug=False)
|
||
#app.debug = True
|
||
server = WSGIServer(("", 5001), app)
|
||
server.serve_forever()
|
||
|