mirror of
https://github.com/developersIndia/deviras.git
synced 2024-11-13 00:36:09 +05:30
save/load data from gist
This commit is contained in:
parent
df213fb36a
commit
c8c1cdd81f
@ -2,20 +2,63 @@ import praw
|
|||||||
import os
|
import os
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
import json
|
import json
|
||||||
|
import requests
|
||||||
|
|
||||||
client_id = os.environ["REDDIT_CLIENT_ID"]
|
client_id = os.environ["REDDIT_CLIENT_ID"]
|
||||||
client_secret = os.environ["REDDIT_CLIENT_SECRET"]
|
client_secret = os.environ["REDDIT_CLIENT_SECRET"]
|
||||||
reddit_pass = os.environ["REDDIT_PASSWORD"]
|
reddit_pass = os.environ["REDDIT_PASSWORD"]
|
||||||
username = os.environ["REDDIT_USERNAME"]
|
username = os.environ["REDDIT_USERNAME"]
|
||||||
|
token = os.environ["GITHUB_TOKEN"]
|
||||||
|
gist_id = os.environ["GIST_ID"]
|
||||||
|
sub = "developersIndia"
|
||||||
|
|
||||||
|
|
||||||
|
def get_gist_content(gist_id):
|
||||||
|
token = os.environ["GITHUB_TOKEN"]
|
||||||
|
headers = {
|
||||||
|
"Authorization": f"token {token}",
|
||||||
|
"Accept": "application/vnd.github.v3+json",
|
||||||
|
}
|
||||||
|
response = requests.get(f"https://api.github.com/gists/{gist_id}", headers=headers)
|
||||||
|
gist = response.json()
|
||||||
|
filename = list(gist["files"].keys())[0]
|
||||||
|
return gist["files"][filename]["content"]
|
||||||
|
|
||||||
|
|
||||||
|
def update_gist(gist_id, filename, content, description=""):
|
||||||
|
token = os.environ["GITHUB_TOKEN"]
|
||||||
|
headers = {
|
||||||
|
"Authorization": f"token {token}",
|
||||||
|
"Accept": "application/vnd.github.v3+json",
|
||||||
|
}
|
||||||
|
data = {"description": description, "files": {filename: {"content": content}}}
|
||||||
|
response = requests.patch(
|
||||||
|
f"https://api.github.com/gists/{gist_id}", headers=headers, json=data
|
||||||
|
)
|
||||||
|
return response.json()
|
||||||
|
|
||||||
|
|
||||||
def get_collection(reddit):
|
def get_collection(reddit):
|
||||||
collection = reddit.subreddit("developersIndia").collections(
|
collection = reddit.subreddit(sub).collections(
|
||||||
permalink="https://reddit.com/r/developersIndia/collection/958aef35-f9cb-414d-ab33-08bc639e47de"
|
permalink="https://reddit.com/r/developersIndia/collection/958aef35-f9cb-414d-ab33-08bc639e47de"
|
||||||
)
|
)
|
||||||
return collection
|
return collection
|
||||||
|
|
||||||
|
|
||||||
|
def update_wiki(reddit, wikipage, posts):
|
||||||
|
wiki_header = """# A collection of good discussions started by community members"""
|
||||||
|
content = wiki_header + "\n\n"
|
||||||
|
# given a wiki link, update the wiki page with new markdown
|
||||||
|
wikipage = reddit.subreddit(sub).wiki[wikipage]
|
||||||
|
|
||||||
|
for post in posts:
|
||||||
|
formatted_date = datetime.strptime(post['created_at'], '%Y-%m-%dT%H:%M:%S').strftime('%d-%m-%Y')
|
||||||
|
content += f"- `{formatted_date}` [{post['title']}]({post['url']})\n\n"
|
||||||
|
|
||||||
|
wikipage.edit(content=content)
|
||||||
|
print("Wiki updated successfully!")
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
reddit = praw.Reddit(
|
reddit = praw.Reddit(
|
||||||
client_id=client_id,
|
client_id=client_id,
|
||||||
@ -27,31 +70,76 @@ def main():
|
|||||||
|
|
||||||
collection = get_collection(reddit)
|
collection = get_collection(reddit)
|
||||||
|
|
||||||
print(f"Last updated: {datetime.utcfromtimestamp(collection.last_update_utc)}")
|
saved_collection_posts = json.loads(get_gist_content(gist_id))
|
||||||
|
saved_collection_ids = [post["id"] for post in saved_collection_posts["posts"]]
|
||||||
|
|
||||||
posts = []
|
print(f"Database was last updated on {saved_collection_posts['collection_last_updated']}")
|
||||||
|
print(f"Collection was last updated on {datetime.utcfromtimestamp(collection.last_update_utc).isoformat()}")
|
||||||
|
|
||||||
for submission_id in collection.sorted_links:
|
if (
|
||||||
submission = reddit.submission(submission_id)
|
saved_collection_posts["collection_last_updated"]
|
||||||
post = {
|
!= datetime.utcfromtimestamp(collection.last_update_utc).isoformat()
|
||||||
"title": submission.title,
|
):
|
||||||
"url": submission.url,
|
print("Collection was updated, getting new posts data...")
|
||||||
"id": submission.id,
|
|
||||||
"num_comments": submission.num_comments,
|
# given 2 lists find non-common elements
|
||||||
"created_at": datetime.utcfromtimestamp(submission.created_utc).isoformat(),
|
db_posts = set(saved_collection_ids)
|
||||||
"flair_text": submission.link_flair_text,
|
collection_posts = []
|
||||||
|
for submission in collection:
|
||||||
|
collection_posts.append(submission.id)
|
||||||
|
collection_posts = set(collection_posts)
|
||||||
|
|
||||||
|
new_posts = list(collection_posts - db_posts)
|
||||||
|
deleted_posts = list(db_posts - collection_posts)
|
||||||
|
|
||||||
|
print(f"Found {len(new_posts)} new posts!")
|
||||||
|
print(f"Found {len(deleted_posts)} deleted posts!")
|
||||||
|
|
||||||
|
posts = []
|
||||||
|
# load the saved collection posts data
|
||||||
|
for submission_id in saved_collection_posts["posts"]:
|
||||||
|
if submission_id["id"] in deleted_posts:
|
||||||
|
continue
|
||||||
|
post = {
|
||||||
|
"title": submission_id["title"],
|
||||||
|
"url": submission_id["url"],
|
||||||
|
"id": submission_id["id"],
|
||||||
|
"num_comments": submission_id["num_comments"],
|
||||||
|
"created_at": submission_id["created_at"],
|
||||||
|
"flair_text": submission_id["flair_text"],
|
||||||
|
}
|
||||||
|
posts.append(post)
|
||||||
|
|
||||||
|
# get the new posts data
|
||||||
|
for submission_id in new_posts:
|
||||||
|
submission = reddit.submission(submission_id)
|
||||||
|
post = {
|
||||||
|
"title": submission.title,
|
||||||
|
"url": submission.url,
|
||||||
|
"id": submission.id,
|
||||||
|
"num_comments": submission.num_comments,
|
||||||
|
"created_at": datetime.utcfromtimestamp(
|
||||||
|
submission.created_utc
|
||||||
|
).isoformat(),
|
||||||
|
"flair_text": submission.link_flair_text,
|
||||||
|
}
|
||||||
|
posts.append(post)
|
||||||
|
|
||||||
|
# sort the posts by created_at
|
||||||
|
posts = sorted(posts, key=lambda k: k["created_at"])
|
||||||
|
|
||||||
|
collection_json = {
|
||||||
|
"collection_last_updated": datetime.utcfromtimestamp(
|
||||||
|
collection.last_update_utc
|
||||||
|
).isoformat(),
|
||||||
|
"posts": posts,
|
||||||
}
|
}
|
||||||
posts.append(post)
|
|
||||||
|
|
||||||
collection_json = {
|
update_gist(gist_id, "collection.json", json.dumps(collection_json, indent=4))
|
||||||
"collection_last_updated": datetime.utcfromtimestamp(
|
print("Internal database updated successfully!")
|
||||||
collection.last_update_utc
|
update_wiki(reddit, "community-threads", posts)
|
||||||
).isoformat(),
|
else:
|
||||||
"posts": posts,
|
print("Collection Saved data is up to date!")
|
||||||
}
|
|
||||||
|
|
||||||
with open("collection.json", "w") as f:
|
|
||||||
json.dump(collection_json, f, indent=4)
|
|
||||||
|
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
|
Loading…
Reference in New Issue
Block a user