__main__.py 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. """Main app"""
  2. from datetime import datetime, timedelta
  3. import random
  4. import time
  5. # libraries and data
  6. import matplotlib.pyplot as plt
  7. import matplotlib.dates as mdates
  8. import numpy as np
  9. import pandas as pd
  10. from pandas.plotting import register_matplotlib_converters
  11. from telegram import ParseMode
  12. from app import SCHEDULER, LOGGER, TELEGRAM_BOT
  13. from app.api import download_resources, refill
  14. from app.database import save_resources, get_resources, get_work_percentage
  15. from app.app import need_refill, max_refill_seconds, print_resources
  16. register_matplotlib_converters()
  17. def job_check_resources(state_id, capital_id, resource_id, do_refill):
  18. """Check resources and refill if necessary"""
  19. regions = download_resources(state_id, resource_id)
  20. print_resources(regions)
  21. save_resources(state_id, regions, resource_id)
  22. if do_refill and need_refill(regions, 25):
  23. max_seconds = max_refill_seconds(regions, 25, 900)
  24. random_seconds = random.randint(0, max_seconds)
  25. random_time_delta = timedelta(seconds=random_seconds)
  26. scheduled_date = datetime.now() + random_time_delta
  27. job_id = 'refill_{}_{}'.format(capital_id, resource_id)
  28. LOGGER.info(
  29. 'Refil resource %s at %s (%s minutes)',
  30. resource_id,
  31. scheduled_date,
  32. round(random_time_delta.seconds / 60)
  33. )
  34. job = SCHEDULER.get_job(job_id)
  35. if not job:
  36. SCHEDULER.add_job(
  37. job_refill_resource,
  38. 'date',
  39. args=[state_id, capital_id, resource_id],
  40. id=job_id,
  41. run_date=scheduled_date
  42. )
  43. def job_refill_resource(state_id, capital_id, resource_id):
  44. """Execute refill job"""
  45. refill(state_id, capital_id, resource_id)
  46. def add_check_resources(state_id, capital_id, resource_id, do_refill, minute):
  47. """Add check resources job"""
  48. SCHEDULER.add_job(
  49. job_check_resources,
  50. 'cron',
  51. args=[state_id, capital_id, resource_id, do_refill],
  52. id='{}_check_{}'.format(state_id, resource_id),
  53. replace_existing=True,
  54. minute=minute
  55. )
  56. def job_send_telegram_update(state_id, group_id, resource_type):
  57. """Send telegram update"""
  58. data = get_work_percentage(state_id, resource_type, datetime.utcnow(), 1, 3)
  59. print(data)
  60. exit()
  61. TELEGRAM_BOT.sendMessage(
  62. chat_id=group_id,
  63. text='*test*',
  64. parse_mode=ParseMode.MARKDOWN
  65. )
  66. def graph():
  67. """make graph"""
  68. date = datetime.now()# - timedelta(1)
  69. region_4001 = get_resources(4001, date, 0)
  70. region_4002 = get_resources(4002, date, 0)
  71. region_4003 = get_resources(4003, date, 0)
  72. region_4004 = get_resources(4004, date, 0)
  73. region_4008 = get_resources(4008, date, 0)
  74. # resource_tmp = np.random.randn(2499)+range(2500, 1, -1)
  75. # Make a data frame
  76. data_frame = pd.DataFrame({
  77. # 'x': range(1, 2500),
  78. # '4001': resource_tmp,
  79. 'x': list(region_4001.keys()),
  80. 'Northern Netherlands': list(region_4001.values()),
  81. 'Eastern Netherlands': list(region_4002.values()),
  82. 'Western Netherlands': list(region_4003.values()),
  83. 'Southern Netherlands': list(region_4004.values()),
  84. 'Amsterdam': list(region_4008.values()),
  85. })
  86. major_fmt = mdates.DateFormatter('%m-%d %H:%M')
  87. fig, ax = plt.subplots()
  88. ax.xaxis.set_major_formatter(major_fmt)
  89. fig.autofmt_xdate()
  90. end_date_time = date.replace(hour=20, minute=0, second=0, microsecond=0)
  91. start_date_time = end_date_time - timedelta(hours=26)
  92. ax.set_xlim([start_date_time, end_date_time])
  93. ax.set_ylim([0, 2500])
  94. # style
  95. plt.style.use('seaborn-darkgrid')
  96. # create a color palette
  97. palette = plt.get_cmap('Set1')
  98. # multiple line plot
  99. num = 0
  100. for column in data_frame.drop('x', axis=1):
  101. num += 1
  102. plt.plot(
  103. data_frame['x'],
  104. data_frame[column],
  105. marker='',
  106. color=palette(num),
  107. linewidth=1,
  108. alpha=0.9,
  109. label=column
  110. )
  111. # Add legend
  112. plt.legend(loc=3, ncol=1)
  113. # plt.setp(plt.xticks()[1], rotation=30, ha='right')
  114. # Add titles
  115. plt.title(
  116. 'Resource limit left | {}'.format(date.strftime('%Y-%m-%d')),
  117. loc='left',
  118. fontsize=12,
  119. fontweight=1
  120. )
  121. plt.xlabel("Time")
  122. plt.ylabel("Resources")
  123. plt.savefig('foo.png')
  124. if __name__ == '__main__':
  125. # job_refill_resource(2788, 4002, 0)
  126. # job_check_resources(2788, 4002, 0, False) # VN
  127. # job_check_resources(2620, 4002, 0, False) # Zeelandiae
  128. # graph()
  129. job_send_telegram_update(2788, '@vn_resources', 0)
  130. # get_resources(4001, datetime.now(), 0)
  131. exit()
  132. # VN
  133. # add_check_resources(2788, 4008, 0, True, '0,15,30,45')
  134. # add_check_resources(2788, 4008, 11, True, '0')
  135. # Zeelandiae
  136. # add_check_resources(2620, 0, 0, False, '50')
  137. # Belgium
  138. # add_check_resources(2604, 0, 0, False, '40')
  139. try:
  140. while True:
  141. time.sleep(100)
  142. except KeyboardInterrupt:
  143. LOGGER.info('Exiting application')
  144. SCHEDULER.shutdown()
  145. exit