]>
git.gir.st - subscriptionfeed.git/blob - app/reddit/__init__.py
3 from flask_login
import current_user
, login_required
4 from flask
import Blueprint
, render_template
, request
, redirect
, flash
6 from ..common
.common
import *
8 frontend
= Blueprint('reddit', __name__
,
9 template_folder
='templates',
10 static_folder
='static',
11 static_url_path
='/static/rd')
13 @frontend.route('/feed/subreddits')
14 @frontend.route('/r/<subreddit>')
15 def reddit(subreddit
=None):
16 token
= getattr(current_user
, 'token', 'guest')
17 count
= int(request
.args
.get('count', 0))
18 before
= request
.args
.get('before')
19 after
= request
.args
.get('after')
21 sortorder
= request
.args
.get('s', "hot") # TODO: verify!
22 timerange
= request
.args
.get('t', None) # TODO: verify!
24 all_subreddits
= get_subreddits(token
)
25 subreddits
= [subreddit
] if subreddit
else all_subreddits
28 data
= fetch_reddit(subreddits
,
29 sorted_by
=sortorder
, time
=timerange
, limit
=36,
30 count
=count
, before
=before
, after
=after
)
31 videos
= parse_reddit_videos(data
)
32 before
= data
['data']['before']
33 after
= data
['data']['after']
34 except RedditException
as e
:
35 return f
"error retrieving reddit data: <xmp>{e}</xmp>", 502 # TODO: better
37 # set pin/hide stati of retrieved videos
38 with sqlite3
.connect(cf
['global']['database']) as conn
:
41 SELECT video_id,display
44 AND display IS NOT NULL
45 -- AND display = 'pinned'
49 pinned
= [video
for video
,disp
in flags
if disp
== 'pinned']
50 hidden
= [video
for video
,disp
in flags
if disp
== 'hidden']
52 {**v
, 'pinned': v
['video_id'] in pinned
}
54 if v
['video_id'] not in hidden
55 ], key
=lambda v
:v
['pinned'], reverse
=True)
57 title
= f
"/r/{subreddit}" if subreddit
else "my subreddits"
58 return render_template('reddit.html.j2', title
=title
, rows
=videos
,
59 subreddits
=all_subreddits
, before
=before
, after
=after
, count
=count
)
61 @frontend.route('/manage/subreddits')
62 # disabled for guest user: @login_required
63 def subscription_manager():
64 token
= getattr(current_user
, 'token', 'guest')
65 subreddits
= get_subreddits(token
)
66 return render_template('subreddit_manager.html.j2', subreddits
=subreddits
)
68 @frontend.route('/manage/subreddits', methods
=['POST'])
70 def manage_subscriptions():
71 token
= current_user
.token
72 if 'subscribe' in request
.form
:
73 subreddit
= request
.form
.get("subscribe")
74 match
= re
.search(r
"(?:(?:https?://)?(?:old.|www.|\w\w.)?reddit.com)?(?:/?r/)?([-+_0-9A-Za-z]{2,21})", subreddit
)
76 subreddit
= match
.group(1)
78 flash("invalid subreddit", "error")
79 return redirect(request
.url
, code
=303)
80 with sqlite3
.connect(cf
['global']['database']) as conn
:
83 INSERT OR IGNORE INTO subreddits (user, subreddit)
85 """, (token
, subreddit
))
87 elif 'unsubscribe' in request
.form
:
88 subreddit
= request
.form
.get("unsubscribe")
89 with sqlite3
.connect(cf
['global']['database']) as conn
:
92 DELETE FROM subreddits
93 WHERE user = ? AND subreddit = ?
94 """, (token
, subreddit
))
95 # TODO: sql-error-handling, report success
98 flash("unsupported action", "error")
100 return redirect(request
.url
, code
=303)
102 def get_subreddits(token
):
103 with sqlite3
.connect(cf
['global']['database']) as conn
:
109 ORDER BY subreddit COLLATE NOCASE ASC
111 subreddits
= [sr
for (sr
,) in c
.fetchall()]
114 @frontend.app_template_filter('trim3')
117 return n
# not a number
118 elif round(n
, 1) >= 10_000:
119 return "%.0fk" % (n
/1000)
121 return "%.1fk" % (n
/1000)