Refactor even more

This commit is contained in:
2024-08-14 05:15:42 +02:00
parent d86cb1fd2a
commit 7d6333183d

View File

@ -41,9 +41,10 @@ def get_profile_dir() -> Path:
Returns: Returns:
Path: The profile directory. Path: The profile directory.
""" """
profile_dir: Path = Path(get_data_dir() / "chrome-profile") profile_dir = Path(get_data_dir() / "chrome-profile")
profile_dir.mkdir(parents=True, exist_ok=True) profile_dir.mkdir(parents=True, exist_ok=True)
logger.debug("Launching Chrome browser with user data directory: %s", profile_dir) if logger.isEnabledFor(logging.DEBUG):
logger.debug("Launching Chrome browser with user data directory: %s", profile_dir)
return profile_dir return profile_dir
@ -57,7 +58,7 @@ def save_json(campaign: dict | None, dir_name: str) -> None:
if not campaign: if not campaign:
return return
save_dir: Path = Path(dir_name) save_dir = Path(dir_name)
save_dir.mkdir(parents=True, exist_ok=True) save_dir.mkdir(parents=True, exist_ok=True)
# File name is the hash of the JSON data # File name is the hash of the JSON data
@ -77,7 +78,7 @@ async def add_reward_campaign(campaign: dict | None) -> None: # noqa: C901
return return
logger.info("Adding reward campaign to database") logger.info("Adding reward campaign to database")
for reward_campaign in campaign["data"]["rewardCampaignsAvailableToUser"]: if "data" in campaign and "rewardCampaignsAvailableToUser" in campaign["data"]:
mappings: dict[str, str] = { mappings: dict[str, str] = {
"brand": "brand", "brand": "brand",
"createdAt": "created_at", "createdAt": "created_at",
@ -91,31 +92,32 @@ async def add_reward_campaign(campaign: dict | None) -> None: # noqa: C901
"aboutURL": "about_url", "aboutURL": "about_url",
"isSitewide": "is_site_wide", "isSitewide": "is_site_wide",
} }
defaults = {new_key: reward_campaign[key] for key, new_key in mappings.items() if reward_campaign.get(key)}
if reward_campaign.get("unlockRequirements", {}).get("subsGoal"): for reward_campaign in campaign["data"]["rewardCampaignsAvailableToUser"]:
defaults["sub_goal"] = reward_campaign["unlockRequirements"]["subsGoal"] defaults = {new_key: reward_campaign[key] for key, new_key in mappings.items() if reward_campaign.get(key)}
if reward_campaign.get("unlockRequirements", {}).get("minuteWatchedGoal"): if reward_campaign.get("unlockRequirements", {}).get("subsGoal"):
defaults["minute_watched_goal"] = reward_campaign["unlockRequirements"]["minuteWatchedGoal"] defaults["sub_goal"] = reward_campaign["unlockRequirements"]["subsGoal"]
if reward_campaign.get("image"): if reward_campaign.get("unlockRequirements", {}).get("minuteWatchedGoal"):
defaults["image_url"] = reward_campaign["image"]["image1xURL"] defaults["minute_watched_goal"] = reward_campaign["unlockRequirements"]["minuteWatchedGoal"]
our_reward_campaign, created = await RewardCampaign.objects.aupdate_or_create( if reward_campaign.get("image"):
id=reward_campaign["id"], defaults["image_url"] = reward_campaign["image"]["image1xURL"]
defaults=defaults,
)
if created:
logger.info("Added reward campaign %s", our_reward_campaign.id)
if reward_campaign["game"]: our_reward_campaign, created = await RewardCampaign.objects.aupdate_or_create(
# TODO(TheLovinator): Add game to reward campaign # noqa: TD003 id=reward_campaign["id"],
# TODO(TheLovinator): Send JSON to Discord # noqa: TD003 defaults=defaults,
logger.error("Not implemented: Add game to reward campaign, JSON: %s", reward_campaign["game"]) )
if created:
logger.info("Added reward campaign %s", our_reward_campaign.id)
# Add rewards if reward_campaign["game"]:
for reward in reward_campaign["rewards"]: # TODO(TheLovinator): Add game to reward campaign # noqa: TD003
# TODO(TheLovinator): Send JSON to Discord # noqa: TD003
logger.error("Not implemented: Add game to reward campaign, JSON: %s", reward_campaign["game"])
# Add rewards
mappings: dict[str, str] = { mappings: dict[str, str] = {
"name": "name", "name": "name",
"bannerImage": "banner_image_url", "bannerImage": "banner_image_url",
@ -124,18 +126,19 @@ async def add_reward_campaign(campaign: dict | None) -> None: # noqa: C901
"redemptionInstructions": "redemption_instructions", "redemptionInstructions": "redemption_instructions",
"redemptionURL": "redemption_url", "redemptionURL": "redemption_url",
} }
defaults = {new_key: reward[key] for key, new_key in mappings.items() if reward.get(key)} for reward in reward_campaign["rewards"]:
defaults = {new_key: reward[key] for key, new_key in mappings.items() if reward.get(key)}
if our_reward_campaign:
defaults["campaign"] = our_reward_campaign
our_reward, created = await Reward.objects.aupdate_or_create(
id=reward["id"],
defaults=defaults,
)
if our_reward_campaign: if created:
defaults["campaign"] = our_reward_campaign logger.info("Added reward %s", our_reward.id)
our_reward, created = await Reward.objects.aupdate_or_create( else:
id=reward["id"], logger.info("Updated reward %s", our_reward.id)
defaults=defaults,
)
if created:
logger.info("Added reward %s", our_reward.id)
else:
logger.info("Updated reward %s", our_reward.id)
async def add_or_update_game(game_json: dict | None) -> Game | None: async def add_or_update_game(game_json: dict | None) -> Game | None:
@ -189,7 +192,7 @@ async def add_or_update_owner(owner_json: dict | None) -> Owner | None:
if owner_json.get("name"): if owner_json.get("name"):
defaults["name"] = owner_json["name"] defaults["name"] = owner_json["name"]
our_owner, created = await Owner.objects.aupdate_or_create(id=owner_json["id"], defaults=defaults) our_owner, created = await Owner.objects.aupdate_or_create(id=owner_json.get("id"), defaults=defaults)
if created: if created:
logger.info("Added owner %s", our_owner.id) logger.info("Added owner %s", our_owner.id)
@ -216,7 +219,7 @@ async def add_or_update_channels(channels_json: list[dict]) -> list[Channel] | N
if channel_json.get("name"): if channel_json.get("name"):
defaults["name"] = channel_json["name"] defaults["name"] = channel_json["name"]
defaults["twitch_url"] = f"https://www.twitch.tv/{channel_json["name"]}" defaults["twitch_url"] = f'https://www.twitch.tv/{channel_json["name"]}'
our_channel, created = await Channel.objects.aupdate_or_create(twitch_id=channel_json["id"], defaults=defaults) our_channel, created = await Channel.objects.aupdate_or_create(twitch_id=channel_json["id"], defaults=defaults)
if created: if created:
@ -234,16 +237,13 @@ async def add_benefit(benefit: dict, time_based_drop: TimeBasedDrop) -> None:
benefit (dict): The benefit to add. benefit (dict): The benefit to add.
time_based_drop (TimeBasedDrop): The time-based drop the benefit belongs to. time_based_drop (TimeBasedDrop): The time-based drop the benefit belongs to.
""" """
logger.info("Adding benefit to database") mappings: dict[str, str] = {
mappings = {
"createdAt": "twitch_created_at", "createdAt": "twitch_created_at",
"entitlementLimit": "entitlement_limit", "entitlementLimit": "entitlement_limit",
"imageAssetURL": "image_url", "imageAssetURL": "image_url",
"isIosAvailable": "is_ios_available", "isIosAvailable": "is_ios_available",
"name": "name", "name": "name",
} }
defaults = {new_key: benefit[key] for key, new_key in mappings.items() if benefit.get(key)} defaults = {new_key: benefit[key] for key, new_key in mappings.items() if benefit.get(key)}
our_benefit, created = await Benefit.objects.aupdate_or_create(id=benefit["id"], defaults=defaults) our_benefit, created = await Benefit.objects.aupdate_or_create(id=benefit["id"], defaults=defaults)
if created: if created: