File: getting-started.md

package info (click to toggle)
python-pyfunceble 4.2.29.dev-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 4,108 kB
  • sloc: python: 27,413; sh: 142; makefile: 27
file content (147 lines) | stat: -rw-r--r-- 3,996 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
# Getting Started

PyFunceble has an internal API that can be used for you own logic. Before PyFunceble
`v4.0.0`, the internal API was extremely tight to the CLI. Therefore it has
been hard for developers to reuse PyFunceble as part of their program because
there was a lot to activate or deactivate to get things started.

Since PyFunceble `v4.0.0`, it is possible to use the internel checkers without
any initial configuration or initialization of any sort.

In other words: Simply choose your checker, interact with it and get what you are looking for!

## The Basics

Before starting to play with any [checkers](./api-reference/checker/index.md),
let me explain some basics.

To get started, you mostly need to understand the following classes:

1. [`CheckerBase`](./api-reference/checker/base.md)
2. [`CheckerStatusBase`](./api-reference/checker/status_base.md)

The first one is the base class of all checkers, and the second one is the base of
all status you get from any checker when you call the `.get_status()` method.

### Interacting with checkers

!!! note

    The method described below is the same for all available checkers.

Let's say we want to test the availability of the **domain** `github.com`.

We first have to select and prepare the checker.

```python linenums="1"
from PyFunceble import from PyFunceble import Domain

checker = DomainAvailabilityChecker()
```

We then declare the subject that we want to test:

```python linenums="1" hl_lines="4 5 6"
from PyFunceble import from PyFunceble import Domain

checker = DomainAvailabilityChecker()
checker.set_subject("github.com")
# This is the same.
checker.subject = "github.com"
```

Now, we trigger the query of the status:

```python linenums="1" hl_lines="8"
from PyFunceble import from PyFunceble import Domain

checker = DomainAvailabilityChecker()
checker.set_subject("github.com")
# This is the same.
checker.subject = "github.com"

status = checker.get_status()
```

Once we have the status, we can print the `#!python dict()` or JSON representation.

```python linenums="1" hl_lines="10 11 12 14 15 16"
from PyFunceble import from PyFunceble import Domain

checker = DomainAvailabilityChecker()
checker.set_subject("github.com")
# This is the same.
checker.subject = "github.com"

status = checker.get_status()

print("DICT REPRESENTATION")
print(status.to_dict())
print("-" * 80)

print("JSON REPRESENTATION")
print(status.to_json())
print("-" * 80)
```

We can also interact with any of the attributes of the status object:

```python linenums="1" hl_lines="18"
from PyFunceble import from PyFunceble import Domain

checker = DomainAvailabilityChecker()
checker.set_subject("github.com")
# This is the same.
checker.subject = "github.com"

status = checker.get_status()

print("DICT REPRESENTATION")
print(status.to_dict())
print("-" * 80)

print("JSON REPRESENTATION")
print(status.to_json())
print("-" * 80)

print(f"{status.idna_subject} is {status.status}")
```

Finally, and probably most importantly, we can ask questions.

!!! note

    Each checker has its own set of method. Be sure the read them or follow the
    autocomplete of your favorite editor.

```python linenums="1" hl_lines="20 21 22 23 24 25"
from PyFunceble import from PyFunceble import Domain

checker = DomainAvailabilityChecker()
checker.set_subject("github.com")
# This is the same.
checker.subject = "github.com"

status = checker.get_status()

print("DICT REPRESENTATION")
print(status.to_dict())
print("-" * 80)

print("JSON REPRESENTATION")
print(status.to_json())
print("-" * 80)

print(f"{status.idna_subject} is {status.status}")

# Is it active ?
print("Is GitHub active ?", "yes" if status.is_active() else "no")
# Is it inactive ?
print("Is GitHub inactive ?", "yes" if status.is_inactive() else "no")
# Is it invalid ?
print("Is github.com invalid ?", "yes" if status.is_invalid() else "no")
```

That's it, you went through the basic. Feel free to discover other checkers or
ask questions if something is not clear.