2021-04-13 07:55:08 +12:00
|
|
|
import platform
|
|
|
|
import time
|
2021-04-13 22:38:11 +12:00
|
|
|
from logging import getLogger
|
2021-04-13 07:55:08 +12:00
|
|
|
|
2021-05-01 21:24:38 +12:00
|
|
|
import pypresence.exceptions
|
2021-04-13 07:55:08 +12:00
|
|
|
from PyQt5.QtCore import QObject, QSettings
|
|
|
|
from pypresence import Presence
|
|
|
|
|
2022-02-26 06:43:27 +13:00
|
|
|
from rare.shared import LegendaryCoreSingleton, GlobalSignalsSingleton
|
2021-04-13 07:55:08 +12:00
|
|
|
|
|
|
|
client_id = "830732538225360908"
|
2021-04-13 22:38:11 +12:00
|
|
|
logger = getLogger("RPC")
|
2021-04-13 07:55:08 +12:00
|
|
|
|
|
|
|
|
|
|
|
class DiscordRPC(QObject):
|
2021-10-15 10:05:00 +13:00
|
|
|
def __init__(self):
|
2021-04-13 07:55:08 +12:00
|
|
|
super(DiscordRPC, self).__init__()
|
|
|
|
self.RPC = None
|
|
|
|
self.state = 1 # 0: game, 1: always active, 2: off
|
2022-02-26 06:43:27 +13:00
|
|
|
self.core = LegendaryCoreSingleton()
|
|
|
|
self.signals = GlobalSignalsSingleton()
|
2021-10-15 10:05:00 +13:00
|
|
|
|
2021-04-13 07:55:08 +12:00
|
|
|
self.settings = QSettings()
|
|
|
|
if self.settings.value("rpc_enable", 0, int) == 1: # show always
|
|
|
|
self.state = 2
|
|
|
|
self.set_discord_rpc()
|
|
|
|
|
2021-10-15 10:05:00 +13:00
|
|
|
self.signals.set_discord_rpc.connect(self.update_presence)
|
2022-03-10 10:16:45 +13:00
|
|
|
self.signals.rpc_settings_updated.connect(self.changed_settings)
|
2021-10-15 10:05:00 +13:00
|
|
|
|
|
|
|
def update_presence(self, app_name):
|
|
|
|
self.set_discord_rpc(app_name)
|
|
|
|
|
2022-03-10 10:16:45 +13:00
|
|
|
def changed_settings(self, game_running: list = None):
|
2021-04-13 07:55:08 +12:00
|
|
|
value = self.settings.value("rpc_enable", 0, int)
|
|
|
|
if value == 2:
|
|
|
|
self.remove_rpc()
|
|
|
|
return
|
2021-04-13 22:38:11 +12:00
|
|
|
if not game_running and value == 0:
|
2021-04-13 07:55:08 +12:00
|
|
|
self.remove_rpc()
|
2021-04-13 22:38:11 +12:00
|
|
|
elif not game_running:
|
|
|
|
self.set_discord_rpc()
|
2021-04-13 07:55:08 +12:00
|
|
|
else:
|
|
|
|
self.set_discord_rpc(game_running[0])
|
|
|
|
|
|
|
|
def remove_rpc(self):
|
|
|
|
if self.settings.value("rpc_enable", 0, int) != 1:
|
|
|
|
if not self.RPC:
|
|
|
|
return
|
2021-04-13 22:38:11 +12:00
|
|
|
try:
|
|
|
|
self.RPC.close()
|
|
|
|
except Exception:
|
|
|
|
logger.warning("Already closed")
|
2021-04-13 07:55:08 +12:00
|
|
|
del self.RPC
|
|
|
|
self.RPC = None
|
2021-04-13 22:38:11 +12:00
|
|
|
logger.info("Remove RPC")
|
2021-04-13 07:55:08 +12:00
|
|
|
self.state = 2
|
|
|
|
else:
|
|
|
|
self.state = 1
|
|
|
|
self.set_discord_rpc()
|
|
|
|
|
|
|
|
def set_discord_rpc(self, app_name=None):
|
|
|
|
if not self.RPC:
|
2021-04-13 22:38:11 +12:00
|
|
|
try:
|
2021-12-24 22:09:50 +13:00
|
|
|
self.RPC = Presence(
|
|
|
|
client_id
|
|
|
|
) # Rare app: https://discord.com/developers/applications
|
2021-04-13 22:38:11 +12:00
|
|
|
self.RPC.connect()
|
|
|
|
except ConnectionRefusedError as e:
|
2022-02-02 10:29:34 +13:00
|
|
|
logger.warning(f"Discord is not active\n{e}")
|
2021-04-13 22:40:50 +12:00
|
|
|
self.RPC = None
|
2021-04-13 22:38:11 +12:00
|
|
|
return
|
2021-04-16 09:02:48 +12:00
|
|
|
except FileNotFoundError as e:
|
2022-02-02 10:29:34 +13:00
|
|
|
logger.warning(f"File not found error\n{e}")
|
2021-04-16 09:02:48 +12:00
|
|
|
self.RPC = None
|
|
|
|
return
|
2021-05-01 21:24:38 +12:00
|
|
|
except pypresence.exceptions.InvalidPipe as e:
|
2022-02-02 10:29:34 +13:00
|
|
|
logger.error(f"Is Discord running? \n{e}")
|
2021-05-01 21:24:38 +12:00
|
|
|
self.RPC = None
|
|
|
|
return
|
|
|
|
except Exception as e:
|
|
|
|
logger.error(str(e))
|
|
|
|
self.RPC = None
|
|
|
|
return
|
2021-04-13 07:55:08 +12:00
|
|
|
self.update_rpc(app_name)
|
|
|
|
|
|
|
|
def update_rpc(self, app_name=None):
|
2021-05-21 23:40:10 +12:00
|
|
|
if self.settings.value("rpc_enable", 0, int) == 2 or (
|
2022-03-10 10:16:45 +13:00
|
|
|
not app_name and self.settings.value("rpc_enable", 0, int) == 0
|
2021-12-24 22:09:50 +13:00
|
|
|
):
|
2021-04-13 07:55:08 +12:00
|
|
|
self.remove_rpc()
|
|
|
|
return
|
|
|
|
title = None
|
|
|
|
if not app_name:
|
2021-12-24 22:09:50 +13:00
|
|
|
self.RPC.update(
|
|
|
|
large_image="logo", details="https://github.com/Dummerle/Rare"
|
|
|
|
)
|
2021-04-13 07:55:08 +12:00
|
|
|
return
|
|
|
|
if self.settings.value("rpc_name", True, bool):
|
2021-09-14 08:27:37 +12:00
|
|
|
try:
|
|
|
|
title = self.core.get_installed_game(app_name).title
|
|
|
|
except AttributeError:
|
2022-02-02 10:29:34 +13:00
|
|
|
logger.error(f"Could not get title of game: {app_name}")
|
2021-09-14 08:27:37 +12:00
|
|
|
title = app_name
|
2021-04-13 07:55:08 +12:00
|
|
|
start = None
|
|
|
|
if self.settings.value("rpc_time", True, bool):
|
|
|
|
start = str(time.time()).split(".")[0]
|
|
|
|
os = None
|
|
|
|
if self.settings.value("rpc_os", True, bool):
|
2022-02-02 10:29:34 +13:00
|
|
|
os = f"via Rare on {platform.system()}"
|
2021-04-13 07:55:08 +12:00
|
|
|
|
2021-12-24 22:09:50 +13:00
|
|
|
self.RPC.update(
|
|
|
|
large_image="logo", details=title, large_text=title, state=os, start=start
|
|
|
|
)
|
2021-04-13 07:55:08 +12:00
|
|
|
self.state = 0
|