diff --git a/oxi/conf.py b/oxi/conf.py
index e39a6b4..1047b2a 100644
--- a/oxi/conf.py
+++ b/oxi/conf.py
@@ -16,7 +16,7 @@ class NodeConfig:
self._device: type[BaseDevice] = device_registry.get(self._model.lower())
if self._device is None:
raise ValueError(f"Device model '{self._model}' not found in registry")
- self._parsed_data = self._device(self.text).parse_config()
+ self._parsed_data = self._device(self.text).parse()
@cached_property
def _response(self):
diff --git a/oxi/interfaces/base.py b/oxi/interfaces/base.py
index 05adeeb..a159243 100644
--- a/oxi/interfaces/base.py
+++ b/oxi/interfaces/base.py
@@ -68,8 +68,10 @@ class BaseDevice(ABC):
...
def _load_template(self):
- path = Path(__file__).parent / "template" / self.template
+ path = Path(__file__).parent / "models" / "templates" / self.template
if not path.exists():
+ print("-" * 12)
+ print(path)
raise FileNotFoundError(f"Template {self.template} not found")
return path.read_text(encoding="utf-8")
diff --git a/oxi/interfaces/models/mikrotik.py b/oxi/interfaces/models/mikrotik.py
index b06f949..c84260d 100644
--- a/oxi/interfaces/models/mikrotik.py
+++ b/oxi/interfaces/models/mikrotik.py
@@ -1,11 +1,27 @@
+from typing import TYPE_CHECKING
from oxi.interfaces import register_parser
from oxi.interfaces.base import BaseDevice
+if TYPE_CHECKING:
+ from oxi.interfaces.contract import Interfaces, System, Vlans
+
@register_parser(["routeros", "ros", "mikrotik"])
class Mikrotik(BaseDevice):
template = "mikrotik.ttp"
+ def system(self) -> "System":
+ print(self._raw["system"])
+ print("-" * 12)
+
+ def interfaces(self) -> "Interfaces":
+ print(f"{self._raw["interfaces"]=}")
+ print("-" * 12)
+
+ def vlans(self) -> list["Vlans"]:
+ print(f"{self._raw["vlans"]=}")
+ print("-" * 12)
+
if __name__ == "__main__":
mikr = Mikrotik()
diff --git a/oxi/interfaces/models/templates/mikrotik.ttp b/oxi/interfaces/models/templates/mikrotik.ttp
index 02d8a0c..a535494 100644
--- a/oxi/interfaces/models/templates/mikrotik.ttp
+++ b/oxi/interfaces/models/templates/mikrotik.ttp
@@ -1,7 +1,31 @@
-
-
+
+
+default_system = {
+ "model": "",
+ "serial_number": ""
+}
+default_vlans = {
+ "id": "",
+ "name": ""
+}
+
-
-
\ No newline at end of file
+
+
+# version: {{ version }} {{ ignore }}
+# model = {{ model }}
+# serial number = {{ serial_number }}
+
+
+
+/ip address
+add address={{ address }} interface={{ interface }} network={{ network }}
+
+
+
+/vlans add {{ id }} name= {{ name }}
+
+
+
\ No newline at end of file