sticker-convert 2.13.3.0__py3-none-any.whl → 2.17.0.0__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (93) hide show
  1. sticker_convert/__main__.py +24 -27
  2. sticker_convert/auth/__init__.py +0 -0
  3. sticker_convert/auth/auth_base.py +19 -0
  4. sticker_convert/{utils/auth/get_discord_auth.py → auth/auth_discord.py} +149 -118
  5. sticker_convert/{utils/auth/get_kakao_auth.py → auth/auth_kakao_android_login.py} +331 -330
  6. sticker_convert/auth/auth_kakao_desktop_login.py +327 -0
  7. sticker_convert/{utils/auth/get_kakao_desktop_auth.py → auth/auth_kakao_desktop_memdump.py} +281 -263
  8. sticker_convert/{utils/auth/get_line_auth.py → auth/auth_line.py} +98 -80
  9. sticker_convert/{utils/auth/get_signal_auth.py → auth/auth_signal.py} +139 -135
  10. sticker_convert/auth/auth_telethon.py +161 -0
  11. sticker_convert/{utils/auth/get_viber_auth.py → auth/auth_viber.py} +250 -235
  12. sticker_convert/{utils/auth → auth}/telegram_api.py +736 -675
  13. sticker_convert/cli.py +623 -608
  14. sticker_convert/converter.py +1093 -1084
  15. sticker_convert/definitions.py +4 -0
  16. sticker_convert/downloaders/download_band.py +111 -110
  17. sticker_convert/downloaders/download_base.py +171 -166
  18. sticker_convert/downloaders/download_discord.py +92 -91
  19. sticker_convert/downloaders/download_kakao.py +417 -404
  20. sticker_convert/downloaders/download_line.py +484 -475
  21. sticker_convert/downloaders/download_ogq.py +80 -79
  22. sticker_convert/downloaders/download_signal.py +108 -105
  23. sticker_convert/downloaders/download_telegram.py +56 -55
  24. sticker_convert/downloaders/download_viber.py +121 -120
  25. sticker_convert/gui.py +788 -873
  26. sticker_convert/gui_components/frames/comp_frame.py +180 -166
  27. sticker_convert/gui_components/frames/config_frame.py +156 -113
  28. sticker_convert/gui_components/frames/control_frame.py +32 -30
  29. sticker_convert/gui_components/frames/cred_frame.py +232 -233
  30. sticker_convert/gui_components/frames/input_frame.py +139 -137
  31. sticker_convert/gui_components/frames/output_frame.py +112 -110
  32. sticker_convert/gui_components/frames/right_clicker.py +25 -23
  33. sticker_convert/gui_components/windows/advanced_compression_window.py +757 -757
  34. sticker_convert/gui_components/windows/base_window.py +7 -2
  35. sticker_convert/gui_components/windows/discord_get_auth_window.py +79 -82
  36. sticker_convert/gui_components/windows/kakao_get_auth_window.py +511 -321
  37. sticker_convert/gui_components/windows/line_get_auth_window.py +94 -102
  38. sticker_convert/gui_components/windows/signal_get_auth_window.py +84 -89
  39. sticker_convert/gui_components/windows/viber_get_auth_window.py +168 -168
  40. sticker_convert/ios-message-stickers-template/.github/FUNDING.yml +3 -3
  41. sticker_convert/ios-message-stickers-template/README.md +10 -10
  42. sticker_convert/ios-message-stickers-template/stickers/Info.plist +43 -43
  43. sticker_convert/ios-message-stickers-template/stickers StickerPackExtension/Info.plist +31 -31
  44. sticker_convert/ios-message-stickers-template/stickers StickerPackExtension/Stickers.xcstickers/Contents.json +6 -6
  45. sticker_convert/ios-message-stickers-template/stickers StickerPackExtension/Stickers.xcstickers/Sticker Pack.stickerpack/Contents.json +20 -20
  46. sticker_convert/ios-message-stickers-template/stickers StickerPackExtension/Stickers.xcstickers/Sticker Pack.stickerpack/Sticker 1.sticker/Contents.json +9 -9
  47. sticker_convert/ios-message-stickers-template/stickers StickerPackExtension/Stickers.xcstickers/Sticker Pack.stickerpack/Sticker 2.sticker/Contents.json +9 -9
  48. sticker_convert/ios-message-stickers-template/stickers StickerPackExtension/Stickers.xcstickers/Sticker Pack.stickerpack/Sticker 3.sticker/Contents.json +9 -9
  49. sticker_convert/ios-message-stickers-template/stickers StickerPackExtension/Stickers.xcstickers/iMessage App Icon.stickersiconset/Contents.json +91 -91
  50. sticker_convert/ios-message-stickers-template/stickers.xcodeproj/project.pbxproj +364 -364
  51. sticker_convert/ios-message-stickers-template/stickers.xcodeproj/project.xcworkspace/contents.xcworkspacedata +7 -7
  52. sticker_convert/ios-message-stickers-template/stickers.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +8 -8
  53. sticker_convert/ios-message-stickers-template/stickers.xcodeproj/xcuserdata/niklaspeterson.xcuserdatad/xcschemes/xcschememanagement.plist +14 -14
  54. sticker_convert/job.py +166 -130
  55. sticker_convert/job_option.py +1 -0
  56. sticker_convert/locales/en_US/LC_MESSAGES/base.mo +0 -0
  57. sticker_convert/locales/ja_JP/LC_MESSAGES/base.mo +0 -0
  58. sticker_convert/locales/zh_CN/LC_MESSAGES/base.mo +0 -0
  59. sticker_convert/locales/zh_TW/LC_MESSAGES/base.mo +0 -0
  60. sticker_convert/py.typed +0 -0
  61. sticker_convert/resources/NotoColorEmoji.ttf +0 -0
  62. sticker_convert/resources/help.ja_JP.json +88 -0
  63. sticker_convert/resources/help.json +10 -7
  64. sticker_convert/resources/help.zh_CN.json +88 -0
  65. sticker_convert/resources/help.zh_TW.json +88 -0
  66. sticker_convert/resources/input.ja_JP.json +74 -0
  67. sticker_convert/resources/input.json +121 -121
  68. sticker_convert/resources/input.zh_CN.json +74 -0
  69. sticker_convert/resources/input.zh_TW.json +74 -0
  70. sticker_convert/resources/output.ja_JP.json +38 -0
  71. sticker_convert/resources/output.zh_CN.json +38 -0
  72. sticker_convert/resources/output.zh_TW.json +38 -0
  73. sticker_convert/uploaders/compress_wastickers.py +186 -177
  74. sticker_convert/uploaders/upload_base.py +44 -35
  75. sticker_convert/uploaders/upload_signal.py +218 -203
  76. sticker_convert/uploaders/upload_telegram.py +353 -338
  77. sticker_convert/uploaders/upload_viber.py +178 -169
  78. sticker_convert/uploaders/xcode_imessage.py +295 -286
  79. sticker_convert/utils/callback.py +238 -6
  80. sticker_convert/utils/emoji.py +16 -4
  81. sticker_convert/utils/files/json_resources_loader.py +24 -19
  82. sticker_convert/utils/files/metadata_handler.py +3 -3
  83. sticker_convert/utils/translate.py +108 -0
  84. sticker_convert/utils/url_detect.py +40 -37
  85. sticker_convert/version.py +1 -1
  86. {sticker_convert-2.13.3.0.dist-info → sticker_convert-2.17.0.0.dist-info}/METADATA +89 -74
  87. {sticker_convert-2.13.3.0.dist-info → sticker_convert-2.17.0.0.dist-info}/RECORD +91 -74
  88. sticker_convert/utils/auth/telethon_setup.py +0 -97
  89. sticker_convert/utils/singletons.py +0 -18
  90. {sticker_convert-2.13.3.0.dist-info → sticker_convert-2.17.0.0.dist-info}/WHEEL +0 -0
  91. {sticker_convert-2.13.3.0.dist-info → sticker_convert-2.17.0.0.dist-info}/entry_points.txt +0 -0
  92. {sticker_convert-2.13.3.0.dist-info → sticker_convert-2.17.0.0.dist-info}/licenses/LICENSE +0 -0
  93. {sticker_convert-2.13.3.0.dist-info → sticker_convert-2.17.0.0.dist-info}/top_level.txt +0 -0
