2018-11-29 10:05:38 -08:00
|
|
|
# sikofitt/generate-mac
|
2018-11-29 09:55:02 -08:00
|
|
|
|
2018-11-29 10:05:38 -08:00
|
|
|
### Small library to generate unique private mac addresses
|
|
|
|
|
|
|
|
#### Install
|
|
|
|
[composer](https://getcomposer.org)
|
|
|
|
```bash
|
|
|
|
composer require sikofitt/generate-mac
|
|
|
|
```
|
|
|
|
|
|
|
|
#### Usage
|
2018-11-29 09:55:02 -08:00
|
|
|
```php
|
|
|
|
use Sikofitt\GenerateMac\Mac;
|
|
|
|
|
|
|
|
$mac = new Mac(); // default is ':'
|
2018-11-29 12:34:59 -08:00
|
|
|
// or
|
2018-11-29 12:41:52 -08:00
|
|
|
$mac->setSeparator(Mac::SEPARATOR_COLON);
|
2018-11-29 09:55:02 -08:00
|
|
|
$address = $mac->getAddress(); // ab:cd:ef:01:23:45
|
|
|
|
|
2018-11-29 12:41:52 -08:00
|
|
|
$mac = new Mac(Mac::SEPARATOR_DASH);
|
2018-11-29 12:34:59 -08:00
|
|
|
// or
|
2018-11-29 12:41:52 -08:00
|
|
|
$mac->setSeparator(Mac::SEPARATOR_DASH);
|
2018-11-29 09:55:02 -08:00
|
|
|
$address = $mac->getAddress(); // ab-cd-ef-01-23-45
|
|
|
|
|
2018-11-29 12:41:52 -08:00
|
|
|
$mac = new Mac(Mac::SEPARATOR_NONE);
|
2018-11-29 12:34:59 -08:00
|
|
|
// or
|
2018-11-29 12:41:52 -08:00
|
|
|
$mac->setSeparator(Mac::SEPARATOR_NONE);
|
2018-11-29 09:55:02 -08:00
|
|
|
$address = $mac->getAddress(); // abcdef012345
|
|
|
|
```
|
|
|
|
|
|
|
|
If you don't care that it is unique you can remove the check for private mac prefixes.
|
|
|
|
|
|
|
|
```php
|
2018-11-29 12:41:52 -08:00
|
|
|
$mac = new Mac(Mac::SEPARATOR_COLON, false);
|
2018-11-29 12:34:59 -08:00
|
|
|
// or
|
|
|
|
$mac->setUnique(false);
|
|
|
|
|
2018-11-29 10:05:38 -08:00
|
|
|
$address = $mac->getAddress();
|
2018-11-29 09:55:02 -08:00
|
|
|
|
2018-11-29 10:05:38 -08:00
|
|
|
// '52:54:00:ab:cd:ef', QEMU virtual NIC prefix 52:54:00
|
|
|
|
// It's really not likely there will be a collision though.
|
2018-11-29 09:55:02 -08:00
|
|
|
```
|
|
|
|
|
|
|
|
Generate multiple mac addresses
|
|
|
|
```php
|
|
|
|
$addresses = $mac->getAddresses(10);
|
|
|
|
|
|
|
|
var_dump($addresses);
|
|
|
|
/*
|
|
|
|
* array (
|
|
|
|
* 0 => '8a:20:0b:b7:c4:62',
|
|
|
|
* 1 => '56:7d:47:56:e8:bd',
|
|
|
|
* 2 => '2a:ae:7b:44:6f:9d',
|
|
|
|
* 3 => '6a:36:1a:7c:04:3a',
|
|
|
|
* 4 => '3a:3d:93:f5:a6:12',
|
|
|
|
* 5 => '8a:85:ce:11:2c:a2',
|
|
|
|
* 6 => '06:54:6f:b1:11:48',
|
|
|
|
* 7 => 'c6:fe:9d:86:38:dd',
|
|
|
|
* 8 => 'ba:39:b3:a2:a1:fa',
|
|
|
|
* 9 => '32:73:c0:b3:62:27',
|
|
|
|
* );
|
|
|
|
*/
|
2018-11-29 12:34:59 -08:00
|
|
|
|
|
|
|
// if you call this with 1 as the count it will still
|
|
|
|
// return an array [0 => '32:73:c0:b3:62:27']
|
2018-11-29 10:05:38 -08:00
|
|
|
```
|
|
|
|
|
|
|
|
#### Test
|
|
|
|
|
|
|
|
```bash
|
|
|
|
user@localhost:~/generate-mac$ vendor/phpunit
|
|
|
|
```
|
|
|
|
|
|
|
|
#### License
|
|
|
|
|
|
|
|
[GPL-3.0](LICENSE)
|