Skip to main content

The tool to check the availability or syntax of domain, IP or URL.

Project description

image

The tool to check the availability or syntax of domain, IP or URL

image image image image image

image image image

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!

image

Table of Content

Installation

Packages & Versioning

This project follows the semver standard.

PyFunceble is distributed through 2 packages that reflects our 2 main development and deployment branches. Both packages are stable but with 2 different phylosophies. Therefore, the choice is up to you.

The 2 packages are pyfunceble and pyfunceble-dev.

If you want a stable but mature, and slowly updating package, you should install the pyfunceble package. It reflects the master branch which only get updated once the new features and bugfixes of pyfunceble-dev are tested long enough to be considered mature.

On the other hand, if you want a stable but fast updating package, you should install the pyfunceble-dev package. It reflects the dev branch which get updated frequently to allow the community to provide feedbacks as soon as possible.

Recommendation: For most people the pyfunceble package should be sufficient. But if you want to help the community or always want to have the latest features and bugfix as soon as possible, you should prefer the pyfunceble-dev package.

PyPi - Python Package Index

Installing from the Python Package Index is for most people the prefered one - after the OS specific packages (see below).

Here is an overview of the packages and where they are hosted.

Package PyPi Link
pyfunceble https://pypi.org/project/PyFunceble
pyfunceble-dev https://pypi.org/project/PyFunceblee-dev

Optional Dependencies

The following dependencies are optional and can be installed if you need them.

Dependency Description
all Install all functional dependencies. Basically all but dev, test and docs. When a binary and non binary version is available, the binary version is installed.
full Install all dependencies listed below. When a binary and non binary version is available, the binary version is installed.
psql, postgresql Build and install the dependencies required to interact with PostgreSQL.
psql-binary, postgresql-binary Install the dependencies required to interact with PostgreSQL - from binary.
docs Install the dependencies required to build the documentation.
test Install the dependencies required to run the tests.
dev Install the dependencies required to develop PyFunceble.

They are intended to be installed through the following syntax:

pip3 install --user {pkg}[{dependency}]

As an example if you want to install the docs and test dependencies, you should run:

pip3 install --user pyfunceble[docs,test]

pyfunceble

You can install the pyfunceble through pip3:

pip3 install --user pyfunceble

pyfunceble-dev

You can install the pyfunceble-dev package through pip3:

pip3 install --user pyfunceble-dev

If you want to help and use the unstable pre-releases, you should install with the --pre argument.

pip3 install --user --pre pyfunceble-dev

Container Image Registry

Installing from a Container Image Registry is the way to go if you are in a hurry or always want the best from the beat without having to look if an update is available. :smile:

Here is an overview of the packages and where they are hosted.

Host Package Link
Docker Hub pyfunceble https://hub.docker.com/r/pyfunceble/pyfunceble
Docker Hub pyfunceble-dev https://hub.docker.com/r/pyfunceble/pyfunceble-dev

pyfunceble

Docker Hub

You can install the pyfunceble image from Docker Hub through docker:

docker pull pyfunceble/pyfunceble

pyfunceble-dev

Docker Hub

You can install the pyfunceble-dev image from Docker Hub through docker:

docker pull pyfunceble/pyfunceble-dev

ArchLinux

For the pyfunceble package:

aur-helper -S pyfunceble
pyfunceble --version

For the pyfunceble-dev package:

aur-helper -S pyfunceble-dev
pyfunceble --version

Git Repository

Installing from a Git Repository with pip3 is not recommended for general user as you will get the latest development patches even before they get published. But if you are one of those who always want to be in sync with the latest development patches, this is probably for you.

Here is an overview of the packages and where they are hosted.

Host Package Repository
GitHub pyfunceble git+https://github.com/funilrys/PyFunceble.git@master#egg=PyFunceble
GitHub pyfunceble-dev git+https://github.com/funilrys/PyFunceble.git@dev#egg=PyFunceble-dev
GitLab pyfunceble git+https://gitlab.com/funilrys/PyFunceble.git@master#egg=PyFunceble
GitLab pyfunceble-dev git+https://gitlab.com/funilrys/PyFunceble.git@dev#egg=PyFunceble-dev

pyfunceble

GitHub

You can install the pyfunceble package from GitHub through pip3:

pip3 install --user git+https://github.com/funilrys/PyFunceble.git@master#egg=PyFunceble

GitLab

You can install the pyfunceble package from GitLab through pip3:

pip3 install --user git+https://gitlab.com/funilrys/PyFunceble.git@master#egg=PyFunceble

pyfunceble-dev

GitHub

You can install the pyfunceble-dev package from GitHub through pip3:

pip3 install --user git+https://github.com/funilrys/PyFunceble.git@dev#egg=PyFunceble-dev

GitLab

You can install the pyfunceble-dev package from GitLab through pip3:

pip3 install --user git+https://gitlab.com/funilrys/PyFunceble.git@dev#egg=PyFunceble-dev

From Source

Installing from source is not recommended at all as you may need to keep the repository up-to-date by yourself.

