The tool to check the availability or syntax of domain, IP or URL
PyFunceble aims to provide an accurate availability check through the usage of multiple sources which are for example - to only list a few:
- the WHOIS record(s).
- the DNS record(s).
- the HTTP status code.
PyFunceble can be included in your existing project through:
- its standard built-in CLI implementation.
- its Python API.
- the PyFunceble web-worker project that provides the core functionalities of PyFunceble behind a web API.
The PyFunceble CLI can test from a hosts file, a plain list of subjects, an AdBlock filter list or even an RPZ record.
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 mechanism - with CI engines like GitHub Action, Travis CI, or GitLab CI.
Happy testing with PyFunceble!
Installation
pip
$ pip install --upgrade pyfunceble $ pyfunceble --version
docker
$ docker pull pyfunceble/pyfunceble $ docker run -it pyfunceble/pyfunceble --version
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.
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!
Ko-Fi
Don't want to use the GitHub Sponsor program ? Single donations are welcome too!
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.
_______ _ _ _ _ |__ __| | | | | | | | | | | |__ __ _ _ __ | | _____ | |_ ___ _ _ ___ _ _ | | | | | '_ \ / _` | '_ \| |/ / __| | __/ _ \ | | | |/ _ \| | | | | | | | | | | | (_| | | | | <\__ \ | || (_) | | |_| | (_) | |_| | |_| |_| |_| |_|\__,_|_| |_|_|\_\___/ \__\___/ \__, |\___/ \__,_| (_) __/ | |___/
- avatartw - @avatartw
- Avinash Reddy - @AvinashReddy3108
- BigDargon - @bigdargon
- Daniel - @dnmTX
- gwarser - @gwarser
- Haris Gušić - @veracioux
- hawkeye116477 - @hawkeye116477
- Human Being - @T145
- Imre Kristoffer Eilertsen - @DandelionSprout
- jawz101 - @jawz101
- Josenilson Ferreira da SIlva - @Nilsonfsilva
- keczuppp - @keczuppp
- kowith337 - @kowith337
- Mitchell Krog - @mitchellkrogza
- NeolithEra - @NeolithEra
- Odyseus - @Odyseus
- opav - @opav
- Reza Rizqullah - @ybreza
- rusty-snake - @rusty-snake
- ScriptTiger - @ScriptTiger
- sjhgvr - @sjhgvr
- speedmann - @speedmann
- spirillen - @spirillen
- The Unknown - @AnonymousPoster
- WaLLy3K - @WaLLy3K
- xxcriticxx - @xxcriticxx
- Yuki2718 - @Yuki2718
- Zachinquarantine - @Zachinquarantine
- 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)
- Iterative (shtab)
- 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, 2022, 2023 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.