blob: 2f388024ce436876e483b6d685c01e0a9ff2ae6f (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
|
# -*- coding: utf-8 -*-
# Copyright 2018-2025 Mike Fährmann
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License version 2 as
# published by the Free Software Foundation.
"""Extractors for https://www.idolcomplex.com/"""
from . import sankaku
BASE_PATTERN = (r"(?:https?://)?(?:www\.)?"
r"idol(?:\.sankaku)?complex\.com"
r"(?:/[a-z]{2}(?:[-_][A-Z]{2})?)?")
class IdolcomplexBase():
"""Base class for idolcomplex extractors"""
category = "idolcomplex"
root = "https://www.idolcomplex.com"
cookies_domain = ".idolcomplex.com"
def _init(self):
self.api = sankaku.SankakuAPI(self)
self.api.ROOT = "https://i.sankakuapi.com"
self.api.headers["Origin"] = self.root
class IdolcomplexTagExtractor(IdolcomplexBase, sankaku.SankakuTagExtractor):
"""Extractor for idolcomplex tag searches"""
pattern = BASE_PATTERN + r"(?:/posts)?/?\?([^#]*)"
example = "https://www.idolcomplex.com/en/posts?tags=TAGS"
class IdolcomplexPoolExtractor(IdolcomplexBase, sankaku.SankakuPoolExtractor):
"""Extractor for idolcomplex pools"""
pattern = BASE_PATTERN + r"/pools?/(?:show/)?(\w+)"
example = "https://www.idolcomplex.com/en/pools/0123456789abcdef"
class IdolcomplexPostExtractor(IdolcomplexBase, sankaku.SankakuPostExtractor):
"""Extractor for individual idolcomplex posts"""
pattern = BASE_PATTERN + r"/posts?(?:/show)?/(\w+)"
example = "https://www.idolcomplex.com/en/posts/0123456789abcdef"
|