@@ -1,79 +1,80 @@
1
- #!/usr/bin/env python3
2
- from __future__ import annotations
3
-
4
- from pathlib import Path
5
- from typing import Any, List, Optional, Tuple
6
- from urllib import parse
7
-
8
- import requests
9
- from bs4 import BeautifulSoup
10
-
11
- from sticker_convert.downloaders.download_base import DownloadBase
12
- from sticker_convert.job_option import CredOption, InputOption
13
- from sticker_convert.utils.callback import CallbackProtocol, CallbackReturn
14
- from sticker_convert.utils.files.metadata_handler import MetadataHandler
15
-
16
- # Reference: https://github.com/star-39/moe-sticker-bot/issues/49
17
-
18
-
19
- class DownloadOgq(DownloadBase):
20
- def __init__(self, *args: Any, **kwargs: Any) -> None:
21
- super().__init__(*args, **kwargs)
22
- self.headers = {"User-Agent": "Mozilla/5.0"}
23
-
24
- def download_stickers_ogq(self) -> Tuple[int, int]:
25
- url_parse = parse.urlparse(self.url)
26
- if (
27
- url_parse.netloc != "ogqmarket.naver.com"
28
- or url_parse.path.startswith("/artworks/sticker/detail") is False
29
- ):
30
- self.cb.put(f"Invalid url: {self.url}")
31
- artwork_id = {
32
- i.split("=")[0]: i.split("=")[1] for i in url_parse.query.split("&")
33
- }["artworkId"]
34
-
35
- html = requests.get(self.url, headers=self.headers).text
36
- soup = BeautifulSoup(html, "html.parser")
37
-
38
- author_tag = soup.select_one("div.info div.nickname span") # type: ignore
39
- author = author_tag.text.strip() if author_tag else "OGQ"
40
- title_tag = soup.select_one("div.header div div.title p") # type: ignore
41
- title = title_tag.text.strip() if title_tag else artwork_id
42
-
43
- seen: List[str] = []
44
- imgs: List[str] = []
45
- targets: List[Tuple[str, Path]] = []
46
- n = 0
47
- for img in soup.find_all("img", alt="sticker-detail-image-prevew"):
48
- src = img.get("src")
49
- if not src:
50
- continue
51
- src = src.split("?")[0]
52
- if src in seen:
53
- continue
54
- seen.append(src)
55
- imgs.append(src)
56
- sticker_url = f"{src}?type=ma480_480"
57
- sticker_url_parse = parse.urlparse(sticker_url)
58
- ext = sticker_url_parse.path.split(".")[-1]
59
- if sticker_url_parse.path.split("/")[-1].startswith("original_"):
60
- path = self.out_dir / f"{n}.{ext}"
61
- else:
62
- path = self.out_dir / f"cover.{ext}"
63
- targets.append((sticker_url, path))
64
- n += 1
65
-
66
- results = self.download_multiple_files(targets)
67
- MetadataHandler.set_metadata(self.out_dir, title=title, author=author)
68
-
69
- return len(results.values()), len(targets)
70
-
71
- @staticmethod
72
- def start(
73
- opt_input: InputOption,
74
- opt_cred: Optional[CredOption],
75
- cb: CallbackProtocol,
76
- cb_return: CallbackReturn,
77
- ) -> Tuple[int, int]:
78
- downloader = DownloadOgq(opt_input, opt_cred, cb, cb_return)
79
- return downloader.download_stickers_ogq()
1
+ #!/usr/bin/env python3
2
+ from __future__ import annotations
3
+
4
+ from pathlib import Path
5
+ from typing import Any, List, Optional, Tuple
6
+ from urllib import parse
7
+
8
+ import requests
9
+ from bs4 import BeautifulSoup
10
+
11
+ from sticker_convert.downloaders.download_base import DownloadBase
12
+ from sticker_convert.job_option import CredOption, InputOption
13
+ from sticker_convert.utils.callback import CallbackProtocol, CallbackReturn
14
+ from sticker_convert.utils.files.metadata_handler import MetadataHandler
15
+ from sticker_convert.utils.translate import I
16
+
17
+ # Reference: https://github.com/star-39/moe-sticker-bot/issues/49
18
+
19
+
20
+ class DownloadOgq(DownloadBase):
21
+ def __init__(self, *args: Any, **kwargs: Any) -> None:
22
+ super().__init__(*args, **kwargs)
23
+ self.headers = {"User-Agent": "Mozilla/5.0"}
24
+
25
+ def download_stickers_ogq(self) -> Tuple[int, int]:
26
+ url_parse = parse.urlparse(self.url)
27
+ if (
28
+ url_parse.netloc != "ogqmarket.naver.com"
29
+ or url_parse.path.startswith("/artworks/sticker/detail") is False
30
+ ):
31
+ self.cb.put(I("Invalid url: {}").format(self.url))
32
+ artwork_id = {
33
+ i.split("=")[0]: i.split("=")[1] for i in url_parse.query.split("&")
34
+ }["artworkId"]
35
+
36
+ html = requests.get(self.url, headers=self.headers).text
37
+ soup = BeautifulSoup(html, "html.parser")
38
+
39
+ author_tag = soup.select_one("div.info div.nickname span") # type: ignore
40
+ author = author_tag.text.strip() if author_tag else "OGQ"
41
+ title_tag = soup.select_one("div.header div div.title p") # type: ignore
42
+ title = title_tag.text.strip() if title_tag else artwork_id
43
+
44
+ seen: List[str] = []
45
+ imgs: List[str] = []
46
+ targets: List[Tuple[str, Path]] = []
47
+ n = 0
48
+ for img in soup.find_all("img", alt="sticker-detail-image-prevew"):
49
+ src = img.get("src")
50
+ if not src:
51
+ continue
52
+ src = src.split("?")[0]
53
+ if src in seen:
54
+ continue
55
+ seen.append(src)
56
+ imgs.append(src)
57
+ sticker_url = f"{src}?type=ma480_480"
58
+ sticker_url_parse = parse.urlparse(sticker_url)
59
+ ext = sticker_url_parse.path.split(".")[-1]
60
+ if sticker_url_parse.path.split("/")[-1].startswith("original_"):
61
+ path = self.out_dir / f"{n}.{ext}"
62
+ else:
63
+ path = self.out_dir / f"cover.{ext}"
64
+ targets.append((sticker_url, path))
65
+ n += 1
66
+
67
+ results = self.download_multiple_files(targets)
68
+ MetadataHandler.set_metadata(self.out_dir, title=title, author=author)
69
+
70
+ return len(results.values()), len(targets)
71
+
72
+ @staticmethod
73
+ def start(
74
+ opt_input: InputOption,
75
+ opt_cred: Optional[CredOption],
76
+ cb: CallbackProtocol,
77
+ cb_return: CallbackReturn,
78
+ ) -> Tuple[int, int]:
79
+ downloader = DownloadOgq(opt_input, opt_cred, cb, cb_return)
80
+ return downloader.download_stickers_ogq()
@@ -1,105 +1,108 @@
1
- #!/usr/bin/env python3
2
- from pathlib import Path
3
- from typing import Dict, Optional, Tuple
4
-
5
- import anyio
6
- from signalstickers_client.errors import SignalException
7
- from signalstickers_client.models import StickerPack
8
- from signalstickers_client.stickersclient import StickersClient
9
-
10
- from sticker_convert.downloaders.download_base import DownloadBase
11
- from sticker_convert.job_option import CredOption, InputOption
12
- from sticker_convert.utils.callback import CallbackProtocol, CallbackReturn
13
- from sticker_convert.utils.files.metadata_handler import MetadataHandler
14
- from sticker_convert.utils.media.codec_info import CodecInfo
15
-
16
-
17
- class DownloadSignal(DownloadBase):
18
- # def __init__(self, *args: Any, **kwargs: Any) -> None:
19
- # super().__init__(*args, **kwargs)
20
-
21
- @staticmethod
22
- async def get_pack(pack_id: str, pack_key: str) -> StickerPack:
23
- async with StickersClient() as client:
24
- pack = await client.get_pack(pack_id, pack_key)
25
-
26
- return pack
27
-
28
- def save_stickers(self, pack: StickerPack) -> None:
29
- self.cb.put(
30
- (
31
- "bar",
32
- None,
33
- {
34
- "set_progress_mode": "determinate",
35
- "steps": len(pack.stickers),
36
- },
37
- )
38
- )
39
-
40
- emoji_dict: Dict[str, str] = {}
41
- for sticker in pack.stickers:
42
- f_id = str(sticker.id).zfill(3)
43
- f_path = Path(self.out_dir, f_id)
44
- with open(f_path, "wb") as f:
45
- f.write(sticker.image_data) # type: ignore
46
-
47
- emoji_dict[f_id] = sticker.emoji # type: ignore
48
-
49
- codec = CodecInfo.get_file_codec(f_path)
50
- if codec == "":
51
- msg = f"Warning: Downloaded {f_path} but cannot get file codec"
52
- self.cb.put(msg)
53
- else:
54
- f_path_new = Path(f"{f_path}.{codec}")
55
- f_path.rename(f_path_new)
56
- msg = f"Downloaded {f_id}.{codec}"
57
- self.cb.put(msg)
58
-
59
- self.cb.put("update_bar")
60
-
61
- if pack.cover is not None and pack.cover.image_data is not None:
62
- cover_path = Path(self.out_dir, "cover")
63
- with open(cover_path, "wb") as f:
64
- f.write(pack.cover.image_data)
65
-
66
- cover_codec = CodecInfo.get_file_codec(cover_path)
67
- if cover_codec == "":
68
- cover_codec = "png"
69
- cover_path_new = Path(self.out_dir, f"cover.{cover_codec}")
70
- cover_path.rename(cover_path_new)
71
- self.cb.put(f"Downloaded cover.{cover_codec}")
72
-
73
- MetadataHandler.set_metadata(
74
- self.out_dir, title=pack.title, author=pack.author, emoji_dict=emoji_dict
75
- )
76
-
77
- def download_stickers_signal(self) -> Tuple[int, int]:
78
- if "signal.art" not in self.url and not self.url.startswith(
79
- "sgnl://addstickers/"
80
- ):
81
- self.cb.put("Download failed: Unrecognized URL format")
82
- return 0, 0
83
-
84
- pack_id = self.url.split("pack_id=")[1].split("&pack_key=")[0]
85
- pack_key = self.url.split("&pack_key=")[1]
86
-
87
- try:
88
- pack = anyio.run(DownloadSignal.get_pack, pack_id, pack_key)
89
- except SignalException as e:
90
- self.cb.put(f"Failed to download pack due to {repr(e)}")
91
- return 0, 0
92
-
93
- self.save_stickers(pack)
94
-
95
- return len(pack.stickers), len(pack.stickers)
96
-
97
- @staticmethod
98
- def start(
99
- opt_input: InputOption,
100
- opt_cred: Optional[CredOption],
101
- cb: CallbackProtocol,
102
- cb_return: CallbackReturn,
103
- ) -> Tuple[int, int]:
104
- downloader = DownloadSignal(opt_input, opt_cred, cb, cb_return)
105
- return downloader.download_stickers_signal()
1
+ #!/usr/bin/env python3
2
+ from pathlib import Path
3
+ from typing import Dict, Optional, Tuple
4
+
5
+ import anyio
6
+ from signalstickers_client.errors import SignalException
7
+ from signalstickers_client.models import StickerPack
8
+ from signalstickers_client.stickersclient import StickersClient
9
+
10
+ from sticker_convert.downloaders.download_base import DownloadBase
11
+ from sticker_convert.job_option import CredOption, InputOption
12
+ from sticker_convert.utils.callback import CallbackProtocol, CallbackReturn
13
+ from sticker_convert.utils.files.metadata_handler import MetadataHandler
14
+ from sticker_convert.utils.media.codec_info import CodecInfo
15
+ from sticker_convert.utils.translate import I
16
+
17
+
18
+ class DownloadSignal(DownloadBase):
19
+ # def __init__(self, *args: Any, **kwargs: Any) -> None:
20
+ # super().__init__(*args, **kwargs)
21
+
22
+ @staticmethod
23
+ async def get_pack(pack_id: str, pack_key: str) -> StickerPack:
24
+ async with StickersClient() as client:
25
+ pack = await client.get_pack(pack_id, pack_key)
26
+
27
+ return pack
28
+
29
+ def save_stickers(self, pack: StickerPack) -> None:
30
+ self.cb.put(
31
+ (
32
+ "bar",
33
+ None,
34
+ {
35
+ "set_progress_mode": "determinate",
36
+ "steps": len(pack.stickers),
37
+ },
38
+ )
39
+ )
40
+
41
+ emoji_dict: Dict[str, str] = {}
42
+ for sticker in pack.stickers:
43
+ f_id = str(sticker.id).zfill(3)
44
+ f_path = Path(self.out_dir, f_id)
45
+ with open(f_path, "wb") as f:
46
+ f.write(sticker.image_data) # type: ignore
47
+
48
+ emoji_dict[f_id] = sticker.emoji # type: ignore
49
+
50
+ codec = CodecInfo.get_file_codec(f_path)
51
+ if codec == "":
52
+ msg = I("Warning: Downloaded {} but cannot get file codec").format(
53
+ f_path
54
+ )
55
+ self.cb.put(msg)
56
+ else:
57
+ f_path_new = Path(f"{f_path}.{codec}")
58
+ f_path.rename(f_path_new)
59
+ msg = I("Downloaded {}.{}").format(f_id, codec)
60
+ self.cb.put(msg)
61
+
62
+ self.cb.put("update_bar")
63
+
64
+ if pack.cover is not None and pack.cover.image_data is not None:
65
+ cover_path = Path(self.out_dir, "cover")
66
+ with open(cover_path, "wb") as f:
67
+ f.write(pack.cover.image_data)
68
+
69
+ cover_codec = CodecInfo.get_file_codec(cover_path)
70
+ if cover_codec == "":
71
+ cover_codec = "png"
72
+ cover_path_new = Path(self.out_dir, f"cover.{cover_codec}")
73
+ cover_path.rename(cover_path_new)
74
+ self.cb.put(I("Downloaded cover.{}").format(cover_codec))
75
+
76
+ MetadataHandler.set_metadata(
77
+ self.out_dir, title=pack.title, author=pack.author, emoji_dict=emoji_dict
78
+ )
79
+
80
+ def download_stickers_signal(self) -> Tuple[int, int]:
81
+ if "signal.art" not in self.url and not self.url.startswith(
82
+ "sgnl://addstickers/"
83
+ ):
84
+ self.cb.put(I("Download failed: Unrecognized URL format"))
85
+ return 0, 0
86
+
87
+ pack_id = self.url.split("pack_id=")[1].split("&pack_key=")[0]
88
+ pack_key = self.url.split("&pack_key=")[1]
89
+
90
+ try:
91
+ pack = anyio.run(DownloadSignal.get_pack, pack_id, pack_key)
92
+ except SignalException as e:
93
+ self.cb.put(I("Failed to download pack. Reason: {}").format(repr(e)))
94
+ return 0, 0
95
+
96
+ self.save_stickers(pack)
97
+
98
+ return len(pack.stickers), len(pack.stickers)
99
+
100
+ @staticmethod
101
+ def start(
102
+ opt_input: InputOption,
103
+ opt_cred: Optional[CredOption],
104
+ cb: CallbackProtocol,
105
+ cb_return: CallbackReturn,
106
+ ) -> Tuple[int, int]:
107
+ downloader = DownloadSignal(opt_input, opt_cred, cb, cb_return)
108
+ return downloader.download_stickers_signal()
@@ -1,55 +1,56 @@
1
- #!/usr/bin/env python3
2
- from pathlib import Path
3
- from typing import Optional, Tuple
4
- from urllib.parse import urlparse
5
-
6
- import anyio
7
-
8
- from sticker_convert.downloaders.download_base import DownloadBase
9
- from sticker_convert.job_option import CredOption, InputOption
10
- from sticker_convert.utils.auth.telegram_api import BotAPI, TelegramAPI, TelethonAPI
11
- from sticker_convert.utils.callback import CallbackProtocol, CallbackReturn
12
- from sticker_convert.utils.files.metadata_handler import MetadataHandler
13
-
14
-
15
- class DownloadTelegram(DownloadBase):
16
- # def __init__(self, *args: Any, **kwargs: Any) -> None:
17
- # super().__init__(*args, **kwargs)
18
-
19
- def download_stickers_telegram(self) -> Tuple[int, int]:
20
- if not ("telegram.me" in self.url or "t.me" in self.url):
21
- self.cb.put("Download failed: Unrecognized URL format")
22
- return 0, 0
23
-
24
- return anyio.run(self.save_stickers)
25
-
26
- async def save_stickers(self) -> Tuple[int, int]:
27
- tg_api: TelegramAPI
28
- if self.input_option.endswith("telethon"):
29
- tg_api = TelethonAPI()
30
- else:
31
- tg_api = BotAPI()
32
-
33
- if self.opt_cred is None:
34
- self.cb.put("Download failed: No credentials")
35
- return 0, 0
36
-
37
- success = await tg_api.setup(self.opt_cred, False, self.cb, self.cb_return)
38
- if success is False:
39
- self.cb.put("Download failed: Invalid credentials")
40
- return 0, 0
41
-
42
- title = Path(urlparse(self.url).path).name
43
- results, emoji_dict = await tg_api.pack_dl(title, self.out_dir)
44
- MetadataHandler.set_metadata(self.out_dir, title=title, emoji_dict=emoji_dict)
45
- return sum(results.values()), len(results)
46
-
47
- @staticmethod
48
- def start(
49
- opt_input: InputOption,
50
- opt_cred: Optional[CredOption],
51
- cb: CallbackProtocol,
52
- cb_return: CallbackReturn,
53
- ) -> Tuple[int, int]:
54
- downloader = DownloadTelegram(opt_input, opt_cred, cb, cb_return)
55
- return downloader.download_stickers_telegram()
1
+ #!/usr/bin/env python3
2
+ from pathlib import Path
3
+ from typing import Optional, Tuple
4
+ from urllib.parse import urlparse
5
+
6
+ import anyio
7
+
8
+ from sticker_convert.auth.telegram_api import BotAPI, TelegramAPI, TelethonAPI
9
+ from sticker_convert.downloaders.download_base import DownloadBase
10
+ from sticker_convert.job_option import CredOption, InputOption
11
+ from sticker_convert.utils.callback import CallbackProtocol, CallbackReturn
12
+ from sticker_convert.utils.files.metadata_handler import MetadataHandler
13
+ from sticker_convert.utils.translate import I
14
+
15
+
16
+ class DownloadTelegram(DownloadBase):
17
+ # def __init__(self, *args: Any, **kwargs: Any) -> None:
18
+ # super().__init__(*args, **kwargs)
19
+
20
+ def download_stickers_telegram(self) -> Tuple[int, int]:
21
+ if not ("telegram.me" in self.url or "t.me" in self.url):
22
+ self.cb.put(I("Download failed: Unrecognized URL format"))
23
+ return 0, 0
24
+
25
+ return anyio.run(self.save_stickers)
26
+
27
+ async def save_stickers(self) -> Tuple[int, int]:
28
+ tg_api: TelegramAPI
29
+ if self.input_option.endswith("telethon"):
30
+ tg_api = TelethonAPI()
31
+ else:
32
+ tg_api = BotAPI()
33
+
34
+ if self.opt_cred is None:
35
+ self.cb.put(I("Download failed: No credentials"))
36
+ return 0, 0
37
+
38
+ success = await tg_api.setup(self.opt_cred, False, self.cb, self.cb_return)
39
+ if success is False:
40
+ self.cb.put(I("Download failed: Invalid credentials"))
41
+ return 0, 0
42
+
43
+ title = Path(urlparse(self.url).path).name
44
+ results, emoji_dict = await tg_api.pack_dl(title, self.out_dir)
45
+ MetadataHandler.set_metadata(self.out_dir, title=title, emoji_dict=emoji_dict)
46
+ return sum(results.values()), len(results)
47
+
48
+ @staticmethod
49
+ def start(
50
+ opt_input: InputOption,
51
+ opt_cred: Optional[CredOption],
52
+ cb: CallbackProtocol,
53
+ cb_return: CallbackReturn,
54
+ ) -> Tuple[int, int]:
55
+ downloader = DownloadTelegram(opt_input, opt_cred, cb, cb_return)
56
+ return downloader.download_stickers_telegram()