diff --git a/TP-02/Pipfile b/TP-02/Pipfile new file mode 100644 index 0000000..13c0612 --- /dev/null +++ b/TP-02/Pipfile @@ -0,0 +1,12 @@ +[[source]] +url = "https://pypi.org/simple" +verify_ssl = true +name = "pypi" + +[packages] +jinja2 = "*" + +[dev-packages] + +[requires] +python_version = "3.12" diff --git a/TP-02/Pipfile.lock b/TP-02/Pipfile.lock new file mode 100644 index 0000000..3ee6b1a --- /dev/null +++ b/TP-02/Pipfile.lock @@ -0,0 +1,125 @@ +{ + "_meta": { + "hash": { + "sha256": "0d6d71bde3074bba6c6c22ffb03c3babc1c25dc9efe76dd93ef12784c56beadb" + }, + "pipfile-spec": 6, + "requires": { + "python_version": "3.12" + }, + "sources": [ + { + "name": "pypi", + "url": "https://pypi.org/simple", + "verify_ssl": true + } + ] + }, + "default": { + "jinja2": { + "hashes": [ + "sha256:0137fb05990d35f1275a587e9aee6d56da821fc83491a0fb838183be43f66d6d", + "sha256:85ece4451f492d0c13c5dd7c13a64681a86afae63a5f347908daf103ce6d2f67" + ], + "index": "pypi", + "markers": "python_version >= '3.7'", + "version": "==3.1.6" + }, + "markupsafe": { + "hashes": [ + "sha256:0303439a41979d9e74d18ff5e2dd8c43ed6c6001fd40e5bf2e43f7bd9bbc523f", + "sha256:068f375c472b3e7acbe2d5318dea141359e6900156b5b2ba06a30b169086b91a", + "sha256:0bf2a864d67e76e5c9a34dc26ec616a66b9888e25e7b9460e1c76d3293bd9dbf", + "sha256:0db14f5dafddbb6d9208827849fad01f1a2609380add406671a26386cdf15a19", + "sha256:0eb9ff8191e8498cca014656ae6b8d61f39da5f95b488805da4bb029cccbfbaf", + "sha256:0f4b68347f8c5eab4a13419215bdfd7f8c9b19f2b25520968adfad23eb0ce60c", + "sha256:1085e7fbddd3be5f89cc898938f42c0b3c711fdcb37d75221de2666af647c175", + "sha256:116bb52f642a37c115f517494ea5feb03889e04df47eeff5b130b1808ce7c219", + "sha256:12c63dfb4a98206f045aa9563db46507995f7ef6d83b2f68eda65c307c6829eb", + "sha256:133a43e73a802c5562be9bbcd03d090aa5a1fe899db609c29e8c8d815c5f6de6", + "sha256:1353ef0c1b138e1907ae78e2f6c63ff67501122006b0f9abad68fda5f4ffc6ab", + "sha256:15d939a21d546304880945ca1ecb8a039db6b4dc49b2c5a400387cdae6a62e26", + "sha256:177b5253b2834fe3678cb4a5f0059808258584c559193998be2601324fdeafb1", + "sha256:1872df69a4de6aead3491198eaf13810b565bdbeec3ae2dc8780f14458ec73ce", + "sha256:1b4b79e8ebf6b55351f0d91fe80f893b4743f104bff22e90697db1590e47a218", + "sha256:1b52b4fb9df4eb9ae465f8d0c228a00624de2334f216f178a995ccdcf82c4634", + "sha256:1ba88449deb3de88bd40044603fafffb7bc2b055d626a330323a9ed736661695", + "sha256:1cc7ea17a6824959616c525620e387f6dd30fec8cb44f649e31712db02123dad", + "sha256:218551f6df4868a8d527e3062d0fb968682fe92054e89978594c28e642c43a73", + "sha256:26a5784ded40c9e318cfc2bdb30fe164bdb8665ded9cd64d500a34fb42067b1c", + "sha256:2713baf880df847f2bece4230d4d094280f4e67b1e813eec43b4c0e144a34ffe", + "sha256:2a15a08b17dd94c53a1da0438822d70ebcd13f8c3a95abe3a9ef9f11a94830aa", + "sha256:2f981d352f04553a7171b8e44369f2af4055f888dfb147d55e42d29e29e74559", + "sha256:32001d6a8fc98c8cb5c947787c5d08b0a50663d139f1305bac5885d98d9b40fa", + "sha256:3524b778fe5cfb3452a09d31e7b5adefeea8c5be1d43c4f810ba09f2ceb29d37", + "sha256:3537e01efc9d4dccdf77221fb1cb3b8e1a38d5428920e0657ce299b20324d758", + "sha256:35add3b638a5d900e807944a078b51922212fb3dedb01633a8defc4b01a3c85f", + "sha256:38664109c14ffc9e7437e86b4dceb442b0096dfe3541d7864d9cbe1da4cf36c8", + "sha256:3a7e8ae81ae39e62a41ec302f972ba6ae23a5c5396c8e60113e9066ef893da0d", + "sha256:3b562dd9e9ea93f13d53989d23a7e775fdfd1066c33494ff43f5418bc8c58a5c", + "sha256:457a69a9577064c05a97c41f4e65148652db078a3a509039e64d3467b9e7ef97", + "sha256:4bd4cd07944443f5a265608cc6aab442e4f74dff8088b0dfc8238647b8f6ae9a", + "sha256:4e885a3d1efa2eadc93c894a21770e4bc67899e3543680313b09f139e149ab19", + "sha256:4faffd047e07c38848ce017e8725090413cd80cbc23d86e55c587bf979e579c9", + "sha256:509fa21c6deb7a7a273d629cf5ec029bc209d1a51178615ddf718f5918992ab9", + "sha256:5678211cb9333a6468fb8d8be0305520aa073f50d17f089b5b4b477ea6e67fdc", + "sha256:591ae9f2a647529ca990bc681daebdd52c8791ff06c2bfa05b65163e28102ef2", + "sha256:5a7d5dc5140555cf21a6fefbdbf8723f06fcd2f63ef108f2854de715e4422cb4", + "sha256:69c0b73548bc525c8cb9a251cddf1931d1db4d2258e9599c28c07ef3580ef354", + "sha256:6b5420a1d9450023228968e7e6a9ce57f65d148ab56d2313fcd589eee96a7a50", + "sha256:722695808f4b6457b320fdc131280796bdceb04ab50fe1795cd540799ebe1698", + "sha256:729586769a26dbceff69f7a7dbbf59ab6572b99d94576a5592625d5b411576b9", + "sha256:77f0643abe7495da77fb436f50f8dab76dbc6e5fd25d39589a0f1fe6548bfa2b", + "sha256:795e7751525cae078558e679d646ae45574b47ed6e7771863fcc079a6171a0fc", + "sha256:7be7b61bb172e1ed687f1754f8e7484f1c8019780f6f6b0786e76bb01c2ae115", + "sha256:7c3fb7d25180895632e5d3148dbdc29ea38ccb7fd210aa27acbd1201a1902c6e", + "sha256:7e68f88e5b8799aa49c85cd116c932a1ac15caaa3f5db09087854d218359e485", + "sha256:83891d0e9fb81a825d9a6d61e3f07550ca70a076484292a70fde82c4b807286f", + "sha256:8485f406a96febb5140bfeca44a73e3ce5116b2501ac54fe953e488fb1d03b12", + "sha256:8709b08f4a89aa7586de0aadc8da56180242ee0ada3999749b183aa23df95025", + "sha256:8f71bc33915be5186016f675cd83a1e08523649b0e33efdb898db577ef5bb009", + "sha256:915c04ba3851909ce68ccc2b8e2cd691618c4dc4c4232fb7982bca3f41fd8c3d", + "sha256:949b8d66bc381ee8b007cd945914c721d9aba8e27f71959d750a46f7c282b20b", + "sha256:94c6f0bb423f739146aec64595853541634bde58b2135f27f61c1ffd1cd4d16a", + "sha256:9a1abfdc021a164803f4d485104931fb8f8c1efd55bc6b748d2f5774e78b62c5", + "sha256:9b79b7a16f7fedff2495d684f2b59b0457c3b493778c9eed31111be64d58279f", + "sha256:a320721ab5a1aba0a233739394eb907f8c8da5c98c9181d1161e77a0c8e36f2d", + "sha256:a4afe79fb3de0b7097d81da19090f4df4f8d3a2b3adaa8764138aac2e44f3af1", + "sha256:ad2cf8aa28b8c020ab2fc8287b0f823d0a7d8630784c31e9ee5edea20f406287", + "sha256:b8512a91625c9b3da6f127803b166b629725e68af71f8184ae7e7d54686a56d6", + "sha256:bc51efed119bc9cfdf792cdeaa4d67e8f6fcccab66ed4bfdd6bde3e59bfcbb2f", + "sha256:bdc919ead48f234740ad807933cdf545180bfbe9342c2bb451556db2ed958581", + "sha256:bdd37121970bfd8be76c5fb069c7751683bdf373db1ed6c010162b2a130248ed", + "sha256:be8813b57049a7dc738189df53d69395eba14fb99345e0a5994914a3864c8a4b", + "sha256:c0c0b3ade1c0b13b936d7970b1d37a57acde9199dc2aecc4c336773e1d86049c", + "sha256:c47a551199eb8eb2121d4f0f15ae0f923d31350ab9280078d1e5f12b249e0026", + "sha256:c4ffb7ebf07cfe8931028e3e4c85f0357459a3f9f9490886198848f4fa002ec8", + "sha256:ccfcd093f13f0f0b7fdd0f198b90053bf7b2f02a3927a30e63f3ccc9df56b676", + "sha256:d2ee202e79d8ed691ceebae8e0486bd9a2cd4794cec4824e1c99b6f5009502f6", + "sha256:d53197da72cc091b024dd97249dfc7794d6a56530370992a5e1a08983ad9230e", + "sha256:d6dd0be5b5b189d31db7cda48b91d7e0a9795f31430b7f271219ab30f1d3ac9d", + "sha256:d88b440e37a16e651bda4c7c2b930eb586fd15ca7406cb39e211fcff3bf3017d", + "sha256:de8a88e63464af587c950061a5e6a67d3632e36df62b986892331d4620a35c01", + "sha256:df2449253ef108a379b8b5d6b43f4b1a8e81a061d6537becd5582fba5f9196d7", + "sha256:e1c1493fb6e50ab01d20a22826e57520f1284df32f2d8601fdd90b6304601419", + "sha256:e1cf1972137e83c5d4c136c43ced9ac51d0e124706ee1c8aa8532c1287fa8795", + "sha256:e2103a929dfa2fcaf9bb4e7c091983a49c9ac3b19c9061b6d5427dd7d14d81a1", + "sha256:e56b7d45a839a697b5eb268c82a71bd8c7f6c94d6fd50c3d577fa39a9f1409f5", + "sha256:e8afc3f2ccfa24215f8cb28dcf43f0113ac3c37c2f0f0806d8c70e4228c5cf4d", + "sha256:e8fc20152abba6b83724d7ff268c249fa196d8259ff481f3b1476383f8f24e42", + "sha256:eaa9599de571d72e2daf60164784109f19978b327a3910d3e9de8c97b5b70cfe", + "sha256:ec15a59cf5af7be74194f7ab02d0f59a62bdcf1a537677ce67a2537c9b87fcda", + "sha256:f190daf01f13c72eac4efd5c430a8de82489d9cff23c364c3ea822545032993e", + "sha256:f34c41761022dd093b4b6896d4810782ffbabe30f2d443ff5f083e0cbbb8c737", + "sha256:f3e98bb3798ead92273dc0e5fd0f31ade220f59a266ffd8a4f6065e0a3ce0523", + "sha256:f42d0984e947b8adf7dd6dde396e720934d12c506ce84eea8476409563607591", + "sha256:f71a396b3bf33ecaa1626c255855702aca4d3d9fea5e051b41ac59a9c1c41edc", + "sha256:f9e130248f4462aaa8e2552d547f36ddadbeaa573879158d721bbd33dfe4743a", + "sha256:fed51ac40f757d41b7c48425901843666a6677e3e8eb0abcff09e4ba6e664f50" + ], + "markers": "python_version >= '3.9'", + "version": "==3.0.3" + } + }, + "develop": {} +} diff --git a/TP-02/config/vlan_ESW2.conf b/TP-02/config/vlan_ESW2.conf new file mode 100644 index 0000000..35c5fc3 --- /dev/null +++ b/TP-02/config/vlan_ESW2.conf @@ -0,0 +1,30 @@ +hostname ESW2 + +! Configuration des interfaces + +interface f1/1 + description Connexion vers le VLAN 10 + + switchport mode access + switchport access vlan 10 + + no shutdown + +interface f1/2 + description Connexion vers le VLAN 20 + + switchport mode access + switchport access vlan 20 + + no shutdown + +interface f1/0 + description Connexion vers le routeur R2 + + switchport mode trunk + switchport trunk allowed vlan add 10,20 + + no shutdown + + +end \ No newline at end of file diff --git a/TP-02/config/vlan_R02.conf b/TP-02/config/vlan_R02.conf new file mode 100644 index 0000000..724403b --- /dev/null +++ b/TP-02/config/vlan_R02.conf @@ -0,0 +1,15 @@ +hostname R2 + +interface g0/0.10 + description Gateway pour le reseau 172.16.30.0/24 + ip address 172.16.30.254 255.255.255.0 + encapsulation dot1Q 10 + no shutdown + +interface g0/0.20 + description Gateway pour le reseau 172.16.40.0/24 + ip address 172.16.40.254 255.255.255.0 + encapsulation dot1Q 20 + no shutdown + +end \ No newline at end of file diff --git a/TP-02/data/vlan_ESW2.json b/TP-02/data/vlan_ESW2.json new file mode 100644 index 0000000..831ba12 --- /dev/null +++ b/TP-02/data/vlan_ESW2.json @@ -0,0 +1,23 @@ +{ + "hostname": "ESW2", + "interfaces": [ + { + "name": "f1/1", + "mode": "access", + "vlan_id": "10", + "description": "Connexion vers le VLAN 10" + }, + { + "name": "f1/2", + "mode": "access", + "vlan_id": "20", + "description": "Connexion vers le VLAN 20" + }, + { + "name": "f1/0", + "mode": "trunk", + "vlan_id": "10,20", + "description": "Connexion vers le routeur R2" + } + ] +} diff --git a/TP-02/data/vlan_R02.json b/TP-02/data/vlan_R02.json new file mode 100644 index 0000000..3323d70 --- /dev/null +++ b/TP-02/data/vlan_R02.json @@ -0,0 +1,19 @@ +{ +"hostname": "R2", +"interfaces": [ +{ + "name": "g0/0.10", + "description": "Gateway pour le reseau 172.16.30.0/24", + "ip": "172.16.30.254", + "mask": "255.255.255.0", + "vlan_id": "10" + }, + { + "name": "g0/0.20", + "description": "Gateway pour le reseau 172.16.40.0/24", + "ip": "172.16.40.254", + "mask": "255.255.255.0", + "vlan_id": "20" + } + ] +} \ No newline at end of file diff --git a/TP-02/scripts/__pycache__/create_config.cpython-312.pyc b/TP-02/scripts/__pycache__/create_config.cpython-312.pyc new file mode 100644 index 0000000..a5d61b4 Binary files /dev/null and b/TP-02/scripts/__pycache__/create_config.cpython-312.pyc differ diff --git a/TP-02/scripts/create_config.py b/TP-02/scripts/create_config.py index f672537..b9a3106 100644 --- a/TP-02/scripts/create_config.py +++ b/TP-02/scripts/create_config.py @@ -4,21 +4,37 @@ from jinja2 import Template, Environment, FileSystemLoader env = Environment(loader=FileSystemLoader("templates")) def load_json_data_from_file(file_path): - pass + with open(file_path) as json_file: + data = json.load(json_file) + return data + + +def load_yaml_data_from_file(file_path): + with open(file_path) as yaml_file: + data = yaml.safe_load(yaml_file) + return data + def render_network_config(template_name, data): - pass + template = env.get_template(template_name) + return template.render(data) def save_built_config(file_name, data): - pass - + with open(file_name, "w") as f: + f.write(data) + return file_name def create_vlan_config_cpe_marseille(): """ Must return two values : router config and the switch config """ - pass + esw2_data = load_json_data_from_file(file_path='data/vlan_ESW2.json') + esw2_config = render_network_config(template_name='vlan_switch.j2', data=esw2_data) + + R2_data = load_json_data_from_file(file_path='data/vlan_R02.json') + R2_config = render_network_config(template_name='vlan_router.j2', data=R2_data) + return R2_config,esw2_config def create_vlan_config_cpe_paris(): @@ -32,9 +48,9 @@ if __name__ == "__main__": """ process question 1 to 5: """ - # r02_config, esw2_config = create_vlan_config_cpe_marseille() - # save_built_config('config/vlan_R02.conf', r02_config) - # save_built_config('config/vlan_ESW2.conf', esw2_config) + r02_config, esw2_config = create_vlan_config_cpe_marseille() + save_built_config('config/vlan_R02.conf', r02_config) + save_built_config('config/vlan_ESW2.conf', esw2_config) # r03_config, esw3_config = create_vlan_config_cpe_paris() # save_built_config('config/vlan_R03.conf', r03_config) diff --git a/TP-02/templates/README.md b/TP-02/templates/README.md deleted file mode 100644 index 182012e..0000000 --- a/TP-02/templates/README.md +++ /dev/null @@ -1,5 +0,0 @@ -# TEMPLATES - -**This directory is required.** - -The templates directory contains your jinja.j2 files. diff --git a/TP-02/templates/vlan_router.j2 b/TP-02/templates/vlan_router.j2 new file mode 100644 index 0000000..ba4e961 --- /dev/null +++ b/TP-02/templates/vlan_router.j2 @@ -0,0 +1,9 @@ +hostname {{ hostname }} +{% for interface in interfaces %} +interface {{ interface.name }} + description {{ interface.description }} + ip address {{ interface.ip }} {{ interface.mask }} + encapsulation dot1Q {{ interface.vlan_id }} + no shutdown +{% endfor %} +end \ No newline at end of file diff --git a/TP-02/templates/vlan_switch.j2 b/TP-02/templates/vlan_switch.j2 new file mode 100644 index 0000000..ae9b435 --- /dev/null +++ b/TP-02/templates/vlan_switch.j2 @@ -0,0 +1,22 @@ +hostname {{ hostname }} + +! Configuration des interfaces +{% for interface in interfaces %} +interface {{ interface.name }} + description {{ interface.description }} +{% if interface.mode == "access" %} + switchport mode access + switchport access vlan {{ interface.vlan_id }} +{% elif interface.mode == "trunk" %} + switchport mode trunk + switchport trunk allowed vlan add {{ interface.vlan_id }} +{% endif %} + no shutdown +{% endfor %} +{% if management is defined %} +! Configuration de l'IP de management +interface vlan {{ management.vlan }} + ip address {{ management.ip_address }} {{ management.subnet }} + no shutdown +{% endif %} +end \ No newline at end of file