mirror of
https://github.com/norohind/EDMC-FCTracker.git
synced 2025-06-19 23:53:50 +03:00
Upload 0.0.4
This commit is contained in:
parent
78c17c20e8
commit
23d5ec14e6
162
load.py
162
load.py
@ -1,12 +1,19 @@
|
|||||||
import logging, plug
|
# -*- coding: utf-8 -*-
|
||||||
import os, requests, threading, json, time
|
import os, requests, threading, json, logging
|
||||||
from config import appname
|
from config import appname
|
||||||
|
|
||||||
|
'''
|
||||||
#GPLv3, wrote by a31 aka norohind aka CMDR Aleksey31
|
#GPLv3, wrote by a31 aka norohind aka CMDR Aleksey31
|
||||||
|
Patch note:
|
||||||
|
Add support for carrier name change event
|
||||||
|
Add possibility to disable sending any type of events (checkout class Plugin_settings from 35 line)
|
||||||
|
Add support for beta
|
||||||
|
Change way to build message for discord
|
||||||
|
Add body to jump message if we have it
|
||||||
|
'''
|
||||||
|
|
||||||
|
VERSION="0.0.4"
|
||||||
VERSION="0.0.3"
|
force_beta=False
|
||||||
|
|
||||||
'''
|
'''
|
||||||
for use you must set an url
|
for use you must set an url
|
||||||
url can be str or list of strs
|
url can be str or list of strs
|
||||||
@ -21,38 +28,41 @@ url = ["https://discord.com/api/webhooks/1", "https://discord.com/api/webhooks/2
|
|||||||
'''
|
'''
|
||||||
url="" #set your url(s)
|
url="" #set your url(s)
|
||||||
|
|
||||||
|
|
||||||
plugin_name = os.path.basename(os.path.dirname(__file__))
|
plugin_name = os.path.basename(os.path.dirname(__file__))
|
||||||
logger = logging.getLogger(f'{appname}.{plugin_name}')
|
logger = logging.getLogger(f'{appname}.{plugin_name}')
|
||||||
|
|
||||||
class Carrier():
|
#some settings
|
||||||
def __init__(self):
|
class Plugin_settings():
|
||||||
self.name = None
|
SEND_IN_BETA = False #do send messages when play in beta?
|
||||||
self.current_location = None
|
SEND_JUMP_REQUESTS = True
|
||||||
self.cID = None #CarrierID (aka MarketID)
|
SEND_JUMPS = True
|
||||||
self.docking_permission = None
|
SEND_JUMP_CANCELING = True
|
||||||
self.allow_notorius = None
|
SEND_CHANGES_DOCKING_PERMISSIONS = True
|
||||||
|
SEND_CHANGES_NAME = True
|
||||||
|
|
||||||
class Messages():
|
class Messages():
|
||||||
|
|
||||||
#take color in HEX and turn it into decimal
|
#take color in HEX and turn it into decimal
|
||||||
JUMP_REQUEST_COLOR="1127128"
|
COLOR_JUMP_REQUEST = "1127128"
|
||||||
JUMP_CANCELLED_COLOR="14177041"
|
COLOR_JUMP_CANCELLED = "14177041"
|
||||||
JUMP_COLOR="130816"
|
COLOR_JUMP = "130816"
|
||||||
PERMISSION_CHANGE_COLOR="5261068"
|
COLOR_PERMISSION_CHANGE = "5261068"
|
||||||
|
COLOR_CHANGE_NAME = "9355388"
|
||||||
EMBEDS_TEMPLATE = '{"embeds":[{"title": null,"color": null,"description": null}]}'
|
|
||||||
|
|
||||||
TITLE_JUMP_REQUEST = "Запланирован прыжок"
|
TITLE_JUMP_REQUEST = "Запланирован прыжок"
|
||||||
TITLE_JUMP_COMPLETE = "Прыжок совершён"
|
TITLE_JUMP = "Прыжок совершён"
|
||||||
TITLE_JUMP_CANCELLED = "Прыжок отменён"
|
TITLE_JUMP_CANCELLED = "Прыжок отменён"
|
||||||
TITLE_CHANGE_DOCKING_PERMISSION = "Изменение разрешения на стыковку"
|
TITLE_CHANGE_DOCKING_PERMISSION = "Изменение разрешения на стыковку"
|
||||||
|
TITLE_IN_BETA= "Бета версия игры"
|
||||||
|
TITLE_CHANGE_NAME = "Изменение имени носителя"
|
||||||
|
|
||||||
TEXT_JUMP_REQUEST_BODY_DIFF = " к телу {body}"
|
TEXT_JUMP_REQUEST_BODY_DIFF = " к телу {body}"
|
||||||
TEXT_JUMP_REQUEST = "Запланирован прыжок носителя {name} в систему {system}"
|
TEXT_JUMP_REQUEST = "Запланирован прыжок носителя {name} в систему {system}"
|
||||||
TEXT_JUMP_COMPLETE = "Носитель {name} совершил прыжок в систему {system}"
|
TEXT_JUMP = "Носитель {name} совершил прыжок в систему {system}"
|
||||||
TEXT_JUMP_CANCELLED = "Прыжок носителя {name} отменён"
|
TEXT_JUMP_CANCELLED = "Прыжок носителя {name} отменён"
|
||||||
TEXT_PERMISSION_CHANGE = "Носитель {name} сменил разрешение на стыковку с {old_permission} на {new_permission}\nСтыковка для преступников была {old_doc_for_crime}, сейчас {new_doc_for_crime}"
|
TEXT_PERMISSION_CHANGE = "Носитель {name} сменил разрешение на стыковку с {old_permission} на {new_permission}\nСтыковка для преступников была {old_doc_for_crime}, сейчас {new_doc_for_crime}"
|
||||||
|
TEXT_IN_BETA = "Внимание, данное сообщение относится только к бета версии игры!"
|
||||||
|
TEXT_CHANGE_NAME = "Имя носителя изменилось с {old_name} на {new_name}"
|
||||||
|
|
||||||
DOC_PERMISSION_ALL = "Для всех"
|
DOC_PERMISSION_ALL = "Для всех"
|
||||||
DOC_PERMISSION_NONE = "Никто"
|
DOC_PERMISSION_NONE = "Никто"
|
||||||
@ -62,7 +72,40 @@ class Messages():
|
|||||||
DOC_PERMISSION_ALLOW_NOTORIUS = "Разрешена"
|
DOC_PERMISSION_ALLOW_NOTORIUS = "Разрешена"
|
||||||
DOC_PERMISSION_DISALLOW_NOTORIUS = "Запрещена"
|
DOC_PERMISSION_DISALLOW_NOTORIUS = "Запрещена"
|
||||||
|
|
||||||
|
class Carrier():
|
||||||
|
def __init__(self):
|
||||||
|
self.name = None
|
||||||
|
self.current_location = None
|
||||||
|
self.cID = None #CarrierID (aka MarketID)
|
||||||
|
self.docking_permission = None
|
||||||
|
self.allow_notorius = None
|
||||||
|
|
||||||
|
class embed():
|
||||||
|
"""Building completed and ready for send embed message for discord. Requeries json lib"""
|
||||||
|
def __init__(self, **kwargs): # color, title, description, postponed
|
||||||
|
self.items = list()
|
||||||
|
if len(kwargs) == 0: #we can create new object without creating an item of list, just do not pass anything to constructor
|
||||||
|
return
|
||||||
|
self.add_item(**kwargs)
|
||||||
|
|
||||||
|
def add_item(self, **kwargs):
|
||||||
|
color = str(kwargs.get('color'))
|
||||||
|
title = str(kwargs.get('title'))
|
||||||
|
description = str(kwargs.get('description'))
|
||||||
|
self.items.append(dict(title=title, color=color, description=description))
|
||||||
|
|
||||||
|
def get_message(self):
|
||||||
|
return json.dumps(dict(embeds=self.items))
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return str(self.get_message())
|
||||||
|
|
||||||
|
def update_item(self, item, key, new_value): #item number, key, new value
|
||||||
|
self.items[item][key] = new_value
|
||||||
|
|
||||||
|
|
||||||
class Messages_sender(threading.Thread):
|
class Messages_sender(threading.Thread):
|
||||||
|
"""Sending message to discord asynchronously, support embeds and content= ways"""
|
||||||
def __init__(self, message, url, embeds=True):
|
def __init__(self, message, url, embeds=True):
|
||||||
threading.Thread.__init__(self)
|
threading.Thread.__init__(self)
|
||||||
self.message = message
|
self.message = message
|
||||||
@ -71,16 +114,6 @@ class Messages_sender(threading.Thread):
|
|||||||
|
|
||||||
|
|
||||||
def run(self):
|
def run(self):
|
||||||
if self.url == None or len(url) == 0:
|
|
||||||
logger.error("No url, you must set at least one url")
|
|
||||||
time.sleep(2)
|
|
||||||
plug.show_error("You must set at least one url")
|
|
||||||
return
|
|
||||||
if len(self.message) == 0:
|
|
||||||
logger.error("empty message")
|
|
||||||
time.sleep(2)
|
|
||||||
plug.show_error("empty message")
|
|
||||||
|
|
||||||
if not self.embeds:
|
if not self.embeds:
|
||||||
self.message=f"content={self.message}"
|
self.message=f"content={self.message}"
|
||||||
self.headers={'Content-Type':'application/x-www-form-urlencoded'}
|
self.headers={'Content-Type':'application/x-www-form-urlencoded'}
|
||||||
@ -95,16 +128,16 @@ class Messages_sender(threading.Thread):
|
|||||||
for self.single_url in self.url:
|
for self.single_url in self.url:
|
||||||
self.send()
|
self.send()
|
||||||
else:
|
else:
|
||||||
logger.error(f'unknown url type {type(self.url)}')
|
logger.error(f'Unknown url type {type(self.url)}')
|
||||||
|
|
||||||
def send(self):
|
def send(self):
|
||||||
r = requests.post(self.single_url, data=self.message.encode('utf-8'), headers=self.headers)
|
r = requests.post(self.single_url, data=self.message.encode('utf-8'), headers=self.headers)
|
||||||
if r.status_code != 204:
|
if r.status_code != 204:
|
||||||
logger.error(f"status code: {r.status_code}!")
|
logger.error(f"Status code: {r.status_code}!")
|
||||||
logger.error(r.text)
|
logger.error(r.text)
|
||||||
|
|
||||||
def docking_permission2text(permission):
|
def docking_permission2text(permission):
|
||||||
"""convert one of all/none/friends/squadron/squadronfriends to normal text for user friendly messages"""
|
"""Convert one of all/none/friends/squadron/squadronfriends to user friendly message"""
|
||||||
if permission == "all":
|
if permission == "all":
|
||||||
return Messages.DOC_PERMISSION_ALL
|
return Messages.DOC_PERMISSION_ALL
|
||||||
elif permission == "none":
|
elif permission == "none":
|
||||||
@ -117,7 +150,7 @@ def docking_permission2text(permission):
|
|||||||
return Messages.DOC_PERMISSION_FRIENDS_SQUADRON
|
return Messages.DOC_PERMISSION_FRIENDS_SQUADRON
|
||||||
|
|
||||||
def docking_permission4notorius2text(notorius):
|
def docking_permission4notorius2text(notorius):
|
||||||
"""as docking_permission2text but for notorius"""
|
"""As docking_permission2text() but for notorius (crime persons)"""
|
||||||
if notorius == True:
|
if notorius == True:
|
||||||
return Messages.DOC_PERMISSION_ALLOW_NOTORIUS
|
return Messages.DOC_PERMISSION_ALLOW_NOTORIUS
|
||||||
elif notorius == False:
|
elif notorius == False:
|
||||||
@ -128,6 +161,9 @@ def plugin_start3(plugin_dir):
|
|||||||
return 'FC dispatcher'
|
return 'FC dispatcher'
|
||||||
|
|
||||||
def journal_entry(cmdr, is_beta, system, station, entry, state):
|
def journal_entry(cmdr, is_beta, system, station, entry, state):
|
||||||
|
if is_beta and not Plugin_settings.SEND_IN_BETA:
|
||||||
|
return
|
||||||
|
|
||||||
event = entry["event"]
|
event = entry["event"]
|
||||||
|
|
||||||
if event == "CarrierStats":
|
if event == "CarrierStats":
|
||||||
@ -137,48 +173,54 @@ def journal_entry(cmdr, is_beta, system, station, entry, state):
|
|||||||
carrier.allow_notorius = entry["AllowNotorious"]
|
carrier.allow_notorius = entry["AllowNotorious"]
|
||||||
return
|
return
|
||||||
|
|
||||||
if event in ["CarrierJumpRequest", "CarrierJumpCancelled", "CarrierJump", "CarrierDockingPermission"]:
|
if event in ["CarrierJumpRequest", "CarrierJumpCancelled", "CarrierJump", "CarrierDockingPermission", "CarrierNameChanged"]:
|
||||||
message = json.loads(Messages.EMBEDS_TEMPLATE)
|
message = embed()
|
||||||
|
|
||||||
|
if event == "CarrierJumpRequest" and Plugin_settings.SEND_JUMP_REQUESTS:
|
||||||
if event == "CarrierJumpRequest":
|
|
||||||
destination_system = entry["SystemName"]
|
destination_system = entry["SystemName"]
|
||||||
|
message.add_item(color=Messages.COLOR_JUMP_REQUEST, title=Messages.TITLE_JUMP_REQUEST)
|
||||||
message["embeds"][0]["title"] = Messages.TITLE_JUMP_REQUEST
|
|
||||||
message["embeds"][0]["color"] = Messages.JUMP_REQUEST_COLOR
|
|
||||||
message["embeds"][0]["description"] = Messages.TEXT_JUMP_REQUEST.format(name=carrier.name, system=destination_system)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
destination_body = entry["Body"]
|
destination_body = entry["Body"]
|
||||||
message["embeds"][0]["description"] += Messages.TEXT_JUMP_REQUEST_BODY_DIFF.format(body=destination_body)
|
message.update_item(item=0, key="description", new_value=Messages.TEXT_JUMP_REQUEST.format(name=carrier.name, system=destination_system) + Messages.TEXT_JUMP_REQUEST_BODY_DIFF.format(body=destination_body))
|
||||||
except KeyError:
|
except KeyError:
|
||||||
pass
|
message.update_item(item=0, key="description", new_value=TEXT_JUMP_REQUEST.format(name=carrier.name, system=destination_system))
|
||||||
|
|
||||||
if event == "CarrierJumpCancelled":
|
if event == "CarrierJumpCancelled" and Plugin_settings.SEND_JUMP_CANCELING:
|
||||||
|
message.add_item(color=Messages.COLOR_JUMP_CANCELLED, title=Messages.TITLE_JUMP_CANCELLED, description=Messages.TEXT_JUMP_CANCELLED.format(name=carrier.name))
|
||||||
message["embeds"][0]["title"] = Messages.TITLE_JUMP_CANCELLED
|
|
||||||
message["embeds"][0]["color"] = Messages.JUMP_CANCELLED_COLOR
|
|
||||||
message["embeds"][0]["description"] = Messages.TEXT_JUMP_CANCELLED.format(name=carrier.name)
|
|
||||||
|
|
||||||
|
|
||||||
if event == "CarrierJump":
|
if event == "CarrierJump" and Plugin_settings.SEND_JUMPS:
|
||||||
destination_system = entry["StarSystem"]
|
destination_system = entry["StarSystem"]
|
||||||
|
|
||||||
message["embeds"][0]["title"] = Messages.TITLE_JUMP_COMPLETE
|
message.add_item(color=Messages.COLOR_JUMP, title=Messages.TITLE_JUMP)
|
||||||
message["embeds"][0]["color"] = Messages.JUMP_COLOR
|
|
||||||
message["embeds"][0]["description"] = Messages.TEXT_JUMP_COMPLETE.format(system=destination_system, name=carrier.name)
|
|
||||||
|
|
||||||
if event == "CarrierDockingPermission":
|
|
||||||
|
try:
|
||||||
|
destination_body = entry["Body"]
|
||||||
|
message.update_item(item=0, key="description", new_value=Messages.TEXT_JUMP.format(system=destination_system, name=carrier.name) + Messages.TEXT_JUMP_REQUEST_BODY_DIFF.format(body=destination_body))
|
||||||
|
except KeyError:
|
||||||
|
message.update_item(item=0, key="description", new_value=Messages.TEXT_JUMP.format(system=destination_system, name=carrier.name))
|
||||||
|
|
||||||
|
|
||||||
|
if event == "CarrierDockingPermission" and Plugin_settings.SEND_CHANGES_DOCKING_PERMISSIONS:
|
||||||
new_permission = entry["DockingAccess"]
|
new_permission = entry["DockingAccess"]
|
||||||
new_doc_for_crime = entry["AllowNotorious"]
|
new_doc_for_crime = entry["AllowNotorious"]
|
||||||
|
|
||||||
message["embeds"][0]["title"] = Messages.TITLE_CHANGE_DOCKING_PERMISSION
|
message.add_item(title=Messages.TITLE_CHANGE_DOCKING_PERMISSION, color=Messages.COLOR_PERMISSION_CHANGE, description=Messages.TEXT_PERMISSION_CHANGE.format(
|
||||||
message["embeds"][0]["color"] = Messages.PERMISSION_CHANGE_COLOR
|
name=carrier.name, old_permission=docking_permission2text(carrier.docking_permission), new_permission=docking_permission2text(new_permission),
|
||||||
message["embeds"][0]["description"] = Messages.TEXT_PERMISSION_CHANGE.format(name=carrier.name, old_permission=docking_permission2text(carrier.docking_permission), new_permission=docking_permission2text(new_permission),
|
old_doc_for_crime=docking_permission4notorius2text(carrier.allow_notorius), new_doc_for_crime=docking_permission4notorius2text(new_doc_for_crime)))
|
||||||
old_doc_for_crime=docking_permission4notorius2text(carrier.allow_notorius), new_doc_for_crime=docking_permission4notorius2text(new_doc_for_crime))
|
|
||||||
carrier.docking_permission = new_permission
|
carrier.docking_permission = new_permission
|
||||||
carrier.allow_notorius = new_doc_for_crime
|
carrier.allow_notorius = new_doc_for_crime
|
||||||
|
|
||||||
Messages_sender(json.dumps(message), url).start() #one Messages_sender instance per message
|
if event == "CarrierNameChanged" and Plugin_settings.SEND_CHANGES_NAME:
|
||||||
|
new_name = entry["Name"]
|
||||||
|
message.add_item(title=Messages.TITLE_CHANGE_NAME, description=Messages.TEXT_CHANGE_NAME.format(old_name=carrier.name, new_name=new_name), color=COLOR_CHANGE_NAME)
|
||||||
|
carrier.name = new_name
|
||||||
|
|
||||||
|
if is_beta or force_beta:
|
||||||
|
message.add_item(title=Messages.TITLE_IN_BETA, description=Messages.TEXT_IN_BETA)
|
||||||
|
|
||||||
|
Messages_sender(message.get_message(), url).start() #one Messages_sender instance per message
|
||||||
|
|
||||||
carrier = Carrier()
|
carrier = Carrier()
|
||||||
|
Loading…
x
Reference in New Issue
Block a user