Optimize
This commit is contained in:
parent
1a402b9a64
commit
def72534fb
|
@ -1,3 +1,5 @@
|
||||||
|
#!/home/naiji/mastodon/vndb-bot/venv/bin/python
|
||||||
|
|
||||||
import re
|
import re
|
||||||
import sys
|
import sys
|
||||||
import random
|
import random
|
||||||
|
@ -8,12 +10,13 @@ from bs4 import BeautifulSoup
|
||||||
from mastodon import Mastodon
|
from mastodon import Mastodon
|
||||||
|
|
||||||
URL_HEAD = 'https://vndb.org/v/rand'
|
URL_HEAD = 'https://vndb.org/v/rand'
|
||||||
FORBIDDEN_TAGS = [2023, 1640, 2600, 84, 156, 162, 897, 214, 391, 98, 2047, 1341, 83]
|
FORBIDDEN_TAGS = [2023, 156, 162, 897, 391, 98, 2047, 1341, 83]
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
#Logging into VNDB
|
#Logging into VNDB
|
||||||
vndb = v.VNDB('VNDBbot', '0.1', 'LOGIN', 'PASSWORD')
|
vndb = v.VNDB('VNDBbot', '0.1', 'LOGIN', 'PASSWORD')
|
||||||
id = -1
|
id = -1
|
||||||
|
safe = True
|
||||||
|
|
||||||
while True: # Searching for a good vn
|
while True: # Searching for a good vn
|
||||||
|
|
||||||
|
@ -43,7 +46,7 @@ def main():
|
||||||
popularity = vn_stats['popularity'] if vn_stats['popularity'] else -1
|
popularity = vn_stats['popularity'] if vn_stats['popularity'] else -1
|
||||||
rating = vn_stats['rating'] if vn_stats['rating'] else -1
|
rating = vn_stats['rating'] if vn_stats['rating'] else -1
|
||||||
votecount = vn_stats['votecount'] if vn_stats['votecount'] else -1
|
votecount = vn_stats['votecount'] if vn_stats['votecount'] else -1
|
||||||
if votecount < 10 or rating < 5 or popularity < 2:
|
if votecount < 10 or rating < 5 or popularity < 0.8:
|
||||||
continue
|
continue
|
||||||
|
|
||||||
# getting details of the VN
|
# getting details of the VN
|
||||||
|
@ -51,25 +54,23 @@ def main():
|
||||||
vn_details = vndb_result['items'][0]
|
vn_details = vndb_result['items'][0]
|
||||||
|
|
||||||
# even slightly suggestive or slightly violent go to Sensitive, so we skip it
|
# even slightly suggestive or slightly violent go to Sensitive, so we skip it
|
||||||
if (vn_details['image_flagging']['sexual_avg'] != 0) or (vn_details['image_flagging']['violence_avg'] != 0):
|
if (vn_details['image_flagging']['sexual_avg'] > 1) or (vn_details['image_flagging']['violence_avg'] > 1):
|
||||||
continue
|
safe = False
|
||||||
|
|
||||||
# getting basic information of the VN
|
# getting basic information of the VN
|
||||||
vndb_result = vndb.get('vn', 'basic', '(id=' + str(id) + ')', '')
|
vndb_result = vndb.get('vn', 'basic', '(id=' + str(id) + ')', '')
|
||||||
vn_basic = vndb_result['items'][0]
|
vn_basic = vndb_result['items'][0]
|
||||||
|
|
||||||
title = vn_basic['title'] if vn_basic['title'] else ''
|
title = vn_basic['title'] if vn_basic['title'] else ''
|
||||||
raw_description = vn_details['description'] if vn_details['description'] else ''
|
description = vn_details['description'] if vn_details['description'] else ''
|
||||||
released = vn_basic['released'] if vn_basic['released'] else 'unknown'
|
released = vn_basic['released'] if vn_basic['released'] else 'unknown'
|
||||||
link = 'https://vndb.org/v' + str(id)
|
link = 'https://vndb.org/v' + str(id)
|
||||||
|
|
||||||
# processing description and removing markdown
|
|
||||||
description = re.sub('^\[.rom.*\[\/url\]\].*', '', raw_description)
|
|
||||||
|
|
||||||
# logging in and posting
|
# logging in and posting
|
||||||
mastodon = Mastodon(
|
mastodon = Mastodon(
|
||||||
access_token = 'token.dat',
|
access_token = 'token.dat',
|
||||||
api_base_url = 'https://udongein.xyz/'
|
api_base_url = 'https://udongein.xyz/',
|
||||||
|
feature_set = 'pleroma'
|
||||||
)
|
)
|
||||||
|
|
||||||
text = title + '\n- - - - - - - -\n\n' + description + '\n\nReleased: ' + released + '\nPopularity: ' + (str(popularity) if popularity > -1 else 'unknown') + '\nRating:' + str(rating) + '\n\n' + link
|
text = title + '\n- - - - - - - -\n\n' + description + '\n\nReleased: ' + released + '\nPopularity: ' + (str(popularity) if popularity > -1 else 'unknown') + '\nRating:' + str(rating) + '\n\n' + link
|
||||||
|
@ -78,12 +79,16 @@ def main():
|
||||||
vndb_result = vndb.get('vn', 'screens', '(id=' + str(id) + ')', '')
|
vndb_result = vndb.get('vn', 'screens', '(id=' + str(id) + ')', '')
|
||||||
vn_screens = vndb_result['items'][0]['screens']
|
vn_screens = vndb_result['items'][0]['screens']
|
||||||
screens = [ ]
|
screens = [ ]
|
||||||
|
counter = 0
|
||||||
screens.append(mastodon.media_post(requests.get(vn_details['image']).content, 'image/jpeg'))
|
screens.append(mastodon.media_post(requests.get(vn_details['image']).content, 'image/jpeg'))
|
||||||
for screen in vn_screens:
|
for screen in vn_screens:
|
||||||
if screen['flagging']['sexual_avg'] == 0 and screen['flagging']['violence_avg'] == 0:
|
if screen['flagging']['sexual_avg'] == 0 and screen['flagging']['violence_avg'] == 0:
|
||||||
screens.append(mastodon.media_post(requests.get(screen['image']).content, 'image/jpeg'))
|
screens.append(mastodon.media_post(requests.get(screen['image']).content, 'image/jpeg'))
|
||||||
|
counter += 1
|
||||||
|
if counter == 3:
|
||||||
|
break
|
||||||
|
|
||||||
mastodon.status_post(text, media_ids=screens, visibility='unlisted', sensitive=False)
|
mastodon.status_post(text, media_ids=screens, visibility='unlisted', sensitive=not safe, content_type='text/bbcode')
|
||||||
break
|
break
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
Loading…
Reference in New Issue