__main__.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  1. import os
  2. import sys
  3. from importlib.util import find_spec
  4. from configparser import ConfigParser
  5. import threading
  6. import json
  7. import time
  8. import schedule
  9. import requests
  10. from flask import Flask, g, redirect, url_for, render_template, jsonify, request, send_from_directory
  11. from flask_cors import CORS
  12. from .web import api
  13. from . import content_system as h_cs
  14. from . import item_collections, view_model as h_vm
  15. from .item_collections import item_collections_bp
  16. from . import schedule_system as h_sched
  17. theme_bootstrap5_enabled = False
  18. if find_spec('theme_bootstrap5'):
  19. from theme_bootstrap5 import hogumathi_theme_bootstrap5_bp
  20. theme_bootstrap5_enabled = True
  21. if find_spec('twitter_v2_facade'):
  22. import twitter_v2_facade
  23. from twitter_v2_facade import twitter_app as twitter_v2
  24. from twitter_v2_facade import oauth2_login
  25. twitter_enabled = True
  26. else:
  27. print('twitter module not found.')
  28. twitter_enabled = False
  29. if find_spec('twitter_v2_live_facade'):
  30. import twitter_v2_live_facade
  31. from twitter_v2_live_facade import twitter_app as twitter_v2_live
  32. import brands
  33. from brands import brands_bp
  34. twitter_live_enabled = True
  35. else:
  36. print('twitter live module not found.')
  37. twitter_live_enabled = False
  38. if find_spec('twitter_archive_facade'):
  39. import twitter_archive_facade
  40. from twitter_archive_facade import twitter_app as twitter_archive
  41. archive_enabled = True
  42. else:
  43. print('twitter archive module not found.')
  44. archive_enabled = False
  45. if find_spec('mastodon_facade'):
  46. from mastodon_facade import twitter_app as mastodon
  47. mastodon_enabled = True
  48. else:
  49. print('mastodon module not found.')
  50. mastodon_enabled = False
  51. if find_spec('feeds_facade'):
  52. import feeds_facade
  53. from feeds_facade import twitter_app as feeds
  54. feeds_enabled = True
  55. else:
  56. print('feeds module not found.')
  57. feeds_enabled = False
  58. if find_spec('youtube_v3_facade'):
  59. import youtube_v3_facade
  60. from youtube_v3_facade import youtube_app as youtube
  61. youtube_enabled = True
  62. else:
  63. print('youtube module not found.')
  64. youtube_enabled = False
  65. if find_spec('messages_facade'):
  66. from messages_facade import messages_facade as messages
  67. messages_enabled = True
  68. else:
  69. print('messages module not found.')
  70. messages_enabled = False
  71. if find_spec('instagram_embed_facade'):
  72. import instagram_embed_facade
  73. instagram_embed_enabled = True
  74. else:
  75. print('instagram_embed module not found.')
  76. instagram_embed_enabled = False
  77. if find_spec('instagram_facade'):
  78. import instagram_facade
  79. instagram_enabled = True
  80. else:
  81. print('instagram module not found.')
  82. instagram_enabled = False
  83. if find_spec('git_facade'):
  84. import git_facade
  85. git_enabled = True
  86. else:
  87. print('git module not found.')
  88. git_enabled = False
  89. if find_spec('bitchute_facade'):
  90. import bitchute_facade
  91. bitchute_enabled = True
  92. else:
  93. print('bitchute module not found.')
  94. bitchute_enabled = False
  95. if find_spec('videojs'):
  96. from videojs import videojs_bp
  97. videojs_enabled = True
  98. else:
  99. print('videojs module not found.')
  100. videojs_enabled = False
  101. if find_spec('visjs'):
  102. from visjs import visjs_bp
  103. visjs_enabled = True
  104. else:
  105. print('messages module not found.')
  106. visjs_enabled = False
  107. """
  108. By default we use embed because it's less likely to get banned, because it does not
  109. use scraping. Once we've used scraping for a while and not been banned we can switch to that.
  110. Biz note: scraping could also be an early access feature.
  111. """
  112. print('disabling instagram_facade to avoid scraping... enable at your own risk')
  113. instagram_enabled = False
  114. #messages_enabled = False
  115. #twitter_live_enabled = True
  116. add_account_enabled = True
  117. def record_content_analytics (content_id, content):
  118. if type(content) == h_vm.CollectionPage:
  119. prefix = None
  120. if content_id.startswith('twitter:feed:user:') or content_id.startswith('twitter:bookmarks:') or content_id.startswith('twitter:feed:reverse_chronological:user:'):
  121. prefix = 'twitter:tweet:'
  122. if not prefix:
  123. return;
  124. for item in content.items:
  125. h_cs.invoke_hooks('got_content', f'{prefix}{item.id}', item)
  126. elif type(content) == h_vm.FeedItem:
  127. print(f'record_content_analytics: feed item: {content_id}')
  128. elif type(content) == h_vm.FeedServiceUser:
  129. print(f'record_content_analytics: user: {content_id}')
  130. else:
  131. print(f'record_content_analytics: unknown type: {content_id}')
  132. if __name__ == '__main__':
  133. glitch_enabled = os.environ.get('PROJECT_DOMAIN') and True
  134. t = os.environ.get('BEARER_TOKEN')
  135. PORT = int(os.environ.get('PORT', 5000))
  136. HOST = os.environ.get('HOST', '127.0.0.1')
  137. archive_enabled = os.environ.get('ARCHIVE_TWEETS_PATH') and True
  138. notes_app_url = os.environ.get('NOTES_APP_URL')
  139. bedrss_app_url = os.environ.get('NOTES_APP_URL')
  140. plots_app_url = os.environ.get('PLOTS_APP_URL')
  141. videos_app_url = os.environ.get('VIDEOS_APP_URL')
  142. messages_app_url = os.environ.get('MESSAGES_APP_URL')
  143. if not os.path.exists('.data'):
  144. os.mkdir('.data')
  145. if not os.path.exists('.data/cache'):
  146. os.mkdir('.data/cache')
  147. # HACK - environ from .env isn't set yet when the import happens. We should call an init function somewhere.
  148. oauth2_login.app_access_token = os.environ.get("BEARER_TOKEN")
  149. oauth2_login.app_consumer_key = os.environ.get("TWITTER_CONSUMER_KEY")
  150. oauth2_login.app_secret_key = os.environ.get("TWITTER_CONSUMER_SECRET")
  151. h_cs.register_hook('got_content', record_content_analytics)
  152. @api.before_request
  153. def add_config ():
  154. g.twitter_enabled = twitter_enabled
  155. g.archive_enabled = archive_enabled
  156. g.mastodon_enabled = mastodon_enabled
  157. g.feeds_enabled = feeds_enabled
  158. g.youtube_enabled = youtube_enabled
  159. g.messages_enabled = messages_enabled
  160. g.twitter_live_enabled = twitter_live_enabled
  161. g.add_account_enabled = add_account_enabled
  162. g.glitch_enabled = glitch_enabled
  163. g.videojs_enabled = videojs_enabled
  164. g.visjs_enabled = visjs_enabled
  165. if glitch_enabled:
  166. g.app_url = 'https://{}.glitch.me'.format( os.environ.get('PROJECT_DOMAIN') )
  167. else:
  168. g.app_url = 'http://{}:{}'.format('localhost', PORT)
  169. if notes_app_url:
  170. g.notes_app_url = notes_app_url
  171. if bedrss_app_url:
  172. g.bedrss_app_url = bedrss_app_url
  173. if plots_app_url:
  174. g.plots_app_url = plots_app_url
  175. if videos_app_url:
  176. g.videos_app_url = videos_app_url
  177. if messages_app_url:
  178. g.messages_app_url = messages_app_url
  179. if theme_bootstrap5_enabled:
  180. g.theme_bootstrap5_enabled = theme_bootstrap5_enabled
  181. @api.context_processor
  182. def inject_config ():
  183. config = {}
  184. config['twitter_enabled'] = twitter_enabled
  185. config['archive_enabled'] = archive_enabled
  186. config['mastodon_enabled'] = mastodon_enabled
  187. config['feeds_enabled'] = feeds_enabled
  188. config['youtube_enabled'] = youtube_enabled
  189. config['messages_enabled'] = messages_enabled
  190. config['twitter_live_enabled'] = twitter_live_enabled
  191. config['add_account_enabled'] = add_account_enabled
  192. config['glitch_enabled'] = glitch_enabled
  193. config['videojs_enabled'] = videojs_enabled
  194. config['visjs_enabled'] = visjs_enabled
  195. config['theme_bootstrap5_enabled'] = theme_bootstrap5_enabled
  196. if notes_app_url:
  197. config['notes_app_url'] = notes_app_url
  198. if bedrss_app_url:
  199. config['bedrss_app_url'] = bedrss_app_url
  200. if plots_app_url:
  201. config['plots_app_url'] = plots_app_url
  202. if videos_app_url:
  203. config['videos_app_url'] = videos_app_url
  204. if messages_app_url:
  205. config['messages_app_url'] = messages_app_url
  206. return config
  207. api.secret_key = os.environ.get('FLASK_SECRET')
  208. api.config['TEMPLATES_AUTO_RELOAD'] = True
  209. # the new way
  210. #api.config['notes_app_url'] = notes_app_url
  211. if theme_bootstrap5_enabled:
  212. api.register_blueprint(hogumathi_theme_bootstrap5_bp)
  213. if videojs_enabled:
  214. api.register_blueprint(videojs_bp, url_prefix='/lib/videojs')
  215. if visjs_enabled:
  216. api.register_blueprint(visjs_bp, url_prefix='/lib/visjs')
  217. twitter_v2_facade.register_content_sources()
  218. api.register_blueprint(twitter_v2, url_prefix='/twitter')
  219. if archive_enabled:
  220. twitter_archive_facade.register_content_sources()
  221. api.register_blueprint(twitter_archive, url_prefix='/twitter-archive')
  222. if mastodon_enabled:
  223. api.register_blueprint(mastodon, url_prefix='/mastodon')
  224. if youtube_enabled:
  225. youtube_v3_facade.register_content_sources()
  226. api.register_blueprint(youtube, url_prefix='/youtube')
  227. if messages_enabled:
  228. api.register_blueprint(messages, url_prefix='/messages')
  229. item_collections.register_content_sources()
  230. api.register_blueprint(item_collections_bp, url_prefix='/collections')
  231. if twitter_live_enabled:
  232. twitter_v2_live_facade.register_content_sources()
  233. api.register_blueprint(twitter_v2_live, url_prefix='/twitter-live')
  234. brands.register_content_sources()
  235. api.register_blueprint(brands_bp, url_prefix='/')
  236. if instagram_enabled:
  237. instagram_facade.register_content_sources()
  238. if instagram_embed_enabled:
  239. instagram_embed_facade.register_content_sources()
  240. if feeds_enabled:
  241. if not os.path.exists('.data/cache/feeds'):
  242. os.mkdir('.data/cache/feeds')
  243. feeds_facade.register_content_sources()
  244. api.register_blueprint(feeds, url_prefix='/feeds')
  245. if git_enabled:
  246. git_facade.register_content_sources()
  247. if bitchute_enabled:
  248. bitchute_facade.register_content_sources()
  249. #CORS(api)
  250. sched_app = h_sched.ScheduleApplication()
  251. print(f'created schedule app: {sched_app}')
  252. running = True
  253. def schedule_main():
  254. print(f'running schedule app: {sched_app}')
  255. while running:
  256. sched_app.run_pending()
  257. time.sleep(1)
  258. def say_something ():
  259. print ('-- something')
  260. sched_app.schedule_job(schedule.every(61).seconds, say_something)
  261. schedule_thread = threading.Thread(target=schedule_main)
  262. schedule_thread.start()
  263. api.run(port=PORT, host=HOST)
  264. running = False
  265. schedule_thread.join()