Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Initial commit #15

Open
wants to merge 1 commit into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Binary file added __pycache__/bookdb.cpython-37.pyc
Binary file not shown.
59 changes: 54 additions & 5 deletions bookapp.py
Original file line number Diff line number Diff line change
@@ -1,24 +1,73 @@
import re
import traceback

from bookdb import BookDB

DB = BookDB()


def book(book_id):
return "<h1>a book with id %s</h1>" % book_id

page = """
<h1>{title}</h1>
<table>
<tr><th>Author</th><td>{author}</td></tr>
<tr><th>Publisher</th><td>{publisher}</td></tr>
<tr><th>ISBN</th><td>{isbn}</td></tr>
</table>
<a href="/">Back to the list</a>
"""
book = DB.title_info(book_id)
if book is None:
raise NameError
return page.format(**book)

def books():
return "<h1>a list of books</h1>"
book_list = DB.titles()
body = ['<h1>My Bookshelf</h1>', '<ul>']
title = '<li><a href="/book/{id}">{title}</a></li>'
for book in book_list:
body.append(title.format(**book))
body.append('</ul>')
return '\n'.join(body)

def resolve_path(path):
funcs = {'': books, 'book': book}
path = path.strip('/').split('/')
args = path[1:]

try:
func = funcs[path[0]]
except KeyError:
raise NameError

return func, args

def application(environ, start_response):
status = "200 OK"
headers = [('Content-type', 'text/html')]
start_response(status, headers)
return ["<h1>No Progress Yet</h1>".encode('utf8')]

# Try/except block to determine what the body and status will be
try:
path = environ.get('PATH_INFO', None)
if path is None:
raise NameError
func, args = resolve_path(path)
body = func(*args)
status = "200 OK"

except NameError:
status = "404 Not Found"
body = "<h1>Not Found</h1>"

except Exception:
status = "500 Internal Server Error"
body = "<h1>Internal Server Error</h1>"
print(traceback.format_exc())

finally:
headers.append(('Content-length', str(len(body))))
start_response(status, headers)
return [body.encode('utf8')]

if __name__ == '__main__':
from wsgiref.simple_server import make_server
Expand Down
11 changes: 6 additions & 5 deletions wsgi_1.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
#!C:\Users\steve\AppData\Local\Programs\Python\Python37\python.exe
#!/usr/bin/env python
import datetime

Expand All @@ -21,11 +22,11 @@ def application(environ, start_response):

response_body = body.format(
software=environ.get('SERVER_SOFTWARE', default),
path="aaaa",
month="bbbb",
date="cccc",
year="dddd",
client_ip="eeee"
path=environ.get('PATH', default),
month=datetime.datetime.now().strftime('%B'),
date=datetime.datetime.now().day,
year=datetime.datetime.now().year,
client_ip=environ.get('REMOTE_ADDR', default),
)
status = '200 OK'

Expand Down