Here is an overview of the packages and where they are hosted.

Host Package Branch Repository
GitHub pyfunceble master https://github.com/funilrys/PyFunceble/tree/master
GitHub pyfunceble-dev dev https://github.com/funilrys/PyFunceble/tree/dev
GitLab pyfunceble master https://gitlab.com/funilrys/PyFunceble/tree/master
GitLab pyfunceble-dev dev https://gitlab.com/funilrys/PyFunceble/tree/master

You can install the package from source through pip3:

pip3 install --user https://github.com/funilrys/PyFunceble/archive/{{branch}}.zip # From Github
pip3 install --user https://gitlab.com/funilrys/PyFunceble/-/archive/{{branch}}/PyFunceble-{{branch}}.zip # From GitLab

Usage

Common Setups

If you installed PyFunceble through any other method that doesn't involve a container image, you can use PyFunceble "normally" through the pyfunceble executable.

pyfunceble --help

Container Image Setups

If you installed PyFunceble through the container image registry method, you can run pyfunceble through:

docker run -it pyfunceble/pyfunceble[-dev] --help

Beware: if the first parameter starts with a slash (/), the entrypoint will assume that you want to run a command within the container.

Data Persitence

If you wish to persist your data, you simply have to mount a volume to the /home/pyfunceble directory.

Example:

mkdir -p pyf-data
echo "example.com" > pyf-data/test.list

docker run -v pyf-data:/home/pyfunceble -it pyfunceble/pyfunceble[-dev] -f /home/pyf-data/test.list

Common Examples

Here are some examples to get started.

Check the availability of 'example.com'.

$ pyfunceble -d example.com

Check the availability of 'example.com' with a simple (stdout) output.

$ pyfunceble -s -d example.com

Check the availability of 'example.com' with extended (stdout) output.

$ pyfunceble -a -d example.com

Check the availability of 'example.com' and 'example.org'.

$ pyfunceble -d example.com example.org

Check the availability of 'https://example.com'.

$ pyfunceble -u https://example.com

Check the availability of 'https://example.com' and 'https://example.org'.

$ pyfunceble -u https://example.com https://example.com

Check the syntax of 'example.com'.

$ pyfunceble --syntax -d example.com

Check the reputation of 'example.com'.

$ pyfunceble --reputation -d example.com

Check the availability of all subjects in the 'myhosts' file.

$ pyfunceble -f myhosts

Check the availability of all subjects in the 'myhosts' and 'yourhosts' files.

$ pyfunceble -f myhosts yourhosts

Check the availability of all (decoded) subject of the adblock filter list 'myadblock'.

$ pyfunceble --adblock -f myadblock

Documentation as the place to be!

Want to know more about details PyFunceble? I invite you to read the documentation at docs.pyfunceble.com!

Want a local copy? I get you covered!

If you want to run the documentation locally, you can do so by following the instructions below.

Through Docker:

docker run -it -p 8080:80 pyfunceble/docs
# Open Documentation with browser: http://localhost:8080
palemoon http://127.0.0.1:8000

From source:

# Install dependencies.
pip install --user .[docs]
# Serve documentation locally.
mkdocs serve
# Open Documentation with browser.
palemoon http://127.0.0.1:8000

NOTE: You are also invited to submit changes and improvement to the documentation through a new Pull Request.

Supporting the project

PyFunceble, Dead-Hosts, adblock-decoder and all other analog projects are powered by free time and a lot of coffee!

This project helps you and you have to possibility to help back financially? Sponsor @funilrys through the GitHub Sponsor program by clicking the image below!

image

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.

Avinash Reddy
Avinash Reddy

๐Ÿ›
BigDargon
BigDargon

๐Ÿ› ๐Ÿค” ๐Ÿ’ฌ ๐Ÿ‘€ ๐Ÿ”ฃ โš ๏ธ
Fanboynz
Fanboynz

๐Ÿ› ๐Ÿค” ๐Ÿ’ต โš ๏ธ ๐Ÿ““
Haris Guลกiฤ‡
Haris Guลกiฤ‡

๐Ÿ“– ๏ธ๏ธ๏ธ๏ธโ™ฟ๏ธ ๐Ÿ”ง โš ๏ธ ๐Ÿ“น โœ… ๐Ÿ’ป
Imre Eilertsen
Imre Eilertsen

๏ธ๏ธ๏ธ๏ธโ™ฟ๏ธ ๐Ÿ› ๐Ÿ”ฃ ๐Ÿ’ก ๐Ÿ’ต ๐Ÿค” ๐Ÿ“ฃ ๐Ÿ’ฌ ๐Ÿ‘€ ๐Ÿ”ง โš ๏ธ ๐Ÿ““
Kowith Singkornkeeree
Kowith Singkornkeeree

๐Ÿ›
Mitchell Krog
Mitchell Krog

