From 7750afc5b9d261387bd3e608342d7c494ba7d03f Mon Sep 17 00:00:00 2001 From: BlenderDumbass Date: Thu, 5 Dec 2024 15:54:16 +0200 Subject: [PATCH] API petitions, sign petitions by subscribing to mastodon and such --- modules/API.py | 50 +++++++++++ modules/Email.py | 11 +-- modules/Render.py | 209 +++++++++++++++++++++++++++++++++++++++------- 3 files changed, 232 insertions(+), 38 deletions(-) create mode 100644 modules/API.py diff --git a/modules/API.py b/modules/API.py new file mode 100644 index 0000000..e6163c0 --- /dev/null +++ b/modules/API.py @@ -0,0 +1,50 @@ +# AGPL 3 or any later version +# (C) J.Y.Amihud ( Blender Dumbass ) + +import os +import json +import time +import email +import random +import hashlib +import urllib.parse +import urllib.request + +from datetime import datetime + +from modules import Set +from modules.Common import * + +def Get(url, data=None, headers={}): + + if data: + data = json.dumps(data).encode("utf-8") + req = urllib.request.Request(url, data=data, headers=headers) + f = urllib.request.urlopen(req, timeout=10) + data = json.loads(f.read().decode('utf-8')) + return data + +def Value(url, keys): + + data = Get(url) + for key in keys: + data = data[key] + return data + +def Petition(article): + + petition = article.get("petition", {}) + api = petition.get("api", {}) + timestamp = api.get("timestamp",0) + + # 5 minutes delay + if time.time() - 300 < timestamp: + return + + value = int(Value(api.get("api", ""), api.get("keys", []))) + article["petition"]["api"]["timestamp"] = time.time() + article["petition"]["signed"] = value + + f = Set.Folder() + with open(f+"/tabs"+article.get("url", "")+"/metadata.json", "w") as save: + json.dump(article, save, indent=4) diff --git a/modules/Email.py b/modules/Email.py index c31335e..f72fa12 100644 --- a/modules/Email.py +++ b/modules/Email.py @@ -118,14 +118,12 @@ def VerifyPage(server): # If we recieved the code. if code not in verifying: - print("code not in verifying") - Render.AccessDenied(server) + Render.Error(server, "Wrong Code!") return if verifying[code] != user.get("email"): - print("email wrong") - Render.AccessDenied(server) + Render.Error(server, "Wrong Code!") return user["email_verified"] = True @@ -165,7 +163,7 @@ def SignPetition(server): email = server.parsed.get("email", [""])[0] if email in Article.get("petition", {}).get("signatures", []): - Render.AccessDenied(server) + Render.Error(server, "You already signed!") return if not code: @@ -222,8 +220,7 @@ def SignPetition(server): # If we recieved the code. if code not in verifying: - print("code not in verifying") - Render.AccessDenied(server) + Render.Error(server, "Wrong Code!") return diff --git a/modules/Render.py b/modules/Render.py index 6362ce5..350d73a 100644 --- a/modules/Render.py +++ b/modules/Render.py @@ -12,6 +12,7 @@ import urllib.parse from datetime import datetime from modules import Set +from modules import API from modules import markdown from modules.Common import * @@ -571,8 +572,16 @@ def ArticlePage(server, url): petition = Articles.get(article, {}).get("petition", "") if petition: + petition_error = False + + if petition.get("api"): + try: + API.Petition(Articles[article]) + except: + petition_error = True + html = html + '
' - html = html + '

[icon petition]' + html = html + '

' html = html + 'Petition

' try: @@ -583,29 +592,61 @@ def ArticlePage(server, url): html = html + ProgressBar(frac) html = html + "
"+str(petition.get("signed", 0))+" / "+Safe(str(petition.get("goal", 1)))+" Signatures" - html = html + """ - -
- - [icon petition] - Sign - - -
- - - - - - + # Last update + if petition.get("api"): -
+ lastUpdate = petition.get("api", {}).get("timestamp", {}) + nowTime = time.time() + html = html + '

