Configuring Local Breakout via script error

JRobinson855
New here

Configuring Local Breakout via script error

meraki: ERROR > appliance, updateNetworkApplianceTrafficShapingVpnExclusions - 400 Bad Request, {'errors': ['Configuring Major Application VPN exclusion rules requires the SDWAN+ license']}

 

Local Breakout by application requires this enhanced license. Local breakout by IP does not.

 

But the function in the library doesn't seem to care much. It seems to try to configure major application rules even when there's no code to do so.

 

Anyone know of any workarounds?

 

 

14 Replies 14
alemabrahao
Kind of a big deal

Do you have the SD-WAN plus license? If you don't have it, you won't be able to enable it.

 

Requirements:

The following are the requirements to utilize this feature in a network:

I am not a Cisco Meraki employee. My suggestions are based on documentation of Meraki best practices and day-to-day experience.

Please, if this post was useful, leave your kudos and mark it as solved.
JRobinson855
New here

I'm not trying to enable Application Exclusion, I'm trying to write a script using the Meraki Python library for VPN exclusion by IP, which is a feature I'm already using on several networks

alemabrahao
Kind of a big deal

And can you share the script so I can try to find the error? Just to make it clear that the previous question was because you didn't mention that you have the license. 😉

I am not a Cisco Meraki employee. My suggestions are based on documentation of Meraki best practices and day-to-day experience.

Please, if this post was useful, leave your kudos and mark it as solved.
alemabrahao
Kind of a big deal

This is an example script.

 

import requests

# Replace with your own API key and Meraki organization ID
api_key = "YOUR_API_KEY"
org_id = "YOUR_ORG_ID"

# Define the API endpoint for VPN exclusions
url = f"https://api.meraki.com/api/v1/organizations/{org_id}/appliance/vpn/exclusions"

# Example payload for application-based exclusion
payload = {
"name": "Office 365 Suite",
"type": "application",
"value": "office365",
}

# Make the API request
headers = {"X-Cisco-Meraki-API-Key": api_key}
response = requests.post(url, json=payload, headers=headers)

if response.status_code == 201:
print("Exclusion rule added successfully!")
else:
print(f"Error: {response.status_code} - {response.text}")

I am not a Cisco Meraki employee. My suggestions are based on documentation of Meraki best practices and day-to-day experience.

Please, if this post was useful, leave your kudos and mark it as solved.
JRobinson855
New here

I'll see if I can give this a shot

RaphaelL
Kind of a big deal
Kind of a big deal

What is the payload that you are sending ? 

JRobinson855
New here

I'm using the Python Library and only using the 'custom' payload.

 

dashboard.appliance.updateNetworkApplianceTrafficShapingVpnExclusions(network_id, custom=[{'protocol': 'tcp', 'destination': '192.168.3.0/24', 'port': '8000'}])

 

Put this example for reference


I understand the Application exclusion requires the SDWAN+ license, but I shouldn't need it to execute code that isn't deploying that feature.

rhbirkelund
Kind of a big deal
Kind of a big deal

According to the endpoint docs schema definition, it looks like that both "custom" and "majorApplications" are required fields. So I don't think you can use that endpoint without also setting "majorApplications". And since that is a SDW+ feature, I guess it would fail for you.

LinkedIn ::: https://blog.rhbirkelund.dk/

Like what you see? - Give a Kudo ## Did it answer your question? - Mark it as a Solution 🙂

All code examples are provided as is. Responsibility for Code execution lies solely your own.
rhbirkelund
Kind of a big deal
Kind of a big deal

If you pass it with an empty list, does that make a difference? I.e.

 

response = dashboard.appliance.updateNetworkApplianceTrafficShapingVpnExclusions(network_id,
    custom=[{'protocol': 'tcp', 'destination': '192.168.3.0/24', 'port': '8000'}],
    majorApplications=[]
)

 

 

LinkedIn ::: https://blog.rhbirkelund.dk/

Like what you see? - Give a Kudo ## Did it answer your question? - Mark it as a Solution 🙂

All code examples are provided as is. Responsibility for Code execution lies solely your own.
JRobinson855
New here

It didn't seem to appreciate an empty list much, lol. Had the same error

rhbirkelund
Kind of a big deal
Kind of a big deal

Does your Spoke site have a Default Route configured on the VPN?

 

Configuring VPN Exclusion Rules (IP/Port)

The L3 VPN Exclusion configuration is available under Security & SD-WAN > SD-WAN and Traffic Shaping or Teleworker Gateway > Traffic Shaping.

The configuration option will appear if:

  • The spoke has at least one default route configured for a hub or
  • A hub is sharing the default route via an advanced routing protocol or
  • A hub with at least one exit hub configured.
LinkedIn ::: https://blog.rhbirkelund.dk/

Like what you see? - Give a Kudo ## Did it answer your question? - Mark it as a Solution 🙂

All code examples are provided as is. Responsibility for Code execution lies solely your own.
JRobinson855
New here

There's a default route at one of the hubs shared out via SDWAN

TomStewart
Comes here often

Did you ever manage to work this one our or is the license required?

I've just built an app to push VPNExclusions to our sites as adding them manually to each site is a pain.

We only have IP and DNS exclusions, no applications but I get the same error when I try to push via the API.

 

Cheers

Chase_Gleason
Meraki Employee
Meraki Employee

SDW+ license is not required but you do need to pass any empty array for major applications. 

 

If using the Python SDK it will look like this. 

dashboard.appliance.updateNetworkApplianceTrafficShapingVpnExclusions(network, custom = exclusionsPayload, majorApplications = [])

 

 

Get notified when there are additional replies to this discussion.