๏ธ๏ธ๏ธ๏ธโ™ฟ๏ธ ๐Ÿ› ๐Ÿ“ ๐Ÿ’ป ๐Ÿ–‹ ๐Ÿ”ฃ ๐Ÿ“– ๐ŸŽจ ๐Ÿ’ก ๐Ÿ” ๐Ÿค” ๐Ÿš‡ ๐Ÿง‘โ€๐Ÿซ ๐Ÿ“ฆ ๐Ÿ”Œ ๐Ÿ“ฃ ๐Ÿ’ฌ ๐Ÿ‘€ ๐Ÿ”ง โš ๏ธ โœ… ๐Ÿ“ข ๐Ÿ““
Nilsonfsilva
Nilsonfsilva

๐Ÿ› ๐Ÿš‡ ๐Ÿ“ฆ ๐Ÿ”ง โš ๏ธ
Odyseus
Odyseus

๐Ÿ› โš ๏ธ
Reza Rizqullah
Reza Rizqullah

๐ŸŽจ ๐Ÿ’ป
Samuel Bishop
Samuel Bishop

๐Ÿ› ๐Ÿค”
ScriptTiger
ScriptTiger

๐Ÿ› ๐Ÿค” โš ๏ธ
Stephan van Ruth
Stephan van Ruth

๐Ÿ› โš ๏ธ
Steven Black
Steven Black

๐Ÿค” ๐Ÿ’ต
T145
T145

๐Ÿ› ๐Ÿค”
WaLLy3K
WaLLy3K

๐Ÿ› ๐Ÿค”
Yuki2718
Yuki2718

๐Ÿ› โš ๏ธ
Zachinquarantine
Zachinquarantine

๐Ÿ’ป
ZeroDot1
ZeroDot1

๐Ÿ› ๐Ÿค” ๐Ÿ’ฌ โš ๏ธ ๐Ÿ’ป
avatartw
avatartw

๐Ÿ›
dnmTX
dnmTX

๐Ÿ› ๐Ÿค” ๐Ÿ’ฌ ๐Ÿ‘€ ๐Ÿ”ฃ โš ๏ธ
gwarser
gwarser

๐Ÿ› ๐Ÿ”ฃ โš ๏ธ
hawkeye116477
hawkeye116477

๐Ÿ›
jawz101
jawz101

๐Ÿ› ๐Ÿค” ๐Ÿ’ฌ ๐Ÿ”ฃ
keczuppp
keczuppp

๐Ÿ› ๐Ÿค” ๐Ÿ’ฌ โš ๏ธ ๐Ÿ”ฃ
opav
opav

๐Ÿ› โš ๏ธ
rusty-snake
rusty-snake

๐Ÿ› ๐Ÿ“–
smed79
smed79

๐Ÿ› ๐Ÿค” ๐Ÿ’ป ๐Ÿ’ฌ โš ๏ธ
speedmann
speedmann

๐Ÿ› โš ๏ธ
spirillen
spirillen

๏ธ๏ธ๏ธ๏ธโ™ฟ๏ธ ๐Ÿ› ๐Ÿ’ป ๐Ÿ–‹ ๐Ÿ”ฃ ๐Ÿ“– ๐Ÿ’ก ๐Ÿค” ๐Ÿšง ๐Ÿง‘โ€๐Ÿซ ๐Ÿ“ฃ ๐Ÿ’ฌ ๐Ÿ‘€ ๐Ÿ”ง โš ๏ธ โœ… ๐Ÿ“ข ๐Ÿ““
watchman-pypi
watchman-pypi

๐Ÿ›
xxcriticxx
xxcriticxx

๐Ÿ› ๐Ÿค” โš ๏ธ

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.

License

Copyright 2017, 2018, 2019, 2020, 2022, 2023, 2024 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

    https://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.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyfunceble_dev-4.3.0a9.tar.gz (255.4 kB view details)

Uploaded Source

Built Distribution

PyFunceble_dev-4.3.0a9-py3-none-any.whl (519.4 kB view details)

Uploaded Python 3

File details

Details for the file pyfunceble_dev-4.3.0a9.tar.gz.

File metadata

  • Download URL: pyfunceble_dev-4.3.0a9.tar.gz
  • Upload date:
  • Size: 255.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for pyfunceble_dev-4.3.0a9.tar.gz
Algorithm Hash digest
SHA256 47e3b4f0e528b8c4e888a995fe0a3a408fa40feee561015fd1231defd8401de1
MD5 65bc39918d11c2d7f3f4d8891611d50a
BLAKE2b-256 b8a6e14bfe114fe0f67755deba26fd05a39c5fad914dca9ce9cd2412d126a1b9

See more details on using hashes here.

File details

Details for the file PyFunceble_dev-4.3.0a9-py3-none-any.whl.

File metadata

File hashes

Hashes for PyFunceble_dev-4.3.0a9-py3-none-any.whl
Algorithm Hash digest
SHA256 8324430c060c550cd15db1b5a2ba93f675e2596e22137a12f28ebf4ff3804951
MD5 e47e035759cbdf612a52dc4f5f76d43e
BLAKE2b-256 40f4f27b8691d68607c169ed6c23ed2e4de744a2f9bcbd604e5a9069be668e96

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page