1
0
Fork 0
mirror of https://github.com/Findus23/se-simulator.git synced 2024-09-11 06:33:48 +02:00

add server

This commit is contained in:
Lukas Winkler 2018-03-22 22:52:14 +01:00
parent ad0a671cba
commit d2e7daf331
No known key found for this signature in database
GPG key ID: 94AFBE7C2656A5B5
15 changed files with 260 additions and 1 deletions

4
.gitignore vendored
View file

@ -5,3 +5,7 @@ word-rnn-tensorflow/
.idea/
__pycache__/
config.py
*.old
web/static/css/
!web/static/css/.gitkeep

3
.gitmodules vendored Normal file
View file

@ -0,0 +1,3 @@
[submodule "web/milligram"]
path = web/milligram
url = git@github.com:Findus23/milligram.git

18
app.py Normal file
View file

@ -0,0 +1,18 @@
# Blog configuration values.
from flask import Flask
from playhouse.flask_utils import FlaskDB
from playhouse.pool import PooledMySQLDatabase
import config
DATABASE = PooledMySQLDatabase("stackdata", **config.db)
# Create a Flask WSGI app and configure it using values from the module.
app = Flask(__name__)
app.config.from_object(__name__)
flask_db = FlaskDB(app)
db = flask_db.database

View file

@ -38,6 +38,7 @@ class Question(BaseModel):
title = ForeignKeyField(Title)
user = ForeignKeyField(User)
site = ForeignKeyField(Site)
datetime = DateTimeField()
class Answer(BaseModel):

20
requirements.txt Normal file
View file

@ -0,0 +1,20 @@
args==0.1.0
backports.csv==1.0.5
beautifulsoup4==4.6.0
certifi==2018.1.18
chardet==3.0.4
clint==0.5.1
docopt==0.6.2
html2text==2018.1.9
idna==2.6
internetarchive==1.7.7
jsonlines==1.2.0
jsonpatch==1.21
jsonpointer==2.0
lxml==4.2.0
mysqlclient==1.3.12
peewee==3.1.3
requests==2.18.4
schema==0.6.7
six==1.11.0
urllib3==1.22

68
server.py Normal file
View file

@ -0,0 +1,68 @@
from datetime import datetime
from flask import render_template, flash
from playhouse.shortcuts import model_to_dict
from sassutils.wsgi import SassMiddleware
import utils
from app import app
from models import *
app.jinja_env.globals.update(prettydate=utils.prettydate)
def query_to_response(query, limit=10, key=False, sort=False, offset=None, list=None, **kwargs):
"""
:param sort: boolean
:param offset: int
:type key: str
:type limit: int|boolean
:param **kwargs
:type query: peewee.ModelSelect
"""
if limit:
query = query.limit(limit)
print(query.sql())
data = {} if key is not False else []
order = int(offset) if offset else 0
for i in query:
element = model_to_dict(i, **kwargs)
if list:
element = element[list]
if sort:
element["order"] = order
order += 1
if key is not False:
if "." in key:
key1, key2 = key.split(".")
data[getattr(getattr(i, key1), key2)] = element
else:
data[getattr(i, key)] = element
else:
data.append(element)
return data
@app.route('/')
def index():
query = Question.select().limit(10)
# return query_to_response(Question.select().limit(10), limit=False, max_depth=1)
# return query_to_response(query, max_depth=1)
return render_template('list.html', questions=query_to_response(query, max_depth=1))
@app.route('/q/<string:slug>')
def question(slug):
# query = Question.select().limit(10)
# return query_to_response(Question.select().limit(10), limit=False, max_depth=1)
# return query_to_response(query, max_depth=1)
return render_template("detail.html", question=slug)
# return render_template('list.html', questions=query_to_response(query, max_depth=1))
if __name__ == '__main__':
app.debug = True
app.wsgi_app = SassMiddleware(app.wsgi_app, manifests={
'web': ('static/sass', 'static/css', '/static/css')
})
app.run()

10
templates/base.html Normal file
View file

@ -0,0 +1,10 @@
<!doctype html>
<title>Flaskr</title>
<link href="{{ url_for('static', filename='css/style.scss.css') }}" rel="stylesheet" type="text/css">
<div class="container">
<h1>Flaskr</h1>
{% for message in get_flashed_messages() %}
<div class="flash">{{ message }}</div>
{% endfor %}
{% block body %}{% endblock %}
</div>

4
templates/detail.html Normal file
View file

@ -0,0 +1,4 @@
{% extends "base.html" %}
{% block body %}
<h1>{{ question }}</h1>
{% endblock %}

29
templates/list.html Normal file
View file

@ -0,0 +1,29 @@
{% extends "base.html" %}
{% block body %}
{% for question in questions %}
<div class="question"
style="border-right-color:{{ question.site.tag_foreground_color }};background-color:{{ question.site.tag_background_color }}">
<div class="vote">
<a class="up"></a>
<div>{{ question.upvotes - question.downvotes }}</div>
<a class="down"></a>
</div>
<div class="questionbox">
<a href="https://{{ question.site.url }}" class="sitename" target="_blank" rel="noopener">
{{ question.site.name }}
</a>
<div>
<a class="title" style="color:{{ question.site.link_color }}"
href="{{ url_for("question",slug=question.title.slug) }}">{{ question.title.text }}</a>
</div>
{{ question.text }}
<div class="date">
asked {{ prettydate(question.datetime) }} by {{ question.user.username }}
</div>
</div>
</div>
{% else %}
<em>Unbelievable. No entries here so far</em>
{% endfor %}
<pre><code>{{ questions[0]|pprint }}</code></pre>
{% endblock %}

View file

@ -1,3 +1,5 @@
from datetime import datetime
from slugify import slugify
from models import *
@ -34,7 +36,8 @@ def add_question(site, count=100):
print(title.text)
user = users[i]
print(user.username)
Question.create(text=text, title_id=title, user_id=user, site_id=site)
time = datetime.now()
Question.create(text=text, title_id=title, user_id=user, site_id=site, datetime=time)
if __name__ == "__main__":

View file

@ -3,6 +3,7 @@ import random
import resource
import string
import sys
from datetime import datetime
from bs4 import BeautifulSoup
from internetarchive import get_item
@ -56,3 +57,27 @@ def get_settings(count):
def get_random_string(length):
return ''.join(random.choices(string.ascii_uppercase + string.digits, k=length))
def prettydate(d):
diff = datetime.now() - d
s = diff.seconds
print(diff)
if diff.days > 7 or diff.days < 0:
return d.strftime('%d %b %y')
elif diff.days == 1:
return '1 day ago'
elif diff.days > 1:
return '{} days ago'.format(diff.days)
elif s <= 1:
return 'just now'
elif s < 60:
return '{} seconds ago'.format(s)
elif s < 120:
return '1 minute ago'
elif s < 3600:
return '{} minutes ago'.format(int(s / 60))
elif s < 7200:
return '1 hour ago'
else:
return '{} hours ago'.format(int(s / 3600))

0
web/__init__.py Normal file
View file

1
web/milligram Submodule

@ -0,0 +1 @@
Subproject commit 0fde381605c1159f39efb5c33c9600331fec4e2e

View file

@ -0,0 +1,73 @@
$link-color: #07C;
$link-hover-color: #3af;
@import "../../milligram/src/milligram";
body {
font-family: Arial, "Helvetica Neue", Helvetica, sans-serif;
color: #111;
}
pre > code {
white-space: pre-wrap;
}
.question {
position: relative;
display: flex;
flex-direction: row;
padding: 15px 5px 30px;
border-bottom: solid lightgray 1px;
border-right: solid 10px;
.questionbox {
margin-left: 10px;
.sitename {
position: absolute;
font-size: 10px;
color: grey;
right: 5px;
&:hover {
text-decoration: underline;
}
}
.date{
position: absolute;
right: 5px;
bottom: 5px;
font-size: 12px;
color: grey;
}
}
.title {
font-size: 20px;
color: $link-color;
&:hover {
color: $link-hover-color;
}
}
.vote {
width: 30px;
display: flex;
flex-direction: column;
div {
text-align: center;
margin: 10px 0;
}
a {
font-size: 20px;
width: 0;
height: 0;
border-style: solid;
cursor: pointer;
}
.up {
border-width: 0 15px 15px 15px;
border-color: transparent transparent #858c93 transparent;
}
.down {
border-width: 15px 15px 0 15px;
border-color: #858c93 transparent transparent transparent;
}
}
}

View file