Virtlab:Řídící server/ParserEquipment.php.inc
Z VirtlabWiki
(Rozdíly mezi verzemi)
| Verze z 10:58, 22. 2. 2007 Vav166 (Diskuse | příspěvky) (→Příklady) ← Předchozí porovnání |
Verze z 14:12, 5. 3. 2007 Vav166 (Diskuse | příspěvky) Následující porovnání → |
||
| Řádka 1: | Řádka 1: | ||
| - | Tato třída pomáhá vytahovat data o vybavení z XML souboru. Ten je naparsován třídou [[Virtlab:XmlParser.php.inc|virtlabXmlParser]]. | + | Tato třída pomáhá extrahovat data o laboratorních prvcích z příslušného XML souboru. Ten je naparsován třídou <tt>[[Virtlab:XmlParser.php.inc|virtlabXmlParser]]</tt>. |
| - | == Popis funkcí == | + | == Konstanty == |
| + | ; parsed = array() : veškerá data získaná z XML souboru parserem <tt>[[Virtlab:XmlParser.php.inc|virtlabXmlParser]]</tt> | ||
| + | ; cached_devices = 0 : určuje, jestli se mají data o laboratorních prvcích (obečně může jít jen o část <tt>$this->parsed</tt>) cacheovat v proměnné <tt>$this->devices</tt> | ||
| + | ; devices = array() : cache dat o laboratorních prvcích | ||
| + | |||
| + | == Metody == | ||
| ; function __construct($file, $is_file=0, $cache_dev=1) : konstruktor třídy v PHP5 | ; function __construct($file, $is_file=0, $cache_dev=1) : konstruktor třídy v PHP5 | ||
| ; public function virtlabParserEquipment($file, $is_file=0, $cache_dev=1) : konstruktor třídy. Jednotlivé parametry mají tento význam: | ; public function virtlabParserEquipment($file, $is_file=0, $cache_dev=1) : konstruktor třídy. Jednotlivé parametry mají tento význam: | ||
| :; $file : obsahuje cestu k XML souboru s [[Virtlab:Equipment.dtd|popisem vybavení]], nebo jsou v této proměnné uložena přímo XML data (o variantě rozhoduje parametr <tt>$is_file</tt>) | :; $file : obsahuje cestu k XML souboru s [[Virtlab:Equipment.dtd|popisem vybavení]], nebo jsou v této proměnné uložena přímo XML data (o variantě rozhoduje parametr <tt>$is_file</tt>) | ||
| - | :; $is_file : udává jestli je atribut <tt>$file</tt> casta k souboru, nebo přímo XML data | + | :; $is_file : udává, jestli je atribut <tt>$file</tt> casta k souboru, nebo přímo XML data |
| - | :; $cache_dev : nastavuje, jestli se maji data o vybavení uložit do proměnné, ze které si při potřebě načítají, nebo se vždy čtou z původního výstupu [[Virtlab:XmlParser.php.inc|třídy virtlabXmlParser]] | + | :; $cache_dev : nastavuje, jestli se maji data o laboratorních prvcích uložit do proměnné <tt>$this->devices</tt>, ze které si při potřebě načítají, nebo se vždy čtou z původního výstupu [[Virtlab:XmlParser.php.inc|třídy virtlabXmlParser]] uloženém v <tt>$this->parsed</tt>. |
| - | ; public function getDevices() : vrátí původní pole s kompletním vybavením | + | ; public function getDevices() : vrátí pole s kompletními daty o laboratorních prvcích |
| - | ; public function getDevicesCount() : vrátí počet zařízení | + | ; public function getDevicesCount() : vrátí počet laboratorních prvků |
| - | ; public function getDevice($index) : vrátí určené zařízení (podle parametru <tt>$index</tt>, který odpovídá jejímu indexu v celkovém poli včech zařízení) | + | ; public function getDevice($index) : vrátí určený laboratorní prvek (odpovídající úsek z naparsovaných dat), podle parametru <tt>$index</tt>, který odpovídá jejímu indexu v celkovém poli všech laboratorních prvků |
| - | ; public function getDeviceType($index) : vrátí typ zadaného zařízení | + | ; public function getDeviceType($index) : vrátí typ zadaného laboratorního prvku |
| - | ; public function getDeviceName($index) : vrátí název zadaného zařízení | + | ; public function getDeviceName($index) : vrátí název zadaného laboratorního prvku |
| - | ; public function getDeviceSerial($index) : vrátí seriové číslo zařízení | + | ; public function getDeviceSerial($index) : vrátí seriové číslo laboratorního prvku |
| - | ; public function getDevicePlatform($index) : vrátí platformu zařízení | + | ; public function getDevicePlatform($index) : vrátí platformu laboratorního prvku |
| - | ; public function getDeviceByName($name, &$index) : vrátí požadované zařízení (určené jeho názvem). Do parametru <tt>$index</tt> se uloží jeho index. | + | ; public function getDeviceByName($name, &$index) : vrátí požadovaný laboratorní prvek (určený jeho názvem). Do parametru <tt>$index</tt> se uloží jeho index |
| - | ; public function getDeviceOS($name, $variant=1) : vrátí veryi OS zařízení. Parametr <tt>$variant</tt> určuje jestli má být výstup upravený nebo v podobě, jako v původním poli. | + | ; public function getDeviceOS($name, $variant=1) : vrátí veri OS laboratorního prvku. Parametr <tt>$variant</tt> určuje jestli má být výstup upravený nebo v podobě, jako v původním poli |
| - | ; public function getDeviceInterfaces($name) : vrátí rozhraní zadaného zařízení | + | ; public function getDeviceInterfaces($name) : vrátí rozhraní zadaného laboratorního prvku |
| - | ; public function getDeviceInterfacesCount($name) : vrátí počet rozhraní zadaného zařízení | + | ; public function getDeviceInterfacesCount($name) : vrátí počet rozhraní zadaného laboratorního prvku |
| - | ; public function getDeviceInterface($name, $index, $variant=1) : vrátí určené rozhraní (určené parametrem <tt>$index</tt>) určeného zařízení | + | ; public function getDeviceInterface($name, $index, $variant=1) : vrátí určené rozhraní (určené parametrem <tt>$index</tt>) určeného laboratorního prvku |
| - | ; public function getDeviceInterfaceTechnology($name, $index) : vratí technologii rozhraní | + | ; public function getDeviceInterfaceTechnology($name, $index) : vratí technologii laboratorního prvku |
| - | ; public function getDeviceInterfaceEthertype($name, $index) : vrátí ''verzi'' ethernetu rozhraní. Pokud je technologie <tt>serial</tt> vrací NULL. | + | ; public function getDeviceInterfaceEthertype($name, $index) : vrátí ''typ'' ethernetu rozhraní. Pokud je technologie <tt>serial</tt> vrací NULL. |
| ; public function getDeviceInterfaceMaxbps($name, $index) : vrátí maximální rychlost rozhraní. Pokud je technologie <tt>ethernet</tt> vrací NULL. | ; public function getDeviceInterfaceMaxbps($name, $index) : vrátí maximální rychlost rozhraní. Pokud je technologie <tt>ethernet</tt> vrací NULL. | ||
| ; public function getDeviceInterfaceFeatures($name, $index) : vrátí speciální vlastnosti zadaného rozhraní | ; public function getDeviceInterfaceFeatures($name, $index) : vrátí speciální vlastnosti zadaného rozhraní | ||
| - | ; public function getDeviceFeatures($name) : vrátí speciální vlastnosti zařízení | + | ; public function getDeviceFeatures($name) : vrátí speciální vlastnosti laboratorního prvku |
| - | ; public function getDevicesFeatures() : vrátí všechny speciální vlastnosti všech zařízení | + | ; public function getDevicesFeatures() : vrátí všechny speciální vlastnosti všech laboratorních prvků - i s duplicitami |
| - | ; public function getDevicesByType($type) : vrátí jména zařízení daného typu | + | ; public function getDevicesByType($type) : vrátí jména laboratorních prvků daného typu |
| - | ; public function getDevicesTypes() : vrátí typy zařízení, které se ve vybavení vyskytují | + | ; public function getDevicesTypes() : vrátí typy laboratorních prvků, které se ve vybavení vyskytují |
| - | ; public function getDeviceInterfacesFeatures($name) : vrátí speciální vlastnosti všech rozhraní daného zařízení | + | ; public function getDeviceInterfacesFeatures($name) : vrátí speciální vlastnosti všech rozhraní daného laboratorního prvku |
| - | ; public function getDevicesInterfacesFeatures() : vrátí speciální vlastnosti všech rozhraní všech zařízení | + | ; public function getDevicesInterfacesFeatures() : vrátí speciální vlastnosti všech rozhraní všech laboratorních prvků |
| - | ; public function getDevicesList() : vrátí seznam názvů všech zařízení | + | ; public function getDevicesList() : vrátí seznam názvů všech laboratorních prvků |
| ; public function getDeviceInterfaceName($name, $index) : vrátí jméno zadaného rozhraní | ; public function getDeviceInterfaceName($name, $index) : vrátí jméno zadaného rozhraní | ||
Verze z 14:12, 5. 3. 2007
Tato třída pomáhá extrahovat data o laboratorních prvcích z příslušného XML souboru. Ten je naparsován třídou virtlabXmlParser.
Obsah |
Konstanty
- parsed = array()
- veškerá data získaná z XML souboru parserem virtlabXmlParser
- cached_devices = 0
- určuje, jestli se mají data o laboratorních prvcích (obečně může jít jen o část $this->parsed) cacheovat v proměnné $this->devices
- devices = array()
- cache dat o laboratorních prvcích
Metody
- function __construct($file, $is_file=0, $cache_dev=1)
- konstruktor třídy v PHP5
- public function virtlabParserEquipment($file, $is_file=0, $cache_dev=1)
- konstruktor třídy. Jednotlivé parametry mají tento význam:
- $file
- obsahuje cestu k XML souboru s popisem vybavení, nebo jsou v této proměnné uložena přímo XML data (o variantě rozhoduje parametr $is_file)
- $is_file
- udává, jestli je atribut $file casta k souboru, nebo přímo XML data
- $cache_dev
- nastavuje, jestli se maji data o laboratorních prvcích uložit do proměnné $this->devices, ze které si při potřebě načítají, nebo se vždy čtou z původního výstupu třídy virtlabXmlParser uloženém v $this->parsed.
- public function getDevices()
- vrátí pole s kompletními daty o laboratorních prvcích
- public function getDevicesCount()
- vrátí počet laboratorních prvků
- public function getDevice($index)
- vrátí určený laboratorní prvek (odpovídající úsek z naparsovaných dat), podle parametru $index, který odpovídá jejímu indexu v celkovém poli všech laboratorních prvků
- public function getDeviceType($index)
- vrátí typ zadaného laboratorního prvku
- public function getDeviceName($index)
- vrátí název zadaného laboratorního prvku
- public function getDeviceSerial($index)
- vrátí seriové číslo laboratorního prvku
- public function getDevicePlatform($index)
- vrátí platformu laboratorního prvku
- public function getDeviceByName($name, &$index)
- vrátí požadovaný laboratorní prvek (určený jeho názvem). Do parametru $index se uloží jeho index
- public function getDeviceOS($name, $variant=1)
- vrátí veri OS laboratorního prvku. Parametr $variant určuje jestli má být výstup upravený nebo v podobě, jako v původním poli
- public function getDeviceInterfaces($name)
- vrátí rozhraní zadaného laboratorního prvku
- public function getDeviceInterfacesCount($name)
- vrátí počet rozhraní zadaného laboratorního prvku
- public function getDeviceInterface($name, $index, $variant=1)
- vrátí určené rozhraní (určené parametrem $index) určeného laboratorního prvku
- public function getDeviceInterfaceTechnology($name, $index)
- vratí technologii laboratorního prvku
- public function getDeviceInterfaceEthertype($name, $index)
- vrátí typ ethernetu rozhraní. Pokud je technologie serial vrací NULL.
- public function getDeviceInterfaceMaxbps($name, $index)
- vrátí maximální rychlost rozhraní. Pokud je technologie ethernet vrací NULL.
- public function getDeviceInterfaceFeatures($name, $index)
- vrátí speciální vlastnosti zadaného rozhraní
- public function getDeviceFeatures($name)
- vrátí speciální vlastnosti laboratorního prvku
- public function getDevicesFeatures()
- vrátí všechny speciální vlastnosti všech laboratorních prvků - i s duplicitami
- public function getDevicesByType($type)
- vrátí jména laboratorních prvků daného typu
- public function getDevicesTypes()
- vrátí typy laboratorních prvků, které se ve vybavení vyskytují
- public function getDeviceInterfacesFeatures($name)
- vrátí speciální vlastnosti všech rozhraní daného laboratorního prvku
- public function getDevicesInterfacesFeatures()
- vrátí speciální vlastnosti všech rozhraní všech laboratorních prvků
- public function getDevicesList()
- vrátí seznam názvů všech laboratorních prvků
- public function getDeviceInterfaceName($name, $index)
- vrátí jméno zadaného rozhraní
Příklady
$parser->getDeviceInterface("r1",0,0);
Array
(
[name] => INTERFACE
[attribs] => Array
(
[TECHNOLOGY] => serial
[CONNECT_GROUP] => 1
[NAME] => s0/1/0
)
[child] => Array
(
[0] => Array
(
[name] => MAX_BPS
[content] => 128000
)
[1] => Array
(
[name] => INT_FEATURE
[content] => ...
)
)
)
$parser->getDeviceInterface("r1",0,1);
Array
(
[technology] => serial
[connect_group] => 1
[name] => s0/1/0
)
$parser->getDeviceInterface("r3",1,1);
Array
(
[technology] => ethernet
[connect_group] => 3
[name] => fa0/0
[ether_type] => fast
)
$parser->getDeviceInterfaceTechnology("r3",1);
ethernet
$parser->getDeviceInterfaceEthertype("r3",1);
fast
$parser->getDevicesByType("router");
Array
(
[0] => r1
[1] => r3
[2] => r5
[3] => r7
)
$parser->getDevicesTypes(); Array ( [0] => router [1] => switch )
$parser->getDevicesInterfacesFeatures(); Array ( [0] => 802.1q [1] => +++ [2] => xxx [3] => ... )
$parser->getDevicesList(); Array ( [4] => swa [3] => r7 [2] => r5 [1] => r3 [0] => r1 )
$parser->getDeviceInterfaceName("r1",0);
s0/1/0
Zdrojový kód
<?php
class virtlabParserEquipment {
private $parsed = array();
private $devices = array();
private $cached_devices = 0;
function __construct($file, $is_file=0, $cache_dev=1) {
$this->virtlabParserEquipment($file, $is_file, $cache_dev);
}//konstruktor
private function virtlabParserEquipment($file, $is_file=0, $cache_dev=1) {
$parser = new virtlabXmlParser(1);
if($is_file) $parser->parse($file);
else $parser->parse_data($file);
$this->parsed = $parser->output;
unset($parser);
if($cache_dev) {
$this->devices = $this->getDevices();
$this->cached_devices = 1;
}
}//function
public function getDevices() {
if(!$this->cached_devices) {
$temp = $this->parsed[0]["child"];
return $temp;
}
else return $this->devices;
}//function
public function getDevicesCount() {
if(!$this->cached_devices)
{
$temp = $this->getDevices();
return count($temp);
}
else return count($this->devices);
}//function
public function getDevice($index) {
$temp = $this->getDevices();
return $temp[$index];
}//function
public function getDeviceType($index) {
$temp = $this->getDevice($index);
return $temp["attribs"]["TYPE"];
}//function
public function getDeviceName($index) {
$temp = $this->getDevice($index);
return $temp["attribs"]["NAME"];
}//function
public function getDeviceSerial($index) {
$temp = $this->getDevice($index);
return $temp["attribs"]["SERIAL_NUMBER"];
}//function
public function getDevicePlatform($index) {
$temp = $this->getDevice($index);
return $temp["attribs"]["PLATFORM"];
}//function
public function getDeviceByName($name, &$index) {
$result = array();
for($i = $this->getDevicesCount(); $i>=0; $i--) {
if($name==$this->getDeviceName($i)) {
$index = $i;
return $this->getDevice($i);
}//if
}//for
return NULL;
}//function
public function getDeviceOS($name, $variant=1) {
$temp = $this->getDeviceByName($name,$idx);
if($temp["child"]) {
$temp2 = $temp["child"][0];
if(!isset($temp2)) return NULL;
if($variant) {
//$temp3["major"] = $temp2["child"][0]["content"];
//if($temp2["child"][1]) $temp3["minor"] = $temp2["child"][1]["content"];
//if($temp2["child"][2]) $temp3["other"] = $temp2["child"][2]["content"];
//return $temp3;
return $temp2["content"];
}
else return $temp2;
}//if
else return NULL;
}//function
public function getDeviceInterfaces($name) {
$temp = $this->getDeviceByName($name,$idx);
if($temp["child"][1]["name"]!="INTERFACES") return NULL;
return $temp["child"][1];
}//function
public function getDeviceInterfacesCount($name) {
$temp = $this->getDeviceInterfaces($name);
if(!$temp["child"]) return NULL;
return count($temp["child"]);
}//function
public function getDeviceInterface($name, $index, $variant=1) {
$temp = $this->getDeviceInterfaces($name);
if(!$temp["child"][$index]) return NULL;
if($variant) {
$temp2 = array();
$temp2["technology"] = $temp["child"][$index]["attribs"]["TECHNOLOGY"];
$temp2["connect_group"] = $temp["child"][$index]["attribs"]["CONNECT_GROUP"];
$temp2["name"] = $temp["child"][$index]["attribs"]["NAME"];
if($temp["child"][$index]["attribs"]["ETHER_TYPE"])
$temp2["ether_type"] = $temp["child"][$index]["attribs"]["ETHER_TYPE"];
return $temp2;
}
else return $temp["child"][$index];
}//function
public function getDeviceInterfaceTechnology($name, $index) {
$temp = $this->getDeviceInterface($name, $index, 1);
return $temp["technology"];
}//function
public function getDeviceInterfaceEthertype($name, $index) {
$temp = $this->getDeviceInterface($name, $index, 1);
if($temp["technology"] == "ethernet") return $temp["ether_type"];
else return NULL;
}//function
public function getDeviceInterfaceMaxbps($name, $index) {
$temp = $this->getDeviceInterface($name, $index, 0);
if($temp["child"][0]["name"]!="MAX_BPS") return NULL;
return $temp["child"][0]["content"];
}//function
public function getDeviceInterfaceFeatures($name, $index) {
$temp = $this->getDeviceInterface($name, $index, 0);
$temp2 = array();
if(is_array($temp) && $temp["child"])
foreach($temp["child"] as $hodnota) {
if($hodnota["name"]=="INT_FEATURE") {
array_push($temp2, $hodnota["content"]);
}//if
}//foreach
if(!$temp2[0]) return NULL;
else return $temp2;
}//function
public function getDeviceFeatures($name) {
$temp = $this->getDeviceByName($name,$idx);
foreach($temp["child"] as $hodnota) {
if($hodnota["name"]=="SPECIAL") {
$result = array();
foreach($hodnota["child"] as $hodnota2) {
array_push($result, $hodnota2["content"]);
}//foreach
break;
}//if
}//foreach
if(!$result[0]) return NULL;
else return $result;
}//function
public function getDevicesFeatures() {
$feat = array();
for($i = $this->getDevicesCount() - 1; $i >= 0; $i--) {
$jmeno = $this->getDeviceName($i);
$temp = $this->getDeviceFeatures($jmeno);
if(is_array($temp))
foreach($temp as $value)
array_push($feat, $value);
}//for
return $feat;
}
public function getDevicesByType($type) {
$temp = $this->getDevices();
$temp2 = array();
foreach($temp as $hodnota) {
if($hodnota["attribs"]["TYPE"] == $type)
array_push($temp2, $hodnota["attribs"]["NAME"]);
}
if(!$temp2[0]) return NULL;
return Unique($temp2);
}//function
public function getDevicesTypes() {
$temp = $this->getDevices();
$temp2 = array();
foreach($temp as $hodnota) {
array_push($temp2, $hodnota["attribs"]["TYPE"]);
}
if(!$temp2[0]) return NULL;
return Unique($temp2);
}//function
public function getDeviceInterfacesFeatures($name) {
$feat = array();
for($i = $this->getDeviceInterfacesCount($name) - 1; $i >= 0; $i--) {
$temp = $this->getDeviceInterfaceFeatures($name, $i);
if(is_array($temp))
foreach($temp as $hodnota)
array_push($feat, $hodnota);
}//for
return $feat;
}//function
public function getDevicesInterfacesFeatures() {
$feat = array();
for($i = $this->getDevicesCount() - 1; $i >= 0; $i--) {
$jmeno = $this->getDeviceName($i);
$temp = $this->getDeviceInterfacesFeatures($jmeno);
if(is_array($temp))
foreach($temp as $hodnota)
array_push($feat, $hodnota);
}//for
return $feat;
}//function
public function getDevicesList() {
$temp = array();
for($i = $this->getDevicesCount() - 1; $i >= 0; $i--) {
$temp[$i] = $this->getDeviceName($i);
}//for
return $temp;
}//function
public function getDeviceInterfaceName($name, $index) {
$temp = $this->getDeviceInterface($name, $index, 1);
return $temp["name"];
}//function
}//class
?>
Kategorie: PHP | Třída | Diplomová práce | Jan Vavříček