Last updated: '+TimeDifference(lastUpdate, nowTime)+'

' -
- """ + if not petition.get("api"): + + html = html + """ + +
+ + [icon petition] + Sign + + +
+ + + + + + + +
+ +
+ """ + + else: + html = html + """ + +
+ + [icon petition] + Sign + + +
+
+ This petition is signed by increasing the number of
+ """+petition.get("api", {}).get("title", "")+""" +

+ + """+Button("Continue", petition.get("api", {}).get("link", ""), "ok")+""" + + +
+ + + """ html = html + '
' @@ -1395,9 +1436,22 @@ def EditorPage(server): if rank(user.get("username","")) == 0: - petition = article.get("petition", {}) - petition_goal = petition.get("goal", 0) - + petition = article.get("petition", {}) + petition_goal = petition.get("goal", "") + petition_api = petition.get("api", {}).get("api", "") + petition_api_key = petition.get("api", {}).get("keys", []) + petition_api_title = petition.get("api", {}).get("title", "") + petition_api_link = petition.get("api", {}).get("link", "") + + if len(petition_api_key) == 1: + petition_api_key = petition_api_key[0] + else: + key = petition_api_key[0] + for n, i in petition_api_key: + if n != 0: + key = key + "/" + i + petition_api_key = key + html = html + """ @@ -1423,19 +1477,19 @@ def EditorPage(server):
[icon link] - +
[icon checlist] - +
[icon scene] - +
[icon link] - +
@@ -1928,7 +1982,33 @@ def AccessDenied(server): send(server, html, 404) +def Error(server, text="Some Error Happened."): + config = Set.Load() + + html = head(title = "501 Error", + description = "501 Error", + config = config + ) + + html = html + Button(config.get("title", "My Website"), "/", image=config.get("favicon", "/icon/internet")) + + html = html + """ + +
+
+

501 Error

+ + """+text+""" + +

+
+ + """ + + send(server, html, 501) + + ### def Redirect(server, url, time=0): @@ -2475,8 +2555,28 @@ def Publish(server): petition["goal"] = int(petition_goal) except: petition["goal"] = 1 + + + # API petition + + if petition_api: + petition["api"] = { + "api" :petition_api, + "keys" :petition_api_key.split("/"), + "title":petition_api_title, + "link" :petition_api_link + } + + + metadata["petition"] = petition + - metadata["petition"] = petition + + else: + try: + del metadata["petition"] + except: + pass # Save the changes @@ -2494,7 +2594,16 @@ def Publish(server): save.write(text) else: save.write(Safe(text)) - + + if metadata.get("petition"): + metadata["url"] = "/"+tab+"/"+name + try: + API.Petition(metadata) + except Exception as e: + Error(server, "Cannot Load API Value
\n"+Safe(str(e))) + return + + Redirect(server, "/"+tab+"/"+name) @@ -2645,7 +2754,45 @@ def ReadNotification(server): except Exception as e: print(clr["bold"]+clr["tdrd"]+"Error:"+clr["norm"]+" Unable to read notification!", e) +def TimeDifference(timeA, timeB): + text = "" + + if timeA < timeB: + if timeB - timeA < 10: + text = "now" + return text + + elif timeB - timeA < 60: + text = str(int(timeB - timeA))+" seconds ago" + return text + + else: + if int( ( timeB - timeA ) / 60 ) == 1: + text = str(int( ( timeB - timeA ) / 60 ))+" minute ago" + else: + text = str(int( ( timeB - timeA ) / 60 ))+" minutes ago" + return text + + + else: + if timeA - timeA < 10: + text= "now" + return text + + elif timeA - timeB < 60: + text = "in "+str(int(timeA - timeB))+" seconds" + return text + + else: + if int( ( timeA - timeB ) / 60 ) == 1: + text = "in "+str(int( ( timeA - timeB ) / 60 ))+" minute" + else: + text = "in "+str(int( ( timeA - timeB ) / 60 ))+" minutes" + + return text + + def RSS(server): # Rendering rss feed.