Network tools Library for PHP with native Yggdrasil / IPv6 support
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

197 lines
2.8 KiB

# net-php
1 year ago
Network Library for PHP with native Yggdrasil support
1 year ago
## Install
`composer require yggverse/net`
1 year ago
## Usage
1 year ago
### Socket
#### Check socket is open
```
var_dump(
\Yggverse\Net\Socket::isOpen('yo.index', 80)
);
```
#### Check host valid
```
var_dump(
1 year ago
\Yggverse\Net\Socket::isHost('yo.index')
1 year ago
);
```
#### Check port valid
```
var_dump(
1 year ago
\Yggverse\Net\Socket::isPort(80)
1 year ago
);
```
### Dig
#### Resolve records
1 year ago
1 year ago
```
var_dump(
\Yggverse\Net\Dig::records('yo.index', ['A', 'AAAA'], &$result = [], &$error = [], $provider = null, $timeout = 5)
1 year ago
);
```
1 year ago
#### Check hostname valid
1 year ago
1 year ago
```
1 year ago
var_dump(
\Yggverse\Net\Dig::isHostName('yo.index')
1 year ago
);
1 year ago
```
1 year ago
1 year ago
#### Check record valid
1 year ago
1 year ago
```
1 year ago
var_dump(
\Yggverse\Net\Dig::isRecord('A')
1 year ago
);
1 year ago
```
1 year ago
1 year ago
#### Check record value valid
1 year ago
1 year ago
```
1 year ago
var_dump(
\Yggverse\Net\Dig::isRecordValue('A', '127.0.0.1')
1 year ago
);
1 year ago
```
### Resolve
```
$resolve = new \Yggverse\Net\Resolve(
[
'A',
'AAAA'
],
[
'1.1.1.1',
'8.8.8.8'
],
// ..
);
$resolved = $resolve->address(
'https://en.wikipedia.org/wiki/Domain_Name_System'
);
if ($resolved)
{
var_dump(
$resolved->get() // https://185.15.59.224/wiki/Domain_Name_System
);
var_dump(
$resolved->getHost() // 185.15.59.224
);
}
```
### Address
Includes methods to work with network addresses.
#### Base address methods
Different operations with address parts:
* `scheme`
* `user`
* `password`
* `host`
* `protocol`
* `path`
* `query`
* `fragment`
#### Address conversion from relative to absolute format
**Document root**
```
$base = new \Yggverse\Net\Address(
'http://yo.ygg/a1/b1/c1'
);
$address = new \Yggverse\Net\Address(
'/a2'
);
var_dump(
$address->getAbsolute(
$base
) // return http://yo.ygg/a2
);
```
**Current folder**
```
$base = new \Yggverse\Net\Address(
'http://yo.ygg/a1/b1/c1'
);
$address = new \Yggverse\Net\Address(
'c2'
);
var_dump(
$address->getAbsolute(
$base
) // return http://yo.ygg/a1/b1/c2
);
```
**Ending slash**
```
$base = new \Yggverse\Net\Address(
'http://yo.ygg/a1/b1/c1/'
);
$address = new \Yggverse\Net\Address(
'../../b2/c2'
);
var_dump(
$address->getAbsolute(
$base
) // return http://yo.ygg/a1/b2/c2
);
```
**All options**
```
$base = new \Yggverse\Net\Address(
'http://user:password@yo.ygg/a1/b1/c1?attribute=value#anchor'
);
$address = new \Yggverse\Net\Address(
'../../a2/b2?attribute2=value2#anchor2'
);
var_dump(
$address->getAbsolute(
$base
) // return http://user:password@yo.ygg/a2/b2?attribute2=value2#anchor2
);
```
1 year ago
## Integrations
1 year ago
* [Network API with native Yggdrasil/IPv6 support](https://github.com/YGGverse/web-api)
* [Yo! Crawler for different networks](https://github.com/YGGverse/Yo)