You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

140 lines
3.9 KiB

from couchpotato.api import api_docs, api_docs_missing, api
14 years ago
from couchpotato.core.event import fireEvent
12 years ago
from couchpotato.core.helpers.variable import md5, tryInt
from couchpotato.core.logger import CPLog
from couchpotato.environment import Env
from tornado import template
12 years ago
from tornado.web import RequestHandler, authenticated
import os
import time
import traceback
log = CPLog(__name__)
14 years ago
views = {}
template_loader = template.Loader(os.path.join(os.path.dirname(__file__), 'templates'))
12 years ago
class BaseHandler(RequestHandler):
def get_current_user(self):
username = Env.setting('username')
password = Env.setting('password')
if username and password:
12 years ago
return self.get_secure_cookie('user')
else: # Login when no username or password are set
return True
# Main web handler
12 years ago
class WebHandler(BaseHandler):
@authenticated
def get(self, route, *args, **kwargs):
route = route.strip('/')
if not views.get(route):
page_not_found(self)
return
try:
self.write(views[route]())
except:
12 years ago
log.error("Failed doing web request '%s': %s", (route, traceback.format_exc()))
self.write({'success': False, 'error': 'Failed returning results'})
def addView(route, func, static = False):
views[route] = func
14 years ago
14 years ago
def get_session(engine = None):
return Env.getSession(engine)
14 years ago
# Web view
def index():
return template_loader.load('index.html').generate(sep = os.sep, fireEvent = fireEvent, Env = Env)
addView('', index)
14 years ago
# API docs
def apiDocs():
routes = []
for route in api.iterkeys():
routes.append(route)
if api_docs.get(''):
del api_docs['']
del api_docs_missing['']
return template_loader.load('api.html').generate(fireEvent = fireEvent, routes = sorted(routes), api_docs = api_docs, api_docs_missing = sorted(api_docs_missing), Env = Env)
addView('docs', apiDocs)
# Make non basic auth option to get api key
class KeyHandler(RequestHandler):
def get(self, *args, **kwargs):
api = None
try:
username = Env.setting('username')
password = Env.setting('password')
if (self.get_argument('u') == md5(username) or not username) and (self.get_argument('p') == password or not password):
api = Env.setting('api_key')
self.write({
'success': api is not None,
'api_key': api
})
except:
log.error('Failed doing key request: %s', (traceback.format_exc()))
self.write({'success': False, 'error': 'Failed returning results'})
12 years ago
class LoginHandler(BaseHandler):
def get(self, *args, **kwargs):
if self.get_current_user():
12 years ago
self.redirect(Env.get('web_base'))
12 years ago
else:
12 years ago
self.write(template_loader.load('login.html').generate(sep = os.sep, fireEvent = fireEvent, Env = Env))
12 years ago
def post(self, *args, **kwargs):
api = None
username = Env.setting('username')
password = Env.setting('password')
if (self.get_argument('username') == username or not username) and (md5(self.get_argument('password')) == password or not password):
api = Env.setting('api_key')
if api:
remember_me = tryInt(self.get_argument('remember_me', default = 0))
12 years ago
self.set_secure_cookie('user', api, expires_days = 30 if remember_me > 0 else None)
12 years ago
12 years ago
self.redirect(Env.get('web_base'))
12 years ago
class LogoutHandler(BaseHandler):
def get(self, *args, **kwargs):
self.clear_cookie('user')
12 years ago
self.redirect('%slogin/' % Env.get('web_base'))
12 years ago
def page_not_found(rh):
index_url = Env.get('web_base')
url = rh.request.uri[len(index_url):]
if url[:3] != 'api':
r = index_url + '#' + url.lstrip('/')
rh.redirect(r)
else:
if not Env.get('dev'):
time.sleep(0.1)
rh.set_status(404)
rh.write('Wrong API key used')
14 years ago