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.

150 lines
4.1 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
14 years ago
11 years ago
log = CPLog(__name__)
views = {}
template_loader = template.Loader(os.path.join(os.path.dirname(__file__), 'templates'))
11 years ago
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')
11 years ago
else: # Login when no username or password are set
12 years ago
return True
11 years ago
# 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'})
11 years ago
def addView(route, func, static = False):
views[route] = func
14 years ago
11 years ago
11 years ago
def get_db():
return Env.get('db')
14 years ago
# Web view
def index():
11 years ago
return template_loader.load('index.thtml').generate(sep = os.sep, fireEvent = fireEvent, Env = Env)
addView('', index)
14 years ago
11 years ago
# API docs
def apiDocs():
11 years ago
routes = list(api.keys())
if api_docs.get(''):
del api_docs['']
del api_docs_missing['']
11 years ago
return template_loader.load('api.thtml').generate(fireEvent = fireEvent, routes = sorted(routes), api_docs = api_docs, api_docs_missing = sorted(api_docs_missing), Env = Env)
addView('docs', apiDocs)
11 years ago
# Database debug manager
def databaseManage():
11 years ago
return template_loader.load('database.thtml').generate(fireEvent = fireEvent, Env = Env)
addView('database', databaseManage)
# Make non basic auth option to get api key
class KeyHandler(RequestHandler):
def get(self, *args, **kwargs):
11 years ago
api_key = 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):
11 years ago
api_key = Env.setting('api_key')
self.write({
11 years ago
'success': api_key is not None,
'api_key': api_key
})
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:
11 years ago
self.write(template_loader.load('login.thtml').generate(sep = os.sep, fireEvent = fireEvent, Env = Env))
12 years ago
def post(self, *args, **kwargs):
11 years ago
api_key = None
12 years ago
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):
11 years ago
api_key = Env.setting('api_key')
12 years ago
11 years ago
if api_key:
12 years ago
remember_me = tryInt(self.get_argument('remember_me', default = 0))
11 years ago
self.set_secure_cookie('user', api_key, expires_days = 30 if remember_me > 0 else None)
12 years ago
12 years ago
self.redirect(Env.get('web_base'))
12 years ago
11 years ago
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')