-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
meraki_device module no longer query's Public IP's #389
Comments
Hello! Thank you! -- |
Hi Marcin,
It was a really simple query using ansible meraki_device module. When I query a specific network using the serial and store the result in a var, I can see two different results. When debugging, I was able to use Python requests on my RHEL9 machine with Python 3.9 for the actual query and I was able to pull all the public ips for our organization. It is only the ansible module that does not spit out public ips anymore on upgraded versions of ansible/Python. I can scrub the playbook tomorrow at work and show you example outputs of both machines and simple queries.
Thanks for your response!
Michael
…________________________________
From: Marcin Woźniak ***@***.***>
Sent: Sunday, December 4, 2022 7:53 AM
To: CiscoDevNet/ansible-meraki ***@***.***>
Cc: mzendan99 ***@***.***>; Author ***@***.***>
Subject: Re: [CiscoDevNet/ansible-meraki] meraki_device module no longer query's Public IP's (Issue #389)
Hello!
Firstly, can you provide the example code when that incompatibility appeared.
Secondly, from the GUI have you got a the same active public IPs?
Thank you!
--
Marcin
—
Reply to this email directly, view it on GitHub<#389 (comment)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/A4K2APDK276OLHMK36CRHKTWLSH4TANCNFSM6AAAAAASSH3M74>.
You are receiving this because you authored the thread.Message ID: ***@***.***>
|
What endpoint are you querying in Python to get the public IP address? The documentation isn't showing the one I use which is basically I'm curious why the Ansible version change is affecting things, if indeed it is. I'd like to work with you on this one more to resolve the issue. Thank you. |
Endpoint = /organizations/{org_id}/devices/statuses
|
That's what is happening. I'm not querying the statuses endpoint. Are you looking to query all devices in the organization or just a single one? I'm using |
I use it to query all the devices in our org and then the rest of my playbook filters and extracts the public IP's to automate conditional access in azure for our meraki sites. I spent a significant amount of time trying to get it working with ansible modules, thinking I was doing something wrong, but this simple python request does the job for now. Do you need anything from me to help test this? |
At this moment, no. I'll need to do a stare and compare to see what's different between the old and new one. I may come back to you for something though, but nothing now. Thank you for asking. |
Well that was quick. I won't be able to swap out the old endpoint with the new endpoint as the new one lacks geographical information. I'm going to think about how to implement it. My current thought is something like:
|
@kbreit Hi, It's been a little while, but I was curious if you implemented any changes for the endpoint? |
I haven't had an opportunity to delve into this yet. There's the possibility this is going to be significant effort so I will try to look soon and give an estimate. |
No worries at all. My work around runs fine so there is no rush. Thanks for the follow up though. |
The way the endpoint works is very different. It needs the organization ID and uses parameters as filters whereas the current one uses the serial number. There are two approaches I could take:
I'm leaning toward the second one but curious if you have a preference. |
Hey @kbreit, its been a while since I have had time to get back into this. I appreciate you looking into it! I definitely want to clean up my playbook for this function and don't want to keep it hacked together with python. I am still dropping alot of devices across our meraki sites for some reason and can't find a correlation as to why some appliances aren't being picked up, when others are. As per your last reply, creating a new module for this endpoint would be awesome, but I am not sure how much effort that will take on your part. I will keep an eye on this thread and hope to hear back from your soon! Let me know if you need some screenshots from me, Thanks again. |
I am still open to creating a new module for this. I cannot commit to when it would be completed but the endpoint doesn't seem too challenging, especially since I have pagination built into the normal request function. |
@mzendan99 Please try the new |
Hi, haven't posted on here before, so not sure if I am doing this wrong.
I have been converting my playbooks on RHEL 7.9 & Ansible Version 2.9.27 to RHEL 9 , Ansible Version 2.14.0
Any help/insight would be appreciated.
The text was updated successfully, but these errors were encountered: