B ` @sGdddeZdS)csLeZdZfddZedddZedddZedd d Zedd d Zeeed ddZ eedddZ eedddZ edddZ eedddZ eedddZeedddZeedddZeeeed d!d"Zeeed#d$d%Zeeed#d&d'Zeedd(d)Zeedd*d+Zeedd,d-Zeedd.d/ZZS)0ActionBatchWirelesscstt|dS)N)superr__init__)self) __class__t/private/var/folders/7j/8686xlfs15q3tgljmghtvg0r0000gn/T/pip-target-isidps9b/lib/python/meraki/api/batch/wireless.pyrszActionBatchWireless.__init__)serialc sZ|tddddgdd}d|d}d d d gfd d |D}|d|d}|S)a **Update the bluetooth settings for a wireless device** https://developer.cisco.com/meraki/api-v1/#!update-device-wireless-bluetooth-settings - serial (string): (required) - uuid (string): Desired UUID of the beacon. If the value is set to null it will reset to Dashboard's automatically generated value. - major (integer): Desired major value of the beacon. If the value is set to null it will reset to Dashboard's automatically generated value. - minor (integer): Desired minor value of the beacon. If the value is set to null it will reset to Dashboard's automatically generated value. wireless configureZ bluetoothsettings%updateDeviceWirelessBluetoothSettings)tags operationz /devices/z/wireless/bluetooth/settingsuuidmajorminorcs&i|]\}}|kr||qSr)strip).0kv) body_paramsrr szMActionBatchWireless.updateDeviceWirelessBluetoothSettings..update)resourcerbody)rlocalsitems)rrkwargsmetadatarpayloadactionr)rrr s    z9ActionBatchWireless.updateDeviceWirelessBluetoothSettingsc sZ|tddddgdd}d|d}d d d gfd d |D}|d|d}|S)a **Update the radio settings of a device** https://developer.cisco.com/meraki/api-v1/#!update-device-wireless-radio-settings - serial (string): (required) - rfProfileId (integer): The ID of an RF profile to assign to the device. If the value of this parameter is null, the appropriate basic RF profile (indoor or outdoor) will be assigned to the device. Assigning an RF profile will clear ALL manually configured overrides on the device (channel width, channel, power). - twoFourGhzSettings (object): Manual radio settings for 2.4 GHz. - fiveGhzSettings (object): Manual radio settings for 5 GHz. r r Zradior !updateDeviceWirelessRadioSettings)r rz /devices/z/wireless/radio/settings rfProfileIdtwoFourGhzSettingsfiveGhzSettingscs&i|]\}}|kr||qSr)r)rrr)rrrr<szIActionBatchWireless.updateDeviceWirelessRadioSettings..r)rrr)rrr)rrrrrrr r)rrr!(s    z5ActionBatchWireless.updateDeviceWirelessRadioSettings) networkIdc sZ|tdddgdd}d|d}dd d d gfd d |D}|d|d}|S)aY **Update alternate management interface and device static IP** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-alternate-management-interface - networkId (string): (required) - enabled (boolean): Boolean value to enable or disable alternate management interface - vlanId (integer): Alternate management interface VLAN, must be between 1 and 4094 - protocols (array): Can be one or more of the following values: 'radius', 'snmp', 'syslog' or 'ldap' - accessPoints (array): Array of access point serial number and IP assignment. Note: accessPoints IP assignment is not applicable for template networks, in other words, do not put 'accessPoints' in the body when updating template networks. Also, an empty 'accessPoints' array will remove all previous static IP assignments r r ZalternateManagementInterface1updateNetworkWirelessAlternateManagementInterface)r rz /networks/z&/wireless/alternateManagementInterfaceenabledvlanIdZ protocolsZ accessPointscs&i|]\}}|kr||qSr)r)rrr)rrrr^szYActionBatchWireless.updateNetworkWirelessAlternateManagementInterface..r)rrr)rrr)rr%rrrrr r)rrr&Is   zEActionBatchWireless.updateNetworkWirelessAlternateManagementInterfacec sV|tdddgdd}d|d}dd gfd d |D}|d |d }|S)ac **Update the billing settings** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-billing - networkId (string): (required) - currency (string): The currency code of this node group's billing plans - plans (array): Array of billing plans in the node group. (Can configure a maximum of 5) r r billingupdateNetworkWirelessBilling)r rz /networks/z/wireless/billingcurrencyZplanscs&i|]\}}|kr||qSr)r)rrr)rrrr~szDActionBatchWireless.updateNetworkWirelessBilling..r)rrr)rrr)rr%rrrrr r)rrr*ks  z0ActionBatchWireless.updateNetworkWirelessBilling)r%namebandSelectionTypec  s|td|kr@ddg}|d|ks@td|dd|d|krtddg}|d|ksttd|dd|d d d gd d }d|d}dddddddgfdd|D}|d|d} | S)a **Creates new RF profile for this network** https://developer.cisco.com/meraki/api-v1/#!create-network-wireless-rf-profile - networkId (string): (required) - name (string): The name of the new profile. Must be unique. This param is required on creation. - bandSelectionType (string): Band selection can be set to either 'ssid' or 'ap'. This param is required on creation. - clientBalancingEnabled (boolean): Steers client to best available access point. Can be either true or false. Defaults to true. - minBitrateType (string): Minimum bitrate can be set to either 'band' or 'ssid'. Defaults to band. - apBandSettings (object): Settings that will be enabled if selectionType is set to 'ap'. - twoFourGhzSettings (object): Settings related to 2.4Ghz band - fiveGhzSettings (object): Settings related to 5Ghz band minBitrateTypebandssidz"minBitrateType" cannot be "z", & must be set to one of: r-apz"bandSelectionType" cannot be "r r rfProfilescreateNetworkWirelessRfProfile)r rz /networks/z/wireless/rfProfilesr,clientBalancingEnabledapBandSettingsr#r$cs&i|]\}}|kr||qSr)r)rrr)rrrrszFActionBatchWireless.createNetworkWirelessRfProfile..create)rrr)rrAssertionErrorr) rr%r,r-roptionsrrrr r)rrr3s  $$ z2ActionBatchWireless.createNetworkWirelessRfProfile)r%r"c  s|td|kr@ddg}|d|ks@td|dd|d|krtddg}|d|ksttd|dd|d d d gd d }d|d|}dddddddgfdd|D}|d|d}|S)aK **Updates specified RF profile for this network** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-rf-profile - networkId (string): (required) - rfProfileId (string): (required) - name (string): The name of the new profile. Must be unique. - clientBalancingEnabled (boolean): Steers client to best available access point. Can be either true or false. - minBitrateType (string): Minimum bitrate can be set to either 'band' or 'ssid'. - bandSelectionType (string): Band selection can be set to either 'ssid' or 'ap'. - apBandSettings (object): Settings that will be enabled if selectionType is set to 'ap'. - twoFourGhzSettings (object): Settings related to 2.4Ghz band - fiveGhzSettings (object): Settings related to 5Ghz band r.r/r0z"minBitrateType" cannot be "z", & must be set to one of: r-r1z"bandSelectionType" cannot be "r r r2updateNetworkWirelessRfProfile)r rz /networks/z/wireless/rfProfiles/r,r4r5r#r$cs&i|]\}}|kr||qSr)r)rrr)rrrrszFActionBatchWireless.updateNetworkWirelessRfProfile..r)rrr)rrr7r) rr%r"rr8rrrr r)rrr9s  $$z2ActionBatchWireless.updateNetworkWirelessRfProfilecCs0dddgdd}d|d|}|dtd }|S) z **Delete a RF Profile** https://developer.cisco.com/meraki/api-v1/#!delete-network-wireless-rf-profile - networkId (string): (required) - rfProfileId (string): (required) r r r2deleteNetworkWirelessRfProfile)r rz /networks/z/wireless/rfProfiles/destroy)rrr)r)rr%r"rrr rrrr:s z2ActionBatchWireless.deleteNetworkWirelessRfProfilec s|td|kr@ddg}|d|ks@td|dd|dddgd d }d |d }d ddddgfdd|D}|d|d}|S)as **Update the wireless settings for a network** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-settings - networkId (string): (required) - meshingEnabled (boolean): Toggle for enabling or disabling meshing in a network - ipv6BridgeEnabled (boolean): Toggle for enabling or disabling IPv6 bridging in a network (Note: if enabled, SSIDs must also be configured to use bridge mode) - locationAnalyticsEnabled (boolean): Toggle for enabling or disabling location analytics for your network - upgradeStrategy (string): The upgrade strategy to apply to the network. Must be one of 'minimizeUpgradeTime' or 'minimizeClientDowntime'. Requires firmware version MR 26.8 or higher' - ledLightsOn (boolean): Toggle for enabling or disabling LED lights on all APs in the network (making them run dark) ZupgradeStrategyZminimizeUpgradeTimeZminimizeClientDowntimez"upgradeStrategy" cannot be "z", & must be set to one of: r r r updateNetworkWirelessSettings)r rz /networks/z/wireless/settingsZmeshingEnabledZipv6BridgeEnabledZlocationAnalyticsEnabledZ ledLightsOncs&i|]\}}|kr||qSr)r)rrr)rrrrszEActionBatchWireless.updateNetworkWirelessSettings..r)rrr)rrr7r)rr%rr8rrrr r)rrr<s $ z1ActionBatchWireless.updateNetworkWirelessSettings)r%numberc 6 s|td|krNdddddddd d g }|d|ksNtd |dd |d |krddg}|d |kstd|d d |d|krddg}|d|kstd|dd |d|krdddddg}|d|kstd|dd |d|kr@dddd d!d"d#d$d%d&d'd(d)d*g}|d|ks@td+|dd |d,|krxd-d.g}|d,|ksxtd/|d,d |d0|krd1d2g}|d0|kstd3|d0d |d4|krd5d6d7d8g}|d4|kstd9|d4d |d:d;d}d?|d@|}dAdBdd ddddCdDddEdFdGdHdIdJdKdLdMdNdOdPdQdRd,d0dSdTdUd4dVdWdXdYdZd[d\d]d^d_d`dadbdcdddedfdgdhdidjdkdldmg6fdndo|D}|dp|dq}|S)ra# **Update the attributes of an MR SSID** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid - networkId (string): (required) - number (string): (required) - name (string): The name of the SSID - enabled (boolean): Whether or not the SSID is enabled - authMode (string): The association control method for the SSID ('open', 'psk', 'open-with-radius', '8021x-meraki', '8021x-radius', '8021x-google', '8021x-localradius', 'ipsk-with-radius' or 'ipsk-without-radius') - enterpriseAdminAccess (string): Whether or not an SSID is accessible by 'enterprise' administrators ('access disabled' or 'access enabled') - encryptionMode (string): The psk encryption mode for the SSID ('wep' or 'wpa'). This param is only valid if the authMode is 'psk' - psk (string): The passkey for the SSID. This param is only valid if the authMode is 'psk' - wpaEncryptionMode (string): The types of WPA encryption. ('WPA1 only', 'WPA1 and WPA2', 'WPA2 only', 'WPA3 Transition Mode' or 'WPA3 only') - dot11w (object): The current setting for Protected Management Frames (802.11w). - dot11r (object): The current setting for 802.11r - splashPage (string): The type of splash page for the SSID ('None', 'Click-through splash page', 'Billing', 'Password-protected with Meraki RADIUS', 'Password-protected with custom RADIUS', 'Password-protected with Active Directory', 'Password-protected with LDAP', 'SMS authentication', 'Systems Manager Sentry', 'Facebook Wi-Fi', 'Google OAuth', 'Sponsored guest', 'Cisco ISE' or 'Google Apps domain'). This attribute is not supported for template children. - splashGuestSponsorDomains (array): Array of valid sponsor email domains for sponsored guest splash type. - oauth (object): The OAuth settings of this SSID. Only valid if splashPage is 'Google OAuth'. - localRadius (object): The current setting for Local Authentication, a built-in RADIUS server on the access point. Only valid if authMode is '8021x-localradius'. - ldap (object): The current setting for LDAP. Only valid if splashPage is 'Password-protected with LDAP'. - activeDirectory (object): The current setting for Active Directory. Only valid if splashPage is 'Password-protected with Active Directory' - radiusServers (array): The RADIUS 802.1X servers to be used for authentication. This param is only valid if the authMode is 'open-with-radius', '8021x-radius' or 'ipsk-with-radius' - radiusProxyEnabled (boolean): If true, Meraki devices will proxy RADIUS messages through the Meraki cloud to the configured RADIUS auth and accounting servers. - radiusTestingEnabled (boolean): If true, Meraki devices will periodically send Access-Request messages to configured RADIUS servers using identity 'meraki_8021x_test' to ensure that the RADIUS servers are reachable. - radiusCalledStationId (string): The template of the called station identifier to be used for RADIUS (ex. $NODE_MAC$:$VAP_NUM$). - radiusAuthenticationNasId (string): The template of the NAS identifier to be used for RADIUS authentication (ex. $NODE_MAC$:$VAP_NUM$). - radiusServerTimeout (integer): The amount of time for which a RADIUS client waits for a reply from the RADIUS server (must be between 1-10 seconds). - radiusServerAttemptsLimit (integer): The maximum number of transmit attempts after which a RADIUS server is failed over (must be between 1-5). - radiusFallbackEnabled (boolean): Whether or not higher priority RADIUS servers should be retried after 60 seconds. - radiusCoaEnabled (boolean): If true, Meraki devices will act as a RADIUS Dynamic Authorization Server and will respond to RADIUS Change-of-Authorization and Disconnect messages sent by the RADIUS server. - radiusFailoverPolicy (string): This policy determines how authentication requests should be handled in the event that all of the configured RADIUS servers are unreachable ('Deny access' or 'Allow access') - radiusLoadBalancingPolicy (string): This policy determines which RADIUS server will be contacted first in an authentication attempt and the ordering of any necessary retry attempts ('Strict priority order' or 'Round robin') - radiusAccountingEnabled (boolean): Whether or not RADIUS accounting is enabled. This param is only valid if the authMode is 'open-with-radius', '8021x-radius' or 'ipsk-with-radius' - radiusAccountingServers (array): The RADIUS accounting 802.1X servers to be used for authentication. This param is only valid if the authMode is 'open-with-radius', '8021x-radius' or 'ipsk-with-radius' and radiusAccountingEnabled is 'true' - radiusAccountingInterimInterval (integer): The interval (in seconds) in which accounting information is updated and sent to the RADIUS accounting server. - radiusAttributeForGroupPolicies (string): Specify the RADIUS attribute used to look up group policies ('Filter-Id', 'Reply-Message', 'Airespace-ACL-Name' or 'Aruba-User-Role'). Access points must receive this attribute in the RADIUS Access-Accept message - ipAssignmentMode (string): The client IP assignment mode ('NAT mode', 'Bridge mode', 'Layer 3 roaming', 'Layer 3 roaming with a concentrator' or 'VPN') - useVlanTagging (boolean): Whether or not traffic should be directed to use specific VLANs. This param is only valid if the ipAssignmentMode is 'Bridge mode' or 'Layer 3 roaming' - concentratorNetworkId (string): The concentrator to use when the ipAssignmentMode is 'Layer 3 roaming with a concentrator' or 'VPN'. - vlanId (integer): The VLAN ID used for VLAN tagging. This param is only valid when the ipAssignmentMode is 'Layer 3 roaming with a concentrator' or 'VPN' - defaultVlanId (integer): The default VLAN ID used for 'all other APs'. This param is only valid when the ipAssignmentMode is 'Bridge mode' or 'Layer 3 roaming' - apTagsAndVlanIds (array): The list of tags and VLAN IDs used for VLAN tagging. This param is only valid when the ipAssignmentMode is 'Bridge mode' or 'Layer 3 roaming' - walledGardenEnabled (boolean): Allow access to a configurable list of IP ranges, which users may access prior to sign-on. - walledGardenRanges (array): Specify your walled garden by entering an array of addresses, ranges using CIDR notation, domain names, and domain wildcards (e.g. '192.168.1.1/24', '192.168.37.10/32', 'www.yahoo.com', '*.google.com']). Meraki's splash page is automatically included in your walled garden. - radiusOverride (boolean): If true, the RADIUS response can override VLAN tag. This is not valid when ipAssignmentMode is 'NAT mode'. - radiusGuestVlanEnabled (boolean): Whether or not RADIUS Guest VLAN is enabled. This param is only valid if the authMode is 'open-with-radius' and addressing mode is not set to 'isolated' or 'nat' mode - radiusGuestVlanId (integer): VLAN ID of the RADIUS Guest VLAN. This param is only valid if the authMode is 'open-with-radius' and addressing mode is not set to 'isolated' or 'nat' mode - minBitrate (number): The minimum bitrate in Mbps. ('1', '2', '5.5', '6', '9', '11', '12', '18', '24', '36', '48' or '54') - bandSelection (string): The client-serving radio frequencies. ('Dual band operation', '5 GHz band only' or 'Dual band operation with Band Steering') - perClientBandwidthLimitUp (integer): The upload bandwidth limit in Kbps. (0 represents no limit.) - perClientBandwidthLimitDown (integer): The download bandwidth limit in Kbps. (0 represents no limit.) - perSsidBandwidthLimitUp (integer): The total upload bandwidth limit in Kbps. (0 represents no limit.) - perSsidBandwidthLimitDown (integer): The total download bandwidth limit in Kbps. (0 represents no limit.) - lanIsolationEnabled (boolean): Boolean indicating whether Layer 2 LAN isolation should be enabled or disabled. Only configurable when ipAssignmentMode is 'Bridge mode'. - visible (boolean): Boolean indicating whether APs should advertise or hide this SSID. APs will only broadcast this SSID if set to true - availableOnAllAps (boolean): Boolean indicating whether all APs should broadcast the SSID or if it should be restricted to APs matching any availability tags. Can only be false if the SSID has availability tags. - availabilityTags (array): Accepts a list of tags for this SSID. If availableOnAllAps is false, then the SSID will only be broadcast by APs with tags matching any of the tags in this list. - mandatoryDhcpEnabled (boolean): If true, Mandatory DHCP will enforce that clients connecting to this SSID must use the IP address assigned by the DHCP server. Clients who use a static IP address won't be able to associate. - adultContentFilteringEnabled (boolean): Boolean indicating whether or not adult content will be blocked - dnsRewrite (object): DNS servers rewrite settings ZauthModeopenZpskzopen-with-radiusz 8021x-merakiz 8021x-radiusz 8021x-googlez8021x-localradiuszipsk-with-radiuszipsk-without-radiusz"authMode" cannot be "z", & must be set to one of: ZenterpriseAdminAccesszaccess disabledzaccess enabledz#"enterpriseAdminAccess" cannot be "ZencryptionModeZwepZwpaz"encryptionMode" cannot be "ZwpaEncryptionModez WPA1 onlyz WPA1 and WPA2z WPA2 onlyzWPA3 Transition Modez WPA3 onlyz"wpaEncryptionMode" cannot be "Z splashPageNonezClick-through splash pageZBillingz%Password-protected with Meraki RADIUSz%Password-protected with custom RADIUSz(Password-protected with Active DirectoryzPassword-protected with LDAPzSMS authenticationzSystems Manager SentryzFacebook Wi-Fiz Google OAuthzSponsored guestz Cisco ISEzGoogle Apps domainz"splashPage" cannot be "ZradiusFailoverPolicyz Deny accessz Allow accessz""radiusFailoverPolicy" cannot be "ZradiusLoadBalancingPolicyzStrict priority orderz Round robinz'"radiusLoadBalancingPolicy" cannot be "ZradiusAttributeForGroupPoliciesz Filter-Idz Reply-MessagezAirespace-ACL-NamezAruba-User-Rolez-"radiusAttributeForGroupPolicies" cannot be "r r ssidsupdateNetworkWirelessSsid)r rz /networks/z/wireless/ssids/r,r'Zdot11wZdot11rZsplashGuestSponsorDomainsZoauthZ localRadiusZldapZactiveDirectoryZ radiusServersZradiusProxyEnabledZradiusTestingEnabledZradiusCalledStationIdZradiusAuthenticationNasIdZradiusServerTimeoutZradiusServerAttemptsLimitZradiusFallbackEnabledZradiusCoaEnabledZradiusAccountingEnabledZradiusAccountingServersZradiusAccountingInterimIntervalZipAssignmentModeZuseVlanTaggingZconcentratorNetworkIdr(Z defaultVlanIdZapTagsAndVlanIdsZwalledGardenEnabledZwalledGardenRangesZradiusOverrideZradiusGuestVlanEnabledZradiusGuestVlanIdZ minBitrateZ bandSelectionZperClientBandwidthLimitUpZperClientBandwidthLimitDownZperSsidBandwidthLimitUpZperSsidBandwidthLimitDownZlanIsolationEnabledZvisibleZavailableOnAllApsZavailabilityTagsZmandatoryDhcpEnabledZadultContentFilteringEnabledZ dnsRewritecs&i|]\}}|kr||qSr)r)rrr)rrrrszAActionBatchWireless.updateNetworkWirelessSsid..r)rrr)rrr7r) rr%r=rr8rrrr r)rrrA&sD? $$$$  & & &  &pz-ActionBatchWireless.updateNetworkWirelessSsidc s^|tddddgdd}d|d|d }d d gfd d |D}|d|d}|S)a **Update the bonjour forwarding setting and rules for the SSID** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-bonjour-forwarding - networkId (string): (required) - number (string): (required) - enabled (boolean): If true, Bonjour forwarding is enabled on this SSID. - rules (array): List of bonjour forwarding rules. r r r@ZbonjourForwarding*updateNetworkWirelessSsidBonjourForwarding)r rz /networks/z/wireless/ssids/z/bonjourForwardingr'rulescs&i|]\}}|kr||qSr)r)rrr)rrrrszRActionBatchWireless.updateNetworkWirelessSsidBonjourForwarding..r)rrr)rrr)rr%r=rrrrr r)rrrBs  z>ActionBatchWireless.updateNetworkWirelessSsidBonjourForwardingc s^|tddddgdd}d|d|d }d d gfd d |D}|d|d}|S)a **Update the device type group policies for the SSID** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-device-type-group-policies - networkId (string): (required) - number (string): (required) - enabled (boolean): If true, the SSID device type group policies are enabled. - deviceTypePolicies (array): List of device type policies. r r r@ZdeviceTypeGroupPolicies0updateNetworkWirelessSsidDeviceTypeGroupPolicies)r rz /networks/z/wireless/ssids/z/deviceTypeGroupPoliciesr'ZdeviceTypePoliciescs&i|]\}}|kr||qSr)r)rrr)rrrrszXActionBatchWireless.updateNetworkWirelessSsidDeviceTypeGroupPolicies..r)rrr)rrr)rr%r=rrrrr r)rrrDs  zDActionBatchWireless.updateNetworkWirelessSsidDeviceTypeGroupPoliciesc s^|tdddddgdd}d|d |d }d gfd d |D}|d|d}|S)a **Update the L7 firewall rules of an SSID on an MR network** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-firewall-l-7-firewall-rules - networkId (string): (required) - number (string): (required) - rules (array): An array of L7 firewall rules for this SSID. Rules will get applied in the same order user has specified in request. Empty array will clear the L7 firewall rule configuration. r r r@ZfirewallZl7FirewallRules0updateNetworkWirelessSsidFirewallL7FirewallRules)r rz /networks/z/wireless/ssids/z/firewall/l7FirewallRulesrCcs&i|]\}}|kr||qSr)r)rrr)rrrrszXActionBatchWireless.updateNetworkWirelessSsidFirewallL7FirewallRules..r)rrr)rrr)rr%r=rrrrr r)rrrEs  zDActionBatchWireless.updateNetworkWirelessSsidFirewallL7FirewallRules)r%r=r, groupPolicyIdc  s`|tddddgdd}d|d|d }d d d gfd d|D}|d|d} | S)a **Create an Identity PSK** https://developer.cisco.com/meraki/api-v1/#!create-network-wireless-ssid-identity-psk - networkId (string): (required) - number (string): (required) - name (string): The name of the Identity PSK - groupPolicyId (string): The group policy to be applied to clients - passphrase (string): The passphrase for client authentication. If left blank, one will be auto-generated. r r r@ identityPsks$createNetworkWirelessSsidIdentityPsk)r rz /networks/z/wireless/ssids/z /identityPsksr, passphraserFcs&i|]\}}|kr||qSr)r)rrr)rrrr szLActionBatchWireless.createNetworkWirelessSsidIdentityPsk..r6)rrr)rrr) rr%r=r,rFrrrrr r)rrrHs   z8ActionBatchWireless.createNetworkWirelessSsidIdentityPsk)r%r= identityPskIdc  sd|tddddgdd}d|d|d |}d d d gfd d|D}|d|d}|S)a **Update an Identity PSK** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-identity-psk - networkId (string): (required) - number (string): (required) - identityPskId (string): (required) - name (string): The name of the Identity PSK - passphrase (string): The passphrase for client authentication - groupPolicyId (string): The group policy to be applied to clients r r r@rG$updateNetworkWirelessSsidIdentityPsk)r rz /networks/z/wireless/ssids/z/identityPsks/r,rIrFcs&i|]\}}|kr||qSr)r)rrr)rrrr.szLActionBatchWireless.updateNetworkWirelessSsidIdentityPsk..r)rrr)rrr) rr%r=rJrrrrr r)rrrKs   z8ActionBatchWireless.updateNetworkWirelessSsidIdentityPskcCs8ddddgdd}d|d|d |}|d td }|S) a **Delete an Identity PSK** https://developer.cisco.com/meraki/api-v1/#!delete-network-wireless-ssid-identity-psk - networkId (string): (required) - number (string): (required) - identityPskId (string): (required) r r r@rG$deleteNetworkWirelessSsidIdentityPsk)r rz /networks/z/wireless/ssids/z/identityPsks/r;)rrr)r)rr%r=rJrrr rrrrL;s z8ActionBatchWireless.deleteNetworkWirelessSsidIdentityPskc s`|tddddgdd}d|d|d }d d d gfd d|D}|d|d}|S)a **Update the outage schedule for the SSID** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-schedules - networkId (string): (required) - number (string): (required) - enabled (boolean): If true, the SSID outage schedule is enabled. - ranges (array): List of outage ranges. Has a start date and time, and end date and time. If this parameter is passed in along with rangesInSeconds parameter, this will take precedence. - rangesInSeconds (array): List of outage ranges in seconds since Sunday at Midnight. Has a start and end. If this parameter is passed in along with the ranges parameter, ranges will take precedence. r r r@Z schedules"updateNetworkWirelessSsidSchedules)r rz /networks/z/wireless/ssids/z /schedulesr'rangesZrangesInSecondscs&i|]\}}|kr||qSr)r)rrr)rrrrlszJActionBatchWireless.updateNetworkWirelessSsidSchedules..r)rrr)rrr)rr%r=rrrrr r)rrrMWs   z6ActionBatchWireless.updateNetworkWirelessSsidSchedulesc  s|td|krBdddg}|d|ksBtd|dd|ddd d d gd d }d|d|d}ddddddddddddddgfdd|D}|d |d!}|S)"a **Modify the splash page settings for the given SSID** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-splash-settings - networkId (string): (required) - number (string): (required) - splashUrl (string): [optional] The custom splash URL of the click-through splash page. Note that the URL can be configured without necessarily being used. In order to enable the custom URL, see 'useSplashUrl' - useSplashUrl (boolean): [optional] Boolean indicating whether the users will be redirected to the custom splash url. A custom splash URL must be set if this is true. Note that depending on your SSID's access control settings, it may not be possible to use the custom splash URL. - splashTimeout (integer): Splash timeout in minutes. This will determine how often users will see the splash page. - redirectUrl (string): The custom redirect URL where the users will go after the splash page. - useRedirectUrl (boolean): The Boolean indicating whether the the user will be redirected to the custom redirect URL after the splash page. A custom redirect URL must be set if this is true. - welcomeMessage (string): The welcome message for the users on the splash page. - splashLogo (object): The logo used in the splash page. - splashImage (object): The image used in the splash page. - splashPrepaidFront (object): The prepaid front image used in the splash page. - blockAllTrafficBeforeSignOn (boolean): How restricted allowing traffic should be. If true, all traffic types are blocked until the splash page is acknowledged. If false, all non-HTTP traffic is allowed before the splash page is acknowledged. - controllerDisconnectionBehavior (string): How login attempts should be handled when the controller is unreachable. Can be either 'open', 'restricted', or 'default'. - allowSimultaneousLogins (boolean): Whether or not to allow simultaneous logins from different devices. - guestSponsorship (object): Details associated with guest sponsored splash. - billing (object): Details associated with billing splash. ZcontrollerDisconnectionBehaviorr>Z restricteddefaultz-"controllerDisconnectionBehavior" cannot be "z", & must be set to one of: r r r@Zsplashr 'updateNetworkWirelessSsidSplashSettings)r rz /networks/z/wireless/ssids/z/splash/settingsZ splashUrlZ useSplashUrlZ splashTimeoutZ redirectUrlZuseRedirectUrlZwelcomeMessageZ splashLogoZ splashImageZsplashPrepaidFrontZblockAllTrafficBeforeSignOnZallowSimultaneousLoginsZguestSponsorshipr)cs&i|]\}}|kr||qSr)r)rrr)rrrrszOActionBatchWireless.updateNetworkWirelessSsidSplashSettings..r)rrr)rrr7r) rr%r=rr8rrrr r)rrrPys  $  z;ActionBatchWireless.updateNetworkWirelessSsidSplashSettingsc sb|tdddddgdd}d|d |d }d d dgfd d|D}|d|d}|S)a^ **Update the traffic shaping settings for an SSID on an MR network** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-traffic-shaping-rules - networkId (string): (required) - number (string): (required) - trafficShapingEnabled (boolean): Whether traffic shaping rules are applied to clients on your SSID. - defaultRulesEnabled (boolean): Whether default traffic shaping rules are enabled (true) or disabled (false). There are 4 default rules, which can be seen on your network's traffic shaping page. Note that default rules count against the rule limit of 8. - rules (array): An array of traffic shaping rules. Rules are applied in the order that they are specified in. An empty list (or null) means no rules. Note that you are allowed a maximum of 8 rules. r r r@ZtrafficShapingrC,updateNetworkWirelessSsidTrafficShapingRules)r rz /networks/z/wireless/ssids/z/trafficShaping/rulesZtrafficShapingEnabledZdefaultRulesEnabledcs&i|]\}}|kr||qSr)r)rrr)rrrrszTActionBatchWireless.updateNetworkWirelessSsidTrafficShapingRules..r)rrr)rrr)rr%r=rrrrr r)rrrQs   z@ActionBatchWireless.updateNetworkWirelessSsidTrafficShapingRulesc s\|tddddgdd}d|d|d }d gfd d |D}|d |d}|S)a, **Update the VPN settings for the SSID** https://developer.cisco.com/meraki/api-v1/#!update-network-wireless-ssid-vpn - networkId (string): (required) - number (string): (required) - splitTunnel (object): The VPN split tunnel settings for this SSID. r r r@ZvpnupdateNetworkWirelessSsidVpn)r rz /networks/z/wireless/ssids/z/vpnZ splitTunnelcs&i|]\}}|kr||qSr)r)rrr)rrrrszDActionBatchWireless.updateNetworkWirelessSsidVpn..r)rrr)rrr)rr%r=rrrrr r)rrrRs  z0ActionBatchWireless.updateNetworkWirelessSsidVpn)__name__ __module__ __qualname__rstrr r!r&r*r3r9r:r<rArBrDrErHrKrLrMrPrQrR __classcell__rr)rrrs( !!" ,-'n!! "#"1%rN)objectrrrrr