Metadata-Version: 2.1
Name: janda
Version: 2.0.4
Summary: A featureful Python library covers most popular doujin API
Home-page: https://github.com/sinkaroid/janda
Author: sinkaroid
Author-email: anakmancasan@gmail.com
License: MIT
Description: <div align="center">
        <img width="450" src="https://cdn.discordapp.com/attachments/952117487166705747/952942740545634344/janda.png" alt="janda!">
        
        <h4 align="center">A featureful Python library covers most popular doujin API</h4>
        
        <p align="center">
        	<a href="https://github.com/sinkaroid/janda/actions/workflows/build.yml"><img src="https://github.com/sinkaroid/janda/actions/workflows/build.yml/badge.svg"></a>
        	<a href="https://github.com/sinkaroid/janda/actions/workflows/api.yml"><img src="https://github.com/sinkaroid/janda/actions/workflows/api.yml/badge.svg"></a>
        	<a href="https://codeclimate.com/github/sinkaroid/janda/maintainability"><img src="https://api.codeclimate.com/v1/badges/90b543fc3495b932488a/maintainability"></a>
        
        
        </p>
        
        Built on minimalist dependencies to resolves and interacts with ease.
        It takes a much more dictionaries rather than just raw data, and hope will be extendable. Janda has plenty api support apart from nhentai.
        
        <a href="https://github.com/sinkaroid/janda/blob/master/CONTRIBUTING.md">Contributing</a> •
        <a href="https://sinkaroid.github.io/janda">Documentation</a> •
        <a href="https://github.com/sinkaroid/janda/issues/new/choose">Report Issues</a>
        </div>
        
        ---
        
        ## Site support
        
        - [x] nhentai API
          - Stable: using official API
        - [x] pururin API
          - Stable: using unofficial API
        - [x] hentaifox API
          - Triage: using unofficial API
        - [x] hentai2read API
          - Functional: using unofficial API
        
        > **Stable**: works well | **Triage**: has some issues | **Functional**: works normally
        
        ## Features
        
        - **Fancy**: apart from official API, Janda has own REST
        - **Easy to use**: check your intelisense
        - **Neat**: object taken is re-processed to make it actionable
        - **All-in-one**: plenty of site support
        
        ## Prerequisites
        
        - Python 3.7 or above
        - Can parse JSON
        
        ## Installation
        `pip install janda / or fork this repo`  
        
        To use specific API, you could use `from janda import Nhentai`
        
        ## Quick example
        Some methods require additional parameters, check your intelisense.
        
        ### get
        `(method) get: (book: int, safe: bool | None = None) -> Coroutine`
        ```py
        import asyncio
        from janda import Nhentai
        
        async def book():
            nh = Nhentai()
            data = await nh.get(274003)
            print(data)
        
        async def main():
            await asyncio.gather(book())
        
        asyncio.run(main())
        ```
        
        ### search
        `(tags: str, page: int = 1, popular: str = 'today') -> Coroutine`
        
        ```py
        await nh.search("jeanne alter", 1, "all")
        ```
        
        ## Documentation
        The documentation can be found [https://sinkaroid.github.io/janda](https://sinkaroid.github.io/janda)
        
        ### Nhentai
        - [`Nhentai.get(options)`](https://sinkaroid.github.io/janda/Nhentai.html)
          - Get specific doujin from nhentai
        - [`Nhentai.search(options)`](https://sinkaroid.github.io/janda/Nhentai.html)
          - Search doujin by tags / artis / character / parody or group
        - [`Nhentai.search_related(options)`](https://sinkaroid.github.io/janda/Nhentai.html)
          - Get realated book or almost alike from Id given
        - [`Nhentai.get_random()`](https://sinkaroid.github.io/janda/Nhentai.html)
          - Get random doujin from nhentai
        
        ### Pururin
        - [`Pururin.get(options)`](https://sinkaroid.github.io/janda/Pururin.html)
          - Get specific doujin from pururin
        - [`Pururin.get_random()`](https://sinkaroid.github.io/janda/Pururin.html)
          - Get random doujin from pururin
        - [`Pururin.get_random_with_query(options)`](https://sinkaroid.github.io/janda/Pururin.html)
          - Get random doujin from pururin with query
        - [`Pururin.search_by_highest_rated(options)`](https://sinkaroid.github.io/janda/Pururin.html)
          - Search highest rated doujin from pururin
        - [`Pururin.search_by_most_popular(options)`](https://sinkaroid.github.io/janda/Pururin.html) 
          - Search most popular doujin from pururin
        - [`Pururin.search_by_most_viewed(options)`](https://sinkaroid.github.io/janda/Pururin.html)
          - Search most viewed doujin from pururin
        - [`Pururin.search_by_newest(options)`](https://sinkaroid.github.io/janda/Pururin.html) 
          - Search newest doujin from pururin
        - [`Pururin.search_by_random(options)`](https://sinkaroid.github.io/janda/Pururin.html)
          - Search random doujin with query from pururin
        - [`Pururin.search_by_title(options)`](https://sinkaroid.github.io/janda/Pururin.html)
          - Search doujin by title given from pururin
        
        ### Hentai2read
        - [`Hentai2read.get(options)`](https://sinkaroid.github.io/janda/Hentai2read.html)
          - Get specific doujin from hentai2read
        - [`Hentai2read.get_random()`](https://sinkaroid.github.io/janda/Hentai2read.html)
          - Get random doujin from hentai2read
        - [`Hentai2read.search(options)`](https://sinkaroid.github.io/janda/Hentai2read.html)
          - Search a doujin from hentai2read by latest only
        
        ### Hentaifox
        - [`Hentaifox.get(options)`](https://sinkaroid.github.io/janda/Hentaifox.html)
          - Get specific doujin from hentaifox
        - [`Hentaifox.get_random()`](https://sinkaroid.github.io/janda/Hentaifox.html) 
          - Get random doujin from hentaifox
        - [`Hentaifox.search_by_latest(options)`](https://sinkaroid.github.io/janda/Hentaifox.html)
          - Search latest doujin from hentaifox
        - [`Hentaifox.search_by_popular(options)`](https://sinkaroid.github.io/janda/Hentaifox.html)
          - Search popular doujin from hentaifox
        
        ## Returns example
        `get` method will represent as **Book Object** and packed with actionable image urls
        ```js
        {
            "details": {
                "id": 274003,
                "link": "https://nhentai.net/g/274003",
                "title": {
                    "english": "(COMIC1☆15) [Koniro Kajitsu (Konka)] Setsudo no Nai Onee-chan de Gomen ne | Onee-chan is sorry she has no restraint (Fate/Grand Order) [English]",
                    "japanese": "(COMIC1☆15) [紺色果実 (紺菓)] 節度のないお姉ちゃんでごめんね♡ (Fate/Grand Order) [英訳]",
                    "pretty": "Setsudo no Nai Oneechan is sorry she has no restraint"
                },
                "upload_date": "2019-06-01 02:09:13"
            },
            "image_urls": [
                "https://i.nhentai.net/galleries/1423853/1.png",
                "https://i.nhentai.net/galleries/1423853/2.png",
                "https://i.nhentai.net/galleries/1423853/3.png",
                "https://i.nhentai.net/galleries/1423853/4.png",
                "https://i.nhentai.net/galleries/1423853/5.png",
                "https://i.nhentai.net/galleries/1423853/6.png",
                "https://i.nhentai.net/galleries/1423853/7.png",
                "https://i.nhentai.net/galleries/1423853/8.png",
                "https://i.nhentai.net/galleries/1423853/9.png",
                "https://i.nhentai.net/galleries/1423853/10.png",
                "https://i.nhentai.net/galleries/1423853/11.png",
                "https://i.nhentai.net/galleries/1423853/12.png",
                "https://i.nhentai.net/galleries/1423853/13.png",
                "https://i.nhentai.net/galleries/1423853/14.png",
                "https://i.nhentai.net/galleries/1423853/15.png",
                "https://i.nhentai.net/galleries/1423853/16.png",
                "https://i.nhentai.net/galleries/1423853/17.png",
                "https://i.nhentai.net/galleries/1423853/18.png",
                "https://i.nhentai.net/galleries/1423853/19.png",
                "https://i.nhentai.net/galleries/1423853/20.png",
                "https://i.nhentai.net/galleries/1423853/21.png",
                "https://i.nhentai.net/galleries/1423853/22.png",
                "https://i.nhentai.net/galleries/1423853/23.png",
                "https://i.nhentai.net/galleries/1423853/24.png",
                "https://i.nhentai.net/galleries/1423853/25.png",
                "https://i.nhentai.net/galleries/1423853/26.png"
            ],
            "language": "english",
            "num_favorites": 6164,
            "num_pages": 26,
            "scanlator": "",
            "tags": [
                "english",
                "translated",
                "fate grand order",
                "tomoe gozen",
                "koniro kajitsu",
                "konka",
                "shotacon",
                "sole male",
                "big breasts",
                "footjob",
                "horns",
                "lactation",
                "lingerie",
                "oni",
                "sole female",
                "stockings",
                "doujinshi",
                "gudao",
                "schoolgirl uniform",
                "kissing",
                "leg lock",
                "breast feeding",
                "x-ray",
                "unusual pupils"
            ],
            "thumbnail_urls": [
                "https://i.nhentai.net/galleries/1423853/1t.png",
                "https://i.nhentai.net/galleries/1423853/2t.png",
                "https://i.nhentai.net/galleries/1423853/3t.png",
                "https://i.nhentai.net/galleries/1423853/4t.png",
                "https://i.nhentai.net/galleries/1423853/5t.png",
                "https://i.nhentai.net/galleries/1423853/6t.png",
                "https://i.nhentai.net/galleries/1423853/7t.png",
                "https://i.nhentai.net/galleries/1423853/8t.png",
                "https://i.nhentai.net/galleries/1423853/9t.png",
                "https://i.nhentai.net/galleries/1423853/10t.png",
                "https://i.nhentai.net/galleries/1423853/11t.png",
                "https://i.nhentai.net/galleries/1423853/12t.png",
                "https://i.nhentai.net/galleries/1423853/13t.png",
                "https://i.nhentai.net/galleries/1423853/14t.png",
                "https://i.nhentai.net/galleries/1423853/15t.png",
                "https://i.nhentai.net/galleries/1423853/16t.png",
                "https://i.nhentai.net/galleries/1423853/17t.png",
                "https://i.nhentai.net/galleries/1423853/18t.png",
                "https://i.nhentai.net/galleries/1423853/19t.png",
                "https://i.nhentai.net/galleries/1423853/20t.png",
                "https://i.nhentai.net/galleries/1423853/21t.png",
                "https://i.nhentai.net/galleries/1423853/22t.png",
                "https://i.nhentai.net/galleries/1423853/23t.png",
                "https://i.nhentai.net/galleries/1423853/24t.png",
                "https://i.nhentai.net/galleries/1423853/25t.png",
                "https://i.nhentai.net/galleries/1423853/26t.png"
            ]
        }
        ```
        
        Otherwise `search` will return 25 **List Object** of search results.
        ```js
        [
            {
                "id": 394795,
                "language": "speechless",
                "link": "https://nhentai.net/g/394795",
                "num_favorites": 962,
                "num_pages": 5,
                "tags": [
                    "big breasts",
                    "swimsuit",
                    "mmf threesome",
                    "group",
                    "uncensored",
                    "nakadashi",
                    "dark skin",
                    "bikini",
                    "x-ray",
                    "double penetration",
                    "blowjob",
                    "muscle",
                    "collar",
                    "body writing",
                    "doujinshi",
                    "speechless",
                    "text cleaned",
                    "fate grand order",
                    "sole female",
                    "jeanne alter",
                    "yanje"
                ],
                "title": {
                    "english": "[Yanje] Jeanne d'Arc Alter (FGO) [Textless]",
                    "japanese": "",
                    "pretty": "Jeanne d'Arc Alter"
                },
                "upload_date": "2022-03-08 01:00:47"
            },
            {
                "id": "394794",
                "language": "japanese",
                "link": "https://nhentai.net/g/394794",
                "num_favorites": 1103,
                "num_pages": 5,
                "tags": [
                    "big breasts",
                    "swimsuit",
                    "japanese",
                    "mmf threesome",
                    "group",
                    "uncensored",
                    "nakadashi",
                    "dark skin",
                    "bikini",
                    "x-ray",
                    "double penetration",
                    "blowjob",
                    "muscle",
                    "collar",
                    "body writing",
                    "doujinshi",
                    "fate grand order",
                    "sole female",
                    "jeanne alter",
                    "yanje"
                ],
                "title": {
                    "english": "[Yanje] Jeanne d'Arc Alter (FGO) [Japanese]",
                    "japanese": "",
                    "pretty": "Jeanne d'Arc Alter"
                },
                "upload_date": "2022-03-07 23:32:20"
            }
        ]
        ```
        
        ## Legal
        This tool can be freely copied, modified, altered, distributed without any attribution whatsoever. However, if you feel
        like this tool deserves an attribution, mention it. It won't hurt anybody :)
        
        Please, read the [license terms](LICENSE). Don't worry, it can be read in less than 30 seconds, unless you have some
        sort of reading disability - in that case, I'm wondering why you're still reading this text. Really. Stop. Please. I
        mean, seriously. Why are you still reading?
        
        ## Pronunciation
        [`id_ID`](https://www.localeplanet.com/java/id-ID/index.html) • **/jan·da/** — wanita yang menjanda karena ditinggal suaminya; _(?)_ the mascot is tomoe gozen FGO
Keywords: doujin,library,wrapper,nhentai,pururin,hentaifox,hentai2read
Platform: UNKNOWN
Classifier: Framework :: AsyncIO
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Natural Language :: English
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 3.7
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Topic :: Software Development :: Libraries
Classifier: Topic :: Software Development :: Libraries :: Application Frameworks
Classifier: Topic :: Software Development :: Libraries :: Python Modules
Description-Content-Type: text/markdown
