|
@ -5,9 +5,10 @@ Werkzeug Documentation: http://werkzeug.pocoo.org/documentation/ |
|
|
This file creates your application. |
|
|
This file creates your application. |
|
|
""" |
|
|
""" |
|
|
|
|
|
|
|
|
from app import app, db, socketio, DOMAIN |
|
|
from app import app, db, socketio, DOMAIN, light |
|
|
from flask import Flask, Response, session, render_template, request, redirect, url_for, flash, send_from_directory, jsonify, abort |
|
|
from flask import Flask, Response, session, render_template, request, redirect, url_for, flash, send_from_directory, jsonify, abort |
|
|
import json |
|
|
import json |
|
|
|
|
|
from functools import wraps |
|
|
from sqlalchemy.sql.expression import func, select |
|
|
from sqlalchemy.sql.expression import func, select |
|
|
from sqlalchemy.sql import except_ |
|
|
from sqlalchemy.sql import except_ |
|
|
from app.forms import UploadForm, EditForm, SearchForm, ChatForm, StackForm, AddtoStackForm, EditStackForm |
|
|
from app.forms import UploadForm, EditForm, SearchForm, ChatForm, StackForm, AddtoStackForm, EditStackForm |
|
@ -47,26 +48,34 @@ def allowed_file(filename): |
|
|
# Routing for your application. |
|
|
# Routing for your application. |
|
|
### |
|
|
### |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def check_light(func): |
|
|
|
|
|
@wraps(func) |
|
|
|
|
|
def decorated_function(*args, **kwargs): |
|
|
|
|
|
if not light: |
|
|
|
|
|
return func(*args, **kwargs) |
|
|
|
|
|
else: |
|
|
|
|
|
flash("Your account has expired. Update your billing info.") |
|
|
|
|
|
return redirect(url_for('home')) |
|
|
|
|
|
|
|
|
|
|
|
return decorated_function |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route('/', methods= ['POST','GET']) |
|
|
@app.route('/', methods= ['POST','GET']) |
|
|
def home(): |
|
|
def home(): |
|
|
|
|
|
print("/////////////") |
|
|
|
|
|
print(light) |
|
|
chat_form = ChatForm() |
|
|
chat_form = ChatForm() |
|
|
chat_messages = db.session.query(Chat).all() |
|
|
chat_messages = db.session.query(Chat).all() |
|
|
username = 'librarian' |
|
|
username = 'librarian' |
|
|
|
|
|
|
|
|
# if request.method == 'POST': |
|
|
|
|
|
# if chat_form.validate_on_submit(): |
|
|
|
|
|
# message = chat_form.message.data |
|
|
|
|
|
# msg = Chat(message) |
|
|
|
|
|
# db.session.add(msg) |
|
|
|
|
|
# db.session.commit() |
|
|
|
|
|
#client = request.remote_addr |
|
|
|
|
|
server = request.host |
|
|
server = request.host |
|
|
if request.environ.get('HTTP_X_FORWARDED_FOR') is None: |
|
|
if request.environ.get('HTTP_X_FORWARDED_FOR') is None: |
|
|
client =request.environ['REMOTE_ADDR'] |
|
|
client =request.environ['REMOTE_ADDR'] |
|
|
else: |
|
|
else: |
|
|
client = request.environ['HTTP_X_FORWARDED_FOR'] |
|
|
client = request.environ['HTTP_X_FORWARDED_FOR'] |
|
|
|
|
|
|
|
|
return render_template('home.html',domain=DOMAIN,chat=chat_messages, channel = 1, username=username, client=client, server=server) |
|
|
return render_template('home.html',domain=DOMAIN,chat=chat_messages, channel = 1, username=username, client=client, server=server, light=light) |
|
|
|
|
|
|
|
|
@app.route('/hello/<name>') |
|
|
@app.route('/hello/<name>') |
|
|
def hello(name): |
|
|
def hello(name): |
|
@ -75,9 +84,10 @@ def hello(name): |
|
|
@app.route('/about/') |
|
|
@app.route('/about/') |
|
|
def about(): |
|
|
def about(): |
|
|
"""Render the website's about page.""" |
|
|
"""Render the website's about page.""" |
|
|
return render_template('about.html', name="Mary Jane") |
|
|
return render_template('about.html', light=light) |
|
|
|
|
|
|
|
|
@app.route('/uploads/<filename>') |
|
|
@app.route('/uploads/<filename>') |
|
|
|
|
|
@check_light |
|
|
def uploaded_file(filename): |
|
|
def uploaded_file(filename): |
|
|
book = Book.query.filter_by(file=filename).first() |
|
|
book = Book.query.filter_by(file=filename).first() |
|
|
i = Instance(request.host, "download") |
|
|
i = Instance(request.host, "download") |
|
@ -89,7 +99,7 @@ def uploaded_file(filename): |
|
|
return send_from_directory(app.config['UPLOAD_FOLDER'], |
|
|
return send_from_directory(app.config['UPLOAD_FOLDER'], |
|
|
filename) |
|
|
filename) |
|
|
|
|
|
|
|
|
@app.route('/uploads/cover/<filename>') |
|
|
@app.route('/cover/<filename>') |
|
|
def uploaded_file_cover(filename): |
|
|
def uploaded_file_cover(filename): |
|
|
return send_from_directory(app.config['UPLOAD_FOLDER_COVER'], |
|
|
return send_from_directory(app.config['UPLOAD_FOLDER_COVER'], |
|
|
filename) |
|
|
filename) |
|
@ -130,7 +140,7 @@ def scape(): |
|
|
@app.route('/books_grid') |
|
|
@app.route('/books_grid') |
|
|
def show_books_grid(): |
|
|
def show_books_grid(): |
|
|
books = db.session.query(Book).all() # or you could have used User.query.all() |
|
|
books = db.session.query(Book).all() # or you could have used User.query.all() |
|
|
return render_template('show_books_grid.html', books=books) |
|
|
return render_template('show_books_grid.html', books=books, light=light) |
|
|
|
|
|
|
|
|
@app.route('/books/<int:id>') |
|
|
@app.route('/books/<int:id>') |
|
|
def show_book_by_id(id): |
|
|
def show_book_by_id(id): |
|
@ -154,12 +164,13 @@ def show_book_by_id(id): |
|
|
db.session.add(user_info) |
|
|
db.session.add(user_info) |
|
|
db.session.commit() |
|
|
db.session.commit() |
|
|
if not book: |
|
|
if not book: |
|
|
return render_template('red_link.html', id=id) |
|
|
return render_template('red_link.html', id=id, light=light) |
|
|
else: |
|
|
else: |
|
|
return render_template('show_book_detail.html', book=book, previousbook = previousbook, nextbook = nextbook, all_instances=all_instances) |
|
|
return render_template('show_book_detail.html', book=book, previousbook = previousbook, nextbook = nextbook, all_instances=all_instances, light=light) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route('/books/<int:id>/delete', methods=['POST', 'GET']) |
|
|
@app.route('/books/<int:id>/delete', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def remove_book_by_id(id): |
|
|
def remove_book_by_id(id): |
|
|
book_to_edit = Book.query.filter_by(id=id).first() |
|
|
book_to_edit = Book.query.filter_by(id=id).first() |
|
|
title = book_to_edit.title |
|
|
title = book_to_edit.title |
|
@ -170,6 +181,7 @@ def remove_book_by_id(id): |
|
|
return redirect(url_for('show_books')) |
|
|
return redirect(url_for('show_books')) |
|
|
|
|
|
|
|
|
@app.route('/books/<int:id>/edit', methods=['POST', 'GET']) |
|
|
@app.route('/books/<int:id>/edit', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def edit_book_by_id(id): |
|
|
def edit_book_by_id(id): |
|
|
book_to_edit = Book.query.filter_by(id=id).first() |
|
|
book_to_edit = Book.query.filter_by(id=id).first() |
|
|
user_form = EditForm(title = book_to_edit.title, author =book_to_edit.authors, category = book_to_edit.category, year_published= book_to_edit.year_published, message= book_to_edit.message, sameness=book_to_edit.sameness, gender=book_to_edit.gender, diversity=book_to_edit.diversity, who=book_to_edit.who) |
|
|
user_form = EditForm(title = book_to_edit.title, author =book_to_edit.authors, category = book_to_edit.category, year_published= book_to_edit.year_published, message= book_to_edit.message, sameness=book_to_edit.sameness, gender=book_to_edit.gender, diversity=book_to_edit.diversity, who=book_to_edit.who) |
|
@ -238,10 +250,11 @@ def edit_book_by_id(id): |
|
|
flash("%s updated" % (title)) |
|
|
flash("%s updated" % (title)) |
|
|
return redirect(url_for('show_book_by_id', id=id)) |
|
|
return redirect(url_for('show_book_by_id', id=id)) |
|
|
|
|
|
|
|
|
return render_template('edit_book_detail.html', book=book_to_edit, form=user_form) |
|
|
return render_template('edit_book_detail.html', book=book_to_edit, form=user_form, light=light) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route('/add-book', methods=['POST', 'GET']) |
|
|
@app.route('/add-book', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def add_book(): |
|
|
def add_book(): |
|
|
upload_form = UploadForm() |
|
|
upload_form = UploadForm() |
|
|
allbooks = db.session.query(Book).all() |
|
|
allbooks = db.session.query(Book).all() |
|
@ -338,7 +351,7 @@ def add_book(): |
|
|
return redirect(url_for('show_books')) |
|
|
return redirect(url_for('show_books')) |
|
|
|
|
|
|
|
|
flash_errors(upload_form) |
|
|
flash_errors(upload_form) |
|
|
return render_template('add_book.html', form=upload_form, books_all=books_all, authors_all=authors_all, categories=categories, stacks_all=stacks_all, books_potential=books_potential, earliest=earliest, latest=latest) |
|
|
return render_template('add_book.html', form=upload_form, books_all=books_all, authors_all=authors_all, categories=categories, stacks_all=stacks_all, books_potential=books_potential, earliest=earliest, latest=latest, light=light) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Flash errors from the form if validation fails |
|
|
# Flash errors from the form if validation fails |
|
@ -358,10 +371,11 @@ def show_author_by_id(id): |
|
|
if not author: |
|
|
if not author: |
|
|
abort (404) |
|
|
abort (404) |
|
|
else: |
|
|
else: |
|
|
return render_template('show_author_detail.html', author=author) |
|
|
return render_template('show_author_detail.html', author=author, light=light) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route('/authors/<int:id>/edit', methods=['POST', 'GET']) |
|
|
@app.route('/authors/<int:id>/edit', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def edit_author_by_id(id): |
|
|
def edit_author_by_id(id): |
|
|
return "Ask the programmer." |
|
|
return "Ask the programmer." |
|
|
|
|
|
|
|
@ -370,9 +384,10 @@ def edit_author_by_id(id): |
|
|
@app.route('/stacks') |
|
|
@app.route('/stacks') |
|
|
def show_stacks(): |
|
|
def show_stacks(): |
|
|
stacks = db.session.query(Stack).all() |
|
|
stacks = db.session.query(Stack).all() |
|
|
return render_template('show_stacks.html', stacks=stacks) |
|
|
return render_template('show_stacks.html', stacks=stacks, light=light) |
|
|
|
|
|
|
|
|
@app.route('/stacks/add_stack', methods=['POST', 'GET']) |
|
|
@app.route('/stacks/add_stack', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def add_stack(): |
|
|
def add_stack(): |
|
|
form = StackForm() |
|
|
form = StackForm() |
|
|
stacks = db.session.query(Stack).all() |
|
|
stacks = db.session.query(Stack).all() |
|
@ -388,7 +403,7 @@ def add_stack(): |
|
|
stacks = db.session.query(Stack).all() |
|
|
stacks = db.session.query(Stack).all() |
|
|
return redirect(url_for('show_stacks')) |
|
|
return redirect(url_for('show_stacks')) |
|
|
flash("%s stack created" % (stack_name)) |
|
|
flash("%s stack created" % (stack_name)) |
|
|
return render_template('add_stack.html', stacks=stacks, form=form) |
|
|
return render_template('add_stack.html', stacks=stacks, form=form, light=light) |
|
|
|
|
|
|
|
|
@app.route('/stacks/tab/<int:id>', methods=['POST', 'GET']) |
|
|
@app.route('/stacks/tab/<int:id>', methods=['POST', 'GET']) |
|
|
def show_stack_in_tab(id): |
|
|
def show_stack_in_tab(id): |
|
@ -400,20 +415,22 @@ def show_stack_by_id(id, is_tab=False): |
|
|
|
|
|
|
|
|
stack = Stack.query.get(id) |
|
|
stack = Stack.query.get(id) |
|
|
if not stack: |
|
|
if not stack: |
|
|
return render_template('add_stack.html', stacks=stacks, form=form) |
|
|
return render_template('add_stack.html', stacks=stacks, form=form, light=light) |
|
|
else: |
|
|
else: |
|
|
if is_tab == False: |
|
|
if is_tab == False: |
|
|
return render_template('show_stack_detail.html', stack=stack) |
|
|
return render_template('show_stack_detail.html', stack=stack, light=light) |
|
|
else: |
|
|
else: |
|
|
return render_template('show_stack_detail_tab.html', stack=stack) |
|
|
return render_template('show_stack_detail_tab.html', stack=stack, light=light) |
|
|
|
|
|
|
|
|
@app.route('/stacks/<int:id>/delete', methods=['POST', 'GET']) |
|
|
@app.route('/stacks/<int:id>/delete', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def remove_stack_by_id(id): |
|
|
def remove_stack_by_id(id): |
|
|
Stack.query.filter_by(id=id).delete() |
|
|
Stack.query.filter_by(id=id).delete() |
|
|
db.session.commit() |
|
|
db.session.commit() |
|
|
return redirect(url_for('show_stacks')) |
|
|
return redirect(url_for('show_stacks')) |
|
|
|
|
|
|
|
|
@app.route('/stacks/<int:id>/edit', methods=['POST', 'GET']) |
|
|
@app.route('/stacks/<int:id>/edit', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def edit_stack_by_id(id): |
|
|
def edit_stack_by_id(id): |
|
|
stack = Stack.query.filter_by(id=id).first() |
|
|
stack = Stack.query.filter_by(id=id).first() |
|
|
form = EditStackForm(edit_stack_name = stack.stack_name, edit_stack_description = stack.stack_description) |
|
|
form = EditStackForm(edit_stack_name = stack.stack_name, edit_stack_description = stack.stack_description) |
|
@ -426,9 +443,10 @@ def edit_stack_by_id(id): |
|
|
stack.stack_description = stack_description |
|
|
stack.stack_description = stack_description |
|
|
db.session.commit() |
|
|
db.session.commit() |
|
|
return redirect(url_for('show_stack_by_id', id=id)) |
|
|
return redirect(url_for('show_stack_by_id', id=id)) |
|
|
return render_template('edit_stack_detail.html', stack=stack, form=form) |
|
|
return render_template('edit_stack_detail.html', stack=stack, form=form, light=light) |
|
|
|
|
|
|
|
|
@app.route('/instances', methods=['POST', 'GET']) |
|
|
@app.route('/instances', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def show_instances(): |
|
|
def show_instances(): |
|
|
all_instances = db.session.query(Instance).all() |
|
|
all_instances = db.session.query(Instance).all() |
|
|
instances = [] |
|
|
instances = [] |
|
@ -457,17 +475,18 @@ def show_instances(): |
|
|
print(oldname) |
|
|
print(oldname) |
|
|
print(name) |
|
|
print(name) |
|
|
db.session.commit() |
|
|
db.session.commit() |
|
|
return render_template('show_instances.html', instances=instances) |
|
|
return render_template('show_instances.html', instances=instances, light=light) |
|
|
|
|
|
|
|
|
@app.route('/stacks/<int:stackid>/remove/<int:bookid>', methods=['POST', 'GET']) |
|
|
@app.route('/stacks/<int:stackid>/remove/<int:bookid>', methods=['POST', 'GET']) |
|
|
|
|
|
@check_light |
|
|
def remove_from_stack(bookid, stackid): |
|
|
def remove_from_stack(bookid, stackid): |
|
|
book = Book.query.get(bookid) |
|
|
book = Book.query.get(bookid) |
|
|
stack = Stack.query.get(stackid) |
|
|
stack = Stack.query.get(stackid) |
|
|
if book not in stack.books: |
|
|
if book not in stack.books: |
|
|
return render_template('show_book_detail.html', book=book) |
|
|
return render_template('show_book_detail.html', book=book, light=light) |
|
|
stack.books.remove(book) |
|
|
stack.books.remove(book) |
|
|
db.session.commit() |
|
|
db.session.commit() |
|
|
return render_template('show_book_detail.html', book=book) |
|
|
return render_template('show_book_detail.html', book=book, light=light) |
|
|
|
|
|
|
|
|
## search |
|
|
## search |
|
|
view = ['1'] |
|
|
view = ['1'] |
|
@ -482,12 +501,12 @@ def show_books(): |
|
|
if search.grid.data: |
|
|
if search.grid.data: |
|
|
viewby = '2' |
|
|
viewby = '2' |
|
|
view.append('2') |
|
|
view.append('2') |
|
|
return render_template ('show_books_grid.html', books=books, form=search) |
|
|
return render_template ('show_books_grid.html', books=books, form=search, light=light) |
|
|
|
|
|
|
|
|
if search.listview.data: |
|
|
if search.listview.data: |
|
|
viewby = '1' |
|
|
viewby = '1' |
|
|
view.append('1') |
|
|
view.append('1') |
|
|
return render_template ('show_books.html', books=books, form=search) |
|
|
return render_template ('show_books.html', books=books, form=search, light=light) |
|
|
|
|
|
|
|
|
if request.method == 'POST': |
|
|
if request.method == 'POST': |
|
|
newmsg = 'searched for: ' + search.search.data |
|
|
newmsg = 'searched for: ' + search.search.data |
|
@ -504,7 +523,7 @@ def show_books(): |
|
|
db.session.rollback() |
|
|
db.session.rollback() |
|
|
return redirect((url_for('search_results', searchtype=search.select.data, query=search.search.data, viewby=viewby))) |
|
|
return redirect((url_for('search_results', searchtype=search.select.data, query=search.search.data, viewby=viewby))) |
|
|
|
|
|
|
|
|
return render_template('show_books.html', books=books, form=search) |
|
|
return render_template('show_books.html', books=books, form=search, light=light) |
|
|
|
|
|
|
|
|
@app.route('/search/<searchtype>/<viewby>/<query>', methods=['POST', 'GET']) |
|
|
@app.route('/search/<searchtype>/<viewby>/<query>', methods=['POST', 'GET']) |
|
|
def search_results(searchtype, query, viewby): |
|
|
def search_results(searchtype, query, viewby): |
|
@ -539,7 +558,7 @@ def search_results(searchtype, query, viewby): |
|
|
if results.count() == 0: |
|
|
if results.count() == 0: |
|
|
books = Book.query.filter(Book.file.like('potential.pdf')) |
|
|
books = Book.query.filter(Book.file.like('potential.pdf')) |
|
|
upload_form = UploadForm(title= query, author='') |
|
|
upload_form = UploadForm(title= query, author='') |
|
|
return render_template('red_link.html', form=upload_form, title=query, books=books) |
|
|
return render_template('red_link.html', form=upload_form, title=query, books=books, light=light) |
|
|
|
|
|
|
|
|
count = results.count() |
|
|
count = results.count() |
|
|
whole = Book.query.count() |
|
|
whole = Book.query.count() |
|
@ -549,11 +568,11 @@ def search_results(searchtype, query, viewby): |
|
|
|
|
|
|
|
|
if search.listview.data: |
|
|
if search.listview.data: |
|
|
view.append('1') |
|
|
view.append('1') |
|
|
return render_template('results.html', books=results, form=search, query=query, books_all=books_all, searchtype=search.select.data, count = count, whole = whole, percentage = percentage) |
|
|
return render_template('results.html', books=results, form=search, query=query, books_all=books_all, searchtype=search.select.data, count = count, whole = whole, percentage = percentage, light=light) |
|
|
|
|
|
|
|
|
if search.grid.data: |
|
|
if search.grid.data: |
|
|
view.append('2') |
|
|
view.append('2') |
|
|
return render_template('results_grid.html', books=results, form=search, query=query, books_all=books_all, searchtype=search.select.data, count = count, whole = whole, percentage = percentage) |
|
|
return render_template('results_grid.html', books=results, form=search, query=query, books_all=books_all, searchtype=search.select.data, count = count, whole = whole, percentage = percentage, light=light) |
|
|
|
|
|
|
|
|
if request.method == 'POST': |
|
|
if request.method == 'POST': |
|
|
newmsg = 'searched for: ' + search.search.data |
|
|
newmsg = 'searched for: ' + search.search.data |
|
@ -578,10 +597,10 @@ def search_results(searchtype, query, viewby): |
|
|
return redirect((url_for('search_results', searchtype=search.select.data, query=search.search.data, viewby=viewby))) |
|
|
return redirect((url_for('search_results', searchtype=search.select.data, query=search.search.data, viewby=viewby))) |
|
|
|
|
|
|
|
|
if viewby == '2': |
|
|
if viewby == '2': |
|
|
return render_template('results_grid.html', form=search, books=results, books_all=books_all, searchtype=search.select.data, query=query, count = count, whole = whole, percentage = percentage) |
|
|
return render_template('results_grid.html', form=search, books=results, books_all=books_all, searchtype=search.select.data, query=query, count = count, whole = whole, percentage = percentage, light=light) |
|
|
|
|
|
|
|
|
else: |
|
|
else: |
|
|
return render_template('results.html', form=search, books=results, books_all=books_all, searchtype=search.select.data, query=query, count = count, whole = whole, percentage = percentage) |
|
|
return render_template('results.html', form=search, books=results, books_all=books_all, searchtype=search.select.data, query=query, count = count, whole = whole, percentage = percentage, light=light) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# ## Search - autocomplete |
|
|
# ## Search - autocomplete |
|
@ -611,22 +630,24 @@ def search_results(searchtype, query, viewby): |
|
|
## STACKS! |
|
|
## STACKS! |
|
|
|
|
|
|
|
|
@app.route('/add_to_stack/<int:id>', methods=['GET', 'POST']) |
|
|
@app.route('/add_to_stack/<int:id>', methods=['GET', 'POST']) |
|
|
|
|
|
@check_light |
|
|
def add_to_stack(id): |
|
|
def add_to_stack(id): |
|
|
stacks = db.session.query(Stack).all() |
|
|
stacks = db.session.query(Stack).all() |
|
|
add_form = AddtoStackForm(request.form) |
|
|
add_form = AddtoStackForm(request.form) |
|
|
add_form.select_stack.choices = [(stack.id, stack.stack_name) for stack in stacks] |
|
|
add_form.select_stack.choices = [(stack.id, stack.stack_name) for stack in stacks] |
|
|
if request.method == 'GET': |
|
|
if request.method == 'GET': |
|
|
book = Book.query.get(id) |
|
|
book = Book.query.get(id) |
|
|
return render_template('add_to_stacks.html', id=id, stacks=stacks, book=book, add_form=add_form) |
|
|
return render_template('add_to_stacks.html', id=id, stacks=stacks, book=book, add_form=add_form, light=light) |
|
|
else: |
|
|
else: |
|
|
stack = Stack.query.get(int(add_form.select_stack.data)) |
|
|
stack = Stack.query.get(int(add_form.select_stack.data)) |
|
|
book = Book.query.get(id) |
|
|
book = Book.query.get(id) |
|
|
stack.books.append(book) |
|
|
stack.books.append(book) |
|
|
db.session.commit() |
|
|
db.session.commit() |
|
|
return render_template('show_stack_detail.html', stack=stack) |
|
|
return render_template('show_stack_detail.html', stack=stack, light=light) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route('/export/csv', methods=['GET']) |
|
|
@app.route('/export/csv', methods=['GET']) |
|
|
|
|
|
@check_light |
|
|
def export_csv(): |
|
|
def export_csv(): |
|
|
output = io.StringIO() |
|
|
output = io.StringIO() |
|
|
#fieldnames = ['title', 'authors', 'file', 'fileformat', 'category', 'year_published', 'description' ] |
|
|
#fieldnames = ['title', 'authors', 'file', 'fileformat', 'category', 'year_published', 'description' ] |
|
@ -662,6 +683,7 @@ def export_csv(): |
|
|
|
|
|
|
|
|
import codecs |
|
|
import codecs |
|
|
@app.route('/import/csv', methods= ['POST','GET']) |
|
|
@app.route('/import/csv', methods= ['POST','GET']) |
|
|
|
|
|
@check_light |
|
|
def import_csv(): |
|
|
def import_csv(): |
|
|
if request.method == 'POST': |
|
|
if request.method == 'POST': |
|
|
if 'file' not in request.files: |
|
|
if 'file' not in request.files: |
|
@ -719,10 +741,11 @@ def import_csv(): |
|
|
db.session.add(a) |
|
|
db.session.add(a) |
|
|
book.authors.append(a) |
|
|
book.authors.append(a) |
|
|
db.session.commit() |
|
|
db.session.commit() |
|
|
return render_template('import_csv.html', numberadded=numberadded) |
|
|
return render_template('import_csv.html', numberadded=numberadded, light=light) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.route('/empty_catalogue487352698237465', methods= ['POST','GET']) |
|
|
@app.route('/emptycataloguexpubxpubfuck', methods= ['POST','GET']) |
|
|
|
|
|
@check_light |
|
|
def empty_catalogue(): |
|
|
def empty_catalogue(): |
|
|
meta = db.metadata |
|
|
meta = db.metadata |
|
|
for table in reversed(meta.sorted_tables): |
|
|
for table in reversed(meta.sorted_tables): |
|
@ -766,12 +789,6 @@ def get_chat(): |
|
|
# The functions below should be applicable to all Flask apps. |
|
|
# The functions below should be applicable to all Flask apps. |
|
|
### |
|
|
### |
|
|
|
|
|
|
|
|
@app.route('/<file_name>.txt') |
|
|
|
|
|
def send_text_file(file_name): |
|
|
|
|
|
"""Send your static text file.""" |
|
|
|
|
|
file_dot_text = file_name + '.txt' |
|
|
|
|
|
return app.send_static_file(file_dot_text) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.after_request |
|
|
@app.after_request |
|
|
def add_header(response): |
|
|
def add_header(response): |
|
@ -780,14 +797,14 @@ def add_header(response): |
|
|
and also to cache the rendered page for 10 minutes. |
|
|
and also to cache the rendered page for 10 minutes. |
|
|
""" |
|
|
""" |
|
|
response.headers['X-UA-Compatible'] = 'IE=Edge,chrome=1' |
|
|
response.headers['X-UA-Compatible'] = 'IE=Edge,chrome=1' |
|
|
response.headers['Cache-Control'] = 'public, max-age=600' |
|
|
response.headers['Cache-Control'] = 'no-cache' |
|
|
return response |
|
|
return response |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@app.errorhandler(404) |
|
|
@app.errorhandler(404) |
|
|
def page_not_found(error): |
|
|
def page_not_found(error): |
|
|
"""Custom 404 page.""" |
|
|
"""Custom 404 page.""" |
|
|
return render_template('404.html'), 404 |
|
|
return render_template('404.html', light=light), 404 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### SOCKET for the chat |
|
|
### SOCKET for the chat |
|
|