Metadata-Version: 1.2
Name: PyFunceble-dev
Version: 4.0.0b13
Summary: The tool to check the availability or syntax of domain, IP or URL.
Home-page: https://github.com/funilrys/PyFunceble
Author: funilrys
Author-email: contact@funilrys.com
License: Apache 2.0
Description: .. image:: https://raw.githubusercontent.com/PyFunceble/logo/dev/Green/HD/RM.png
        
        The tool to check the availability or syntax of domain, IP or URL
        -----------------------------------------------------------------
        
        .. image:: https://img.shields.io/badge/code%20style-black-000000.png
            :target: https://github.com/ambv/black
        .. image:: https://coveralls.io/repos/github/funilrys/PyFunceble/badge.png?branch=dev
            :target: https://coveralls.io/github/funilrys/PyFunceble?branch=dev
        .. image:: https://img.shields.io/github/license/funilrys/PyFunceble.png
            :target: https://github.com/funilrys/PyFunceble/blob/dev/LICENSE
        .. image:: https://img.shields.io/pypi/v/pyfunceble-dev.png
            :target: https://pypi.org/project/pyfunceble-dev
        .. image:: https://img.shields.io/github/issues/funilrys/PyFunceble.png
            :target: https://github.com/funilrys/PyFunceble/issues
        .. image:: https://pepy.tech/badge/pyfunceble-dev
            :target: https://pepy.tech/project/pyfunceble-dev
        .. image:: https://pepy.tech/badge/pyfunceble-dev/month
            :target: https://pepy.tech/project/pyfunceble-dev
        .. image:: https://pepy.tech/badge/pyfunceble-dev/week
            :target: https://pepy.tech/project/pyfunceble-dev
        
        Welcome to PyFunceble!
        
        PyFunceble  is the little sister of `Funceble`_ which was archived on 13th March
        2018. In March 2018, because Funceble was starting to become a huge unmanageable
        script, I - Nissar Chababy aka `@funilrys`_ - decided to make it a Python tool
        for the purpose of extending my Python knowledge. It was meant for my own use case.
        
        Back then, my problem was that I didn't want to download a huge hosts file
        knowing that most of the entries do not exist anymore. That's how Py-Funceble
        started.
        
        My objective - now - through this tool is to provide a tool and a Python API
        which helps the world test the availability of domains, IPs and URL through
        the gathering and interpretation of information from existing tools or
        protocols like WHOIS records, DNS lookup, or even HTTP status codes.
        
        The base of this tool was my idea.
        But as with many Open Source (related) projects, communities or
        individuals, we evolve with the people we meet, exchange with or just discuss
        with privately. PyFunceble was and is still not an exception to that.
        
        My main idea was to check the availability of domains in hosts files.
        But 3 years later, PyFunceble is now capable of a lot including:
        
        - The testing of domains, IPs, and URLs.
        - The checking of the syntax or reputation of a domain, IPs, and URLs.
        - The decoding of AdBlock filters, RPZ records, or plain files before a test
          from the CLI.
        
        PyFunceble evolved and will probably continue to evolve with the time
        and the people using it.
        
        In June 2020, The PyFunceble-dev PyPI package - which gets everything as
        soon as possible compared to the PyFunceble (stable) package - reached 1 million
        total downloads. I never noticed it until I was reached by someone informing me
        of it. But, I was shocked.
        
        I never thought that something I built from A to Z in my free time will ever
        reach that point.
        I was thankful to that nice person for informing me of it. But at the same time
        concerned about PyFunceble and how it will evolve. That's why I started the
        development of PyFunceble 4.0.0. My idea as I was refactoring it was to provide
        a better Python API and implementation of my core ideas along with a better
        incorporation and extension capability.
        Indeed, in the last few years, I was so much obsessed with the CLI that I
        really never wrote each component individually. They were all dependent - if
        not part of - the CLI. With 4.0.0, you can now import one of the components
        of PyFunceble and start straight away. No real need to play with the
        configuration unless you want something very specific.
        That's how I see the future of PyFunceble.
        
        As of today, PyFunceble is running actively - if not daily - within several
        servers, laptops, PCs, and Raspberry Pis. It is even used - thanks to our
        auto continue dataset and component - with CI engines like GitHub Action,
        Travis CI, and GitLab CI.
        
        PyFunceble is my tool. But it is indirectly also become yours.
        Therefore, I invite you to let me know how you use PyFunceble or simply open a
        discussion - or join an existing one - about anything you do with PyFunceble.
        But also anything that you - would - like - or dislike - in PyFunceble.
        
        Happy testing with PyFunceble!
        
        ___________________________________________
        
        Documentation as the place to be!
        ---------------------------------
        
        Want to know more about details **PyFunceble**?
        I invite you to read the documentation at https://pyfunceble.readthedocs.io/en/dev/!
        
        Want a local copy? I get you covered!
        
        Simply run the following and enjoy the documentation!
        
        ::
        
            $ pip install --user -r requirements.docs.txt # Install dependencies.
            $ cd docs/
            $ make clean html
            $ palemoon _build/html/index.html # palemoon or whatever browser you use.
        
        .. note::
            You are also invited to submit changes and improvement to the documentation
            through a new Pull Request.
        
        ___________________________________________
        
        What can PyFunceble do?
        -----------------------
        
        - Test the availability of a domain.
        - Test the availability of an IPv4.
        - Test the availability of an IPv6.
        - Test the availability of a URL.
        - Test the availability of a domain/DNS name in a private or local network.
        - Test the availability of an IPv4 in a private or local network.
        - Test the availability of an IPv6 in a private or local network.
        - Test the availability of a URL in a private or local network.
        - Test the syntax of a domain.
        - Test the syntax of an IPv4.
        - Test the syntax of an IPv6.
        - Test the syntax of a URL.
        - Test against the AlienVault's reputation of an IPv4.
        - Test of domain or IP which are present into an Adblock formatted file.
        - Test from a given raw link.
        - Test using multiprocessing (from CLI only).
        - Save test result(s) in file(s) (hosts file, plain text and/or JSON format).
        - Save test result(s) in a MySQL or MariaDB database.
        - Show test result(s) on screen.
        - Show percentage of each status (:code:`ACTIVE`, :code:`INACTIVE`,
          :code:`INVALID`)
        - Sort outputs hierarchically.
        - "Mining" of domain or IP which are related to the tested element.
        - Auto-continuation of tests in case of system crash or script stop.
        - Filtering of a file content.
        
          - This feature will let us for example test all blogspot domain of the given
            file no matter the content of the file.
        
        - Set the user-agent to use for the tests.
        - Give some analytic depending of the HTTP status code (:code:`ACTIVE`,
          :code:`POTENTIALLY_ACTIVE`, :code:`POTENTIALLY_INACTIVE`, :code:`SUSPICIOUS`).
        - Retest overtime of :code:`INACTIVE` and :code:`INVALID` domains.
        - Print the execution time on screen and file.
        - Customisation of the different option via command-line arguments or
          configuration file.
        - Continuous tests under Travis CI or GitLab CI/CI
        
          - ... with the help of an auto saving and database system.
          - Set the branch to push the result to. For the autosaving system.
          - Set the minimal time before we autosave in order to avoid CI/CD limitation.
          - Set a command to execute at the end of the test.
          - Set the commit message for the autosaving system.
        
        - ... and a lot more!
        
        .. image:: https://github.com/PyFunceble/gifs/raw/dev/domain.gif
            :target: https://github.com/PyFunceble/gifs/raw/dev/domain.gif
        
        ___________________________________________
        
        Supporting the project
        ----------------------
        
        
        `PyFunceble`_, `Dead-Hosts`_, and all other analog projects are powered by free
        time and a lot of coffee!
        
        This project helps you and/or you like it?
        
        GitHub Sponsor
        """"""""""""""
        `@funilrys`_ is part of the GitHub Sponsor program!
        
        *GitHub will match all donation for the coming months!*
        
        .. image:: https://github.com/PyFunceble/logo/raw/master/pyfunceble_github.png
            :target: https://github.com/sponsors/funilrys
            :height: 70px
        
        `Sponsor me`_!
        
        Ko-Fi
        """""
        
        Don't want to use the GitHub Sponsor program ?
        Single donations are welcome too!
        
        .. image:: https://az743702.vo.msecnd.net/cdn/kofi3.png
            :target: https://ko-fi.com/V7V3EH2Y
            :height: 70px
        
        `Buy me a coffee`_!
        
        ___________________________________________
        
        Contributors
        ------------
        
        Thanks to those awesome peoples for their awesome and crazy idea(s),
        contribution(s) and or issue report which made or make `PyFunceble`_ a better tool.
        
        ::
        
            _______ _                 _          _                              _
           |__   __| |               | |        | |                            | |
              | |  | |__   __ _ _ __ | | _____  | |_ ___    _   _  ___  _   _  | |
              | |  | '_ \ / _` | '_ \| |/ / __| | __/ _ \  | | | |/ _ \| | | | | |
              | |  | | | | (_| | | | |   <\__ \ | || (_) | | |_| | (_) | |_| | |_|
              |_|  |_| |_|\__,_|_| |_|_|\_\___/  \__\___/   \__, |\___/ \__,_| (_)
                                                             __/ |
                                                            |___/
        
        -   Daniel - `@dnmTX`_
        -   hawkeye116477 - `@hawkeye116477`_
        -   Imre Kristoffer Eilertsen - `@DandelionSprout`_
        -   jawz101 - `@jawz101`_
        -   kowith337 - `@kowith337`_
        -   Mitchell Krog - `@mitchellkrogza`_
        -   NeolithEra - `@NeolithEra`_
        -   Odyseus - `@Odyseus`_
        -   opav - `@opav`_
        -   Reza Rizqullah - `@ybreza`_
        -   sjhgvr - `@sjhgvr`_
        -   ScriptTiger - `@ScriptTiger`_
        -   speedmann - `@speedmann`_
        -   spirillen - `@spirillen`_
        -   The Unknown - `@AnonymousPoster`_
        -   WaLLy3K - `@WaLLy3K`_
        -   xxcriticxx - `@xxcriticxx`_
        -   ZeroDot1 - `@ZeroDot1`_
        
        ___________________________________________
        
        Special Thanks
        --------------
        
        Thanks to those awesome organization(s), tool(s) and or people(s) for
        
        *   Their awesome documentation
        *   Their awesome repository
        *   Their awesome tool/software/source code
        *   Their breaking reports
        *   Their contributions
        *   Their current work/purpose
        *   Their promotion of Py-Funceble
        *   Their support
        *   Their testings reports
        
        which helped and/or still help me build, test and or make `PyFunceble`_ a better tool.
        
        ::
        
             _______ _                 _          _                              _
            |__   __| |               | |        | |                            | |
               | |  | |__   __ _ _ __ | | _____  | |_ ___    _   _  ___  _   _  | |
               | |  | '_ \ / _` | '_ \| |/ / __| | __/ _ \  | | | |/ _ \| | | | | |
               | |  | | | | (_| | | | |   <\__ \ | || (_) | | |_| | (_) | |_| | |_|
               |_|  |_| |_|\__,_|_| |_|_|\_\___/  \__\___/   \__, |\___/ \__,_| (_)
                                                              __/ |
                                                             |___/
        
        -   Adam Warner - `@PromoFaux`_
        -   Adblock Plus - `@adblockplus`_
        -   asciinema - `@asciinema`_
        -   Bob Halley - `@rthalley`_ (`DNSPython`_)
        -   Chris Griffith - `@cdgriffith`_ (`Box`_)
        -   Daniel - `@dnmTX`_
        -   Jonathan Hartley - `@tartley`_ (`colorama`_)
        -   `IANA`_ - `ICANN`_ (`Root Zone Database`_)
        -   Kenneth Reitz - `@kennethreitz`_ (`requests`_)
        -   Mitchell Krog - `@mitchellkrogza`_
        -   Mohammad Fares - `@faressoft`_ (`Terminalizer`_)
        -   Pi-Hole - `@pi-hole`_
        -   Public Suffix List - `@publicsuffix`_
        -   Reza Rizqullah - `@ybreza`_
        -   Saurabh Kumar - `@theskumar`_ (`python-dotenv`_)
        -   ScriptTiger - `@ScriptTiger`_
        -   SMed79 - `@SMed79`_
        -   spirillen - `@spirillen`_
        -   The YAML Project - `@yaml`_ (`pyyaml`_)
        -   `yWorks`_ - (`yEd Graph Editor`_)
        
        ___________________________________________
        
        License
        -------
        ::
        
            Copyright 2017, 2018, 2019, 2020, 2021 Nissar Chababy
        
            Licensed under the Apache License, Version 2.0 (the "License");
            you may not use this file except in compliance with the License.
            You may obtain a copy of the License at
        
                http://www.apache.org/licenses/LICENSE-2.0
        
            Unless required by applicable law or agreed to in writing, software
            distributed under the License is distributed on an "AS IS" BASIS,
            WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
            See the License for the specific language governing permissions and
            limitations under the License.
        
        .. _Box: https://github.com/cdgriffith/Box
        .. _colorama: https://github.com/tartley/colorama
        .. _Dead-Hosts: https://github.com/dead-hosts
        .. _DNSPython: https://github.com/rthalley/dnspython
        .. _Funceble: https://github.com/funilrys/funceble
        .. _IANA: https://www.iana.org/
        .. _ICANN: https://www.icann.org/
        .. _PyFunceble: https://github.com/funilrys/PyFunceble
        .. _python-dotenv: https://github.com/theskumar/python-dotenv
        .. _pyyaml: https://github.com/yaml/pyyaml
        .. _requests: https://github.com/kennethreitz/requests
        .. _Root Zone Database: https://www.iana.org/domains/root/db
        .. _Terminalizer: https://github.com/faressoft/terminalizer
        .. _yEd Graph Editor: https://www.yworks.com/products/yed
        .. _yWorks: https://www.yworks.com/company
        
        .. _@adblockplus: https://github.com/adblockplus
        .. _@AnonymousPoster: https://github.com/AnonymousPoster
        .. _@asciinema: https://github.com/asciinema
        .. _@cdgriffith: https://github.com/cdgriffith
        .. _@DandelionSprout: https://github.com/DandelionSprout
        .. _@dnmTX: https://github.com/dnmTX
        .. _@faressoft: https://github.com/faressoft
        .. _@funilrys: https://github.com/funilrys
        .. _@hawkeye116477: https://github.com/hawkeye116477
        .. _@jawz101: https://github.com/jawz101
        .. _@kennethreitz: https://github.com/kennethreitz
        .. _@kowith337: https://github.com/kowith337
        .. _@mitchellkrogza: https://github.com/mitchellkrogza
        .. _@NeolithEra: https://github.com/NeolithEra
        .. _@Odyseus: https://github.com/Odyseus
        .. _@opav: https://github.com/opav
        .. _@pi-hole: https://github.com/pi-hole/pi-hole
        .. _@PromoFaux: https://github.com/PromoFaux
        .. _@publicsuffix: https://github.com/publicsuffix
        .. _@rthalley: https://github.com/rthalley
        .. _@ScriptTiger: https://github.com/ScriptTiger
        .. _@sjhgvr: https://github.com/sjhgvr
        .. _@SMed79: https://github.com/SMed79
        .. _@speedmann: https://github.com/speedmann
        .. _@spirillen: https://github.com/spirillen
        .. _@tartley: https://github.com/tartley
        .. _@theskumar: https://github.com/theskumar
        .. _@Wally3K: https://github.com/WaLLy3K
        .. _@xxcriticxx: https://github.com/xxcriticxx
        .. _@yaml: https://github.com/yaml
        .. _@ybreza: https://github.com/ybreza
        .. _@ZeroDot1: https://github.com/ZeroDot1
        
        .. _documentation for more GIF: https://pyfunceble.readthedocs.io/en/dev/in-action.html
        .. _Sponsor me: https://github.com/sponsors/funilrys
        .. _Buy me a coffee: https://ko-fi.com/V7V3EH2Y
        
Keywords: PyFunceble,syntax-checker,reputation-checker,availability-checker
Platform: any
Classifier: Environment :: Console
Classifier: Topic :: Internet
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: License :: OSI Approved
Requires-Python: >=3.6, <4
