stash
This commit is contained in:
72
stash/config/scrapers/community/CzechHunter/CzechHunter.py
Normal file
72
stash/config/scrapers/community/CzechHunter/CzechHunter.py
Normal file
@@ -0,0 +1,72 @@
|
||||
import json
|
||||
import sys
|
||||
from typing import Any
|
||||
from py_common import log
|
||||
from py_common.util import dig, replace_all
|
||||
from AyloAPI.scrape import (
|
||||
gallery_from_url,
|
||||
scraper_args,
|
||||
scene_from_url,
|
||||
scene_search,
|
||||
scene_from_fragment,
|
||||
performer_from_url,
|
||||
performer_from_fragment,
|
||||
performer_search,
|
||||
movie_from_url,
|
||||
)
|
||||
|
||||
|
||||
def czechhunter(obj: Any, _) -> Any:
|
||||
replacement = None
|
||||
match dig(obj, "studio", "name"):
|
||||
case "Czech Hunter":
|
||||
replacement = "czechhunter.com"
|
||||
case "Debt Dandy":
|
||||
replacement = "debtdandy.com"
|
||||
case "Dirty Scout":
|
||||
replacement = "dirtyscout.com"
|
||||
case _:
|
||||
# This will never be correct, but I don't see a better way to handle it
|
||||
replacement = "bigstr.com"
|
||||
|
||||
# Replace the studio name in all URLs
|
||||
fixed = replace_all(obj, "url", lambda x: x.replace("bigstr.com", replacement))
|
||||
|
||||
return fixed
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
domains = [
|
||||
"czechhunter",
|
||||
"debtdandy",
|
||||
"dirtyscout",
|
||||
]
|
||||
op, args = scraper_args()
|
||||
result = None
|
||||
|
||||
match op, args:
|
||||
case "gallery-by-url" | "gallery-by-fragment", {"url": url} if url:
|
||||
result = gallery_from_url(url, postprocess=czechhunter)
|
||||
case "scene-by-url", {"url": url} if url:
|
||||
result = scene_from_url(url, postprocess=czechhunter)
|
||||
case "scene-by-name", {"name": name} if name:
|
||||
result = scene_search(name, search_domains=domains, postprocess=czechhunter)
|
||||
case "scene-by-fragment" | "scene-by-query-fragment", args:
|
||||
result = scene_from_fragment(
|
||||
args, search_domains=domains, postprocess=czechhunter
|
||||
)
|
||||
case "performer-by-url", {"url": url}:
|
||||
result = performer_from_url(url, postprocess=czechhunter)
|
||||
case "performer-by-fragment", args:
|
||||
result = performer_from_fragment(args)
|
||||
case "performer-by-name", {"name": name} if name:
|
||||
result = performer_search(
|
||||
name, search_domains=domains, postprocess=czechhunter
|
||||
)
|
||||
case "movie-by-url", {"url": url} if url:
|
||||
result = movie_from_url(url, postprocess=czechhunter)
|
||||
case _:
|
||||
log.error(f"Operation: {op}, arguments: {json.dumps(args)}")
|
||||
sys.exit(1)
|
||||
|
||||
print(json.dumps(result))
|
||||
84
stash/config/scrapers/community/CzechHunter/CzechHunter.yml
Normal file
84
stash/config/scrapers/community/CzechHunter/CzechHunter.yml
Normal file
@@ -0,0 +1,84 @@
|
||||
name: Czech Hunter (BigStr)
|
||||
# requires: py_common, AyloAPI
|
||||
# scrapes: Czech Hunter, Debt Dandy, Dirty Scout
|
||||
galleryByURL:
|
||||
- action: script
|
||||
url:
|
||||
- czechhunter.com/scene/
|
||||
- debtdandy.com/scene/
|
||||
- dirtyscout.com/scene/
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- gallery-by-url
|
||||
galleryByFragment:
|
||||
action: script
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- gallery-by-fragment
|
||||
sceneByURL:
|
||||
- action: script
|
||||
url:
|
||||
- czechhunter.com/scene/
|
||||
- debtdandy.com/scene/
|
||||
- dirtyscout.com/scene/
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- scene-by-url
|
||||
sceneByFragment:
|
||||
action: script
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- scene-by-fragment
|
||||
sceneByName:
|
||||
action: script
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- scene-by-name
|
||||
sceneByQueryFragment:
|
||||
action: script
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- scene-by-query-fragment
|
||||
performerByName:
|
||||
action: script
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- performer-by-name
|
||||
performerByURL:
|
||||
- action: script
|
||||
url:
|
||||
- czechhunter.com/model/
|
||||
- debtdandy.com/model/
|
||||
- dirtyscout.com/model/
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- performer-by-url
|
||||
performerByFragment:
|
||||
action: script
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- performer-by-fragment
|
||||
movieByURL:
|
||||
- action: script
|
||||
url:
|
||||
- czechhunter.com/scene/
|
||||
- debtdandy.com/scene/
|
||||
- dirtyscout.com/scene/
|
||||
# Since scenes link to the movie we can scrape movies from scenes
|
||||
- czechhunter.com/movie/
|
||||
- debtdandy.com/movie/
|
||||
- dirtyscout.com/movie/
|
||||
script:
|
||||
- python
|
||||
- CzechHunter.py
|
||||
- movie-by-url
|
||||
# Last Updated January 14, 2024
|
||||
10
stash/config/scrapers/community/CzechHunter/manifest
Executable file
10
stash/config/scrapers/community/CzechHunter/manifest
Executable file
@@ -0,0 +1,10 @@
|
||||
id: CzechHunter
|
||||
name: Czech Hunter (BigStr)
|
||||
metadata: {}
|
||||
version: c2abfdf
|
||||
date: "2024-02-03 17:45:33"
|
||||
requires: []
|
||||
source_repository: https://stashapp.github.io/CommunityScrapers/stable/index.yml
|
||||
files:
|
||||
- CzechHunter.yml
|
||||
- CzechHunter.py
|
||||
Reference in New Issue
Block a user