Closed sueleymanaydemir closed 1 year ago
Hi @sueleymanaydemir
I reviewed your playbook and everything looks good, only one thing, ansible_httpapi_use_ssl, is your fgt device is licensed? if it's licensed, you have to change it to yes. Also, ansible_httpapi_port, https protocol transfers encrypted data to 443 (depending on your configurations). I'd like to confirm some information with you.
Hi @sueleymanaydemir
I reviewed your playbook and everything looks good, only one thing, ansible_httpapi_use_ssl, is your fgt device is licensed? if it's licensed, you have to change it to yes. Also, ansible_httpapi_port, https protocol transfers encrypted data to 443 (depending on your configurations). I'd like to confirm some information with you.
- Did the first task execute successfully? ----> name: Configure global attributes.
- Does port10 exist on your devices?
Hi, yes the first task executed successfully and port10 definitely exist. I tried port 2-9 too, but got the same error.
Thanks for the confirmation! @sueleymanaydemir
Can you please enable_log in the playbook and send me a copy of the log? Here's an example:
tasks:
- name: Configure Port10 on FG1
fortios_system_interface:
enable_log: True
vdom: "{{ vdom }}"
state: "present"
system_interface:
name: "port10"
vdom: "root"
allowaccess: [ping,http,https,ssh]
ip: "192.168.56.111 255.255.255.0"
The log is saved in the path /tmp/fortios.ansible.log
Thanks for the confirmation! @sueleymanaydemir
Can you please enable_log in the playbook and send me a copy of the log? Here's an example:
tasks: - name: Configure Port10 on FG1 fortios_system_interface: enable_log: True vdom: "{{ vdom }}" state: "present" system_interface: name: "port10" vdom: "root" allowaccess: [ping,http,https,ssh] ip: "192.168.56.111 255.255.255.0"
The log is saved in the path /tmp/fortios.ansible.log
Here is the Log Output:
2023-10-24 07:49:34.300413: checking system_version
2023-10-24 07:49:34.300585: perform pre request login
2023-10-24 07:49:34.300662: login with username and password, try API based auth first
2023-10-24 07:49:34.300762: Sending request: METHOD:POST URL:/api/v2/authentication DATA:{"username": "admin", "secretkey": "admin", "ack_post_disclaimer": true, "ack_pre_disclaimer": true, "request_key": true}
2023-10-24 07:49:34.300915: login with username and password, try API based auth first
2023-10-24 07:49:34.300973: Sending request: METHOD:POST URL:/api/v2/authentication DATA:{"username": "admin", "secretkey": "admin", "ack_post_disclaimer": true, "ack_pre_disclaimer": true, "request_key": true}
2023-10-24 07:49:34.344497: updated auth headers: dict_items([('Accept', 'application/json')])
2023-10-24 07:49:34.344533: response data: {
"status_code":5,
"status_message":"LOGIN_SUCCESS",
"session_key":"9wc9ywng7whjfxk9gsfdb9gf947gwx",
"session_key_timeout":"23"
}...<truncated>
2023-10-24 07:49:34.344556: API based auth with user: admin succeeds
2023-10-24 07:49:34.344582: checking system_version
2023-10-24 07:49:34.344617: Sending request: METHOD:GET URL:/api/v2/monitor/system/status?vdom=root&access_token=9wc9ywng7whjfxk9gsfdb9gf947gwx DATA:
2023-10-24 07:49:34.353220: using access token - no auth update needed: 9wc9ywng7whjfxk9gsfdb9gf947gwx
2023-10-24 07:49:34.353259: response data: {
"http_method":"GET",
"results":{
"model_name":"FortiGate",
"model_number":"VM64-KVM",
"model":"FGVMK6",
"hostname":"FortiGate02",
"log_disk_status":"available"
},
"vdom":...<truncated>
2023-10-24 07:49:34.353312: system version: v7.0.5
2023-10-24 07:49:34.353327: ansible version: v6.0.0
2023-10-24 07:49:34.370099: using access token - no auth update needed: 9wc9ywng7whjfxk9gsfdb9gf947gwx
2023-10-24 07:49:34.370149: response data: {
"status_code":5,
"status_message":"LOGIN_SUCCESS",
"session_key":"gnHw7dttGjyy6kHbNkw18g5cwf4yw5",
"session_key_timeout":"23"
}...<truncated>
2023-10-24 07:49:34.370179: API based auth with user: admin succeeds
2023-10-24 07:49:34.370207: checking system_version
2023-10-24 07:49:34.370227: Sending request: METHOD:GET URL:/api/v2/monitor/system/status?vdom=root&access_token=gnHw7dttGjyy6kHbNkw18g5cwf4yw5 DATA:
2023-10-24 07:49:34.375290: using access token - no auth update needed: gnHw7dttGjyy6kHbNkw18g5cwf4yw5
2023-10-24 07:49:34.375339: response data: {
"http_method":"GET",
"results":{
"model_name":"FortiGate",
"model_number":"VM64-KVM",
"model":"FGVMK6",
"hostname":"FortiGate02",
"log_disk_status":"available"
},
"vdom":...<truncated>
2023-10-24 07:49:34.375388: system version: v7.0.5
2023-10-24 07:49:34.375401: ansible version: v6.0.0
2023-10-24 07:49:34.377040: Sending request: METHOD:PUT URL:/api/v2/cmdb/system/interface/port10?vdom=root&access_token=gnHw7dttGjyy6kHbNkw18g5cwf4yw5 DATA:{"allowaccess": "ping http https ssh", "ip": "192.168.56.111/24", "name": "port10", "vdom": "root"}
2023-10-24 07:49:34.398262: Exception thrown from handling http: HTTP Error 500: Internal Server Error
2023-10-24 07:49:34.398465: using access token - no auth update needed: gnHw7dttGjyy6kHbNkw18g5cwf4yw5
2023-10-24 07:49:34.398512: response data: {
"http_method":"PUT",
"revision":"bc80a10633d3d8e6871988d1e2fbbe3a",
"revision_changed":false,
"cli_error":"Subnets overlap between 'port10' with primary IP of 'port1'\nnode_check_object fail...<truncated>
2023-10-24 07:49:34.399233: Sending request: METHOD:POST URL:/api/v2/cmdb/system/interface?vdom=root&access_token=gnHw7dttGjyy6kHbNkw18g5cwf4yw5 DATA:{"allowaccess": "ping http https ssh", "ip": "192.168.56.111/24", "name": "port10", "vdom": "root"}
2023-10-24 07:49:34.404593: Exception thrown from handling http: HTTP Error 500: Internal Server Error
2023-10-24 07:49:34.404701: using access token - no auth update needed: gnHw7dttGjyy6kHbNkw18g5cwf4yw5
2023-10-24 07:49:34.404735: response data: {
"http_method":"POST",
"revision":"bc80a10633d3d8e6871988d1e2fbbe3a",
"revision_changed":false,
"error":-5,
"status":"error",
"http_status":500,
"vdom":"root",
"path":"system",
"nam...<truncated>
2023-10-24 07:49:34.457573: logout
2023-10-24 07:49:34.457647: Sending request: METHOD:DELETE URL:/api/v2/authentication?access_token=gnHw7dttGjyy6kHbNkw18g5cwf4yw5 DATA:
2023-10-24 07:49:34.464980: using access token - no auth update needed: gnHw7dttGjyy6kHbNkw18g5cwf4yw5
2023-10-24 07:49:34.465073: response data: {
"status":"API_LOGOUT_SUCCESS",
"status_id":0
}...<truncated>
The issue coming from IP Address :
...
Subnets overlap between 'port10' with primary IP of 'port1
...
The issue coming from IP Address :
... Subnets overlap between 'port10' with primary IP of 'port1 ...
Thank you very much, you are right! This was the problem and after editing my playbook, it now works fine. :)
Hi guys,
i'm learning some ansible basics at the moment. I created some small tasks already successfully. for exmaple, i was able to change the hostname and some other global settigs on my both FortiGate VMs.
But now, i wanted to enable Port10, assign an IP & set allowaccess.
This time, i get an error:
`PLAY [fortigates] **
TASK [Gathering Facts] ***** [DEPRECATION WARNING]: Distribution ubuntu 22.04 on host FG1 should use /usr/bin/python3, but is using /usr/bin/python for backward compatibility with prior Ansible releases. A future Ansible release will default to using the discovered platform python for this host. See https://docs.ansible.com/ansible/2.10/reference_appendices/interpreter_discovery.html for more information. This feature will be removed in version 2.12. Deprecation warnings can be disabled by setting deprecation_warnings=False in ansible.cfg. ok: [FG1] [DEPRECATION WARNING]: Distribution ubuntu 22.04 on host FG2 should use /usr/bin/python3, but is using /usr/bin/python for backward compatibility with prior Ansible releases. A future Ansible release will default to using the discovered platform python for this host. See https://docs.ansible.com/ansible/2.10/reference_appendices/interpreter_discovery.html for more information. This feature will be removed in version 2.12. Deprecation warnings can be disabled by setting deprecation_warnings=False in ansible.cfg. ok: [FG2]
TASK [Configure global attributes.] **** ok: [FG2] ok: [FG1]
PLAY [FG1] *****
TASK [Gathering Facts] ***** ok: [FG1]
TASK [Configure Port10 on FG1] ***** fatal: [FG1]: FAILED! => {"changed": false, "meta": {"build": 304, "error": -5, "http_method": "POST", "http_status": 500, "name": "interface", "path": "system", "revision": "96528c0c5c2d57cbd51dce6b075d78be", "revision_changed": false, "serial": "FGVMEVFXB3S0Z5DA", "status": "error", "vdom": "root", "version": "v7.0.5"}, "msg": "Error in repo"}
PLAY RECAP ***** FG1 : ok=3 changed=0 unreachable=0 failed=1 skipped=0 rescued=0 ignored=0
FG2 : ok=2 changed=0 unreachable=0 failed=0 skipped=0 rescued=0 ignored=0`
My Playbook looks like this:
`---
hosts: fortigates collections:
hosts: FG1 collections:
hosts: FG2 collections: