Interface ChargingRuleRemove
-
- All Superinterfaces:
Cloneable,DiameterAvp,GroupedAvp
public interface ChargingRuleRemove extends GroupedAvp
Defines an interface representing the Charging-Rule-Remove grouped AVP type. From the Diameter Gx Reference Point Protocol Details (3GPP TS 29.212 V10.1.0) specification:5.3.3 Charging-Rule-Remove The Charging-Rule-Remove AVP (AVP code 1002) is of type Grouped, and it is used to deactivate or remove PCC rules from an IP CAN session. Charging-Rule-Name AVP is a reference for a specific PCC rule at the PCEF to be removed or for a specific PCC rule predefined at the PCEF to be deactivated. The Charging-Rule-Base-Name AVP is a reference for a group of PCC rules predefined at the PCEF to be deactivated. It has the following ABNF grammar: Charging-Rule-Remove ::= < AVP Header: 1002 > *[ Charging-Rule-Name ] *[ Charging-Rule-Base-Name ] *[ AVP ]
-
-
Field Summary
-
Fields inherited from interface org.jainslee.resources.diameter.base.DiameterAvp
FLAG_RULE_MAY, FLAG_RULE_MUST, FLAG_RULE_MUSTNOT
-
-
Method Summary
All Methods Instance Methods Abstract Methods Modifier and Type Method Description String[]getChargingRuleBaseNames()Returns the set of Charging-Rule-Base-Name AVPs.byte[][]getChargingRuleNames()Returns the set of Charging-Rule-Name AVPs.DiameterAvp[]getExtensionAvps()Returns the set of extension AVPs.voidremoveChargingRuleBaseNames()Removes all Charging-Rule-Base-Name AVPs from the Charging-Rule-Remove AVP.voidremoveChargingRuleNames()Removes all Charging-Rule-Name AVPs from the Charging-Rule-Remove AVP.voidremoveExtensionAvps()Removes all extension AVPs from the Charging-Rule-Remove AVP.voidsetChargingRuleBaseName(String chargingRuleBaseName)Sets a single Charging-Rule-Base-Name AVP in the Charging-Rule-Remove AVP, of type UTF8String.voidsetChargingRuleBaseNames(String[] chargingRuleBaseNames)Sets the set of Charging-Rule-Base-Name AVPs, with all the values in the given array.voidsetChargingRuleName(byte[] chargingRuleName)Sets a single Charging-Rule-Name AVP in the Charging-Rule-Remove AVP, of type OctetString.voidsetChargingRuleNames(byte[][] chargingRuleNames)Sets the set of Charging-Rule-Name AVPs, with all the values in the given array.voidsetExtensionAvps(DiameterAvp[] avps)Sets the set of extension AVPs with all the values in the given array.-
Methods inherited from interface org.jainslee.resources.diameter.base.DiameterAvp
byteArrayValue, clone, doubleValue, floatValue, getCode, getMandatoryRule, getName, getProtectedRule, getType, getVendorID, groupedAvpValue, intValue, longValue, stringValue
-
-
-
-
Method Detail
-
getChargingRuleNames
byte[][] getChargingRuleNames()
Returns the set of Charging-Rule-Name AVPs. The returned array contains the AVPs in the order they appear in the Charging-Rule-Remove AVP. A return value of null implies that no Charging-Rule-Name AVPs have been set. The elements in the given array are byte[] objects.
-
setChargingRuleName
void setChargingRuleName(byte[] chargingRuleName)
Sets a single Charging-Rule-Name AVP in the Charging-Rule-Remove AVP, of type OctetString.- Throws:
NullPointerException- ifchargingRuleNameisnull.
-
setChargingRuleNames
void setChargingRuleNames(byte[][] chargingRuleNames)
Sets the set of Charging-Rule-Name AVPs, with all the values in the given array. The AVPs will be added to the Charging-Rule-Remove AVP in the order in which they appear in the array. Note: the array must not be altered by the caller following this call, and getChargingRuleNames() is not guaranteed to return the same array instance, e.g. an "==" check would fail.- Throws:
NullPointerException- ifchargingRuleNamesisnull.
-
removeChargingRuleNames
void removeChargingRuleNames()
Removes all Charging-Rule-Name AVPs from the Charging-Rule-Remove AVP. If no Charging-Rule-Name AVPs are present, this method returns silently.
-
getChargingRuleBaseNames
String[] getChargingRuleBaseNames()
Returns the set of Charging-Rule-Base-Name AVPs. The returned array contains the AVPs in the order they appear in the Charging-Rule-Remove AVP. A return value of null implies that no Charging-Rule-Base-Name AVPs have been set. The elements in the given array are String objects.
-
setChargingRuleBaseName
void setChargingRuleBaseName(String chargingRuleBaseName)
Sets a single Charging-Rule-Base-Name AVP in the Charging-Rule-Remove AVP, of type UTF8String.- Throws:
NullPointerException- ifchargingRuleBaseNameisnull.
-
setChargingRuleBaseNames
void setChargingRuleBaseNames(String[] chargingRuleBaseNames)
Sets the set of Charging-Rule-Base-Name AVPs, with all the values in the given array. The AVPs will be added to the Charging-Rule-Remove AVP in the order in which they appear in the array. Note: the array must not be altered by the caller following this call, and getChargingRuleBaseNames() is not guaranteed to return the same array instance, e.g. an "==" check would fail.- Throws:
NullPointerException- ifchargingRuleBaseNamesisnull.
-
removeChargingRuleBaseNames
void removeChargingRuleBaseNames()
Removes all Charging-Rule-Base-Name AVPs from the Charging-Rule-Remove AVP. If no Charging-Rule-Base-Name AVPs are present, this method returns silently.
-
getExtensionAvps
DiameterAvp[] getExtensionAvps()
Returns the set of extension AVPs. The returned array contains the extension AVPs in the order they appear in the Charging-Rule-Remove AVP. A return value of null implies that no extensions AVPs have been set.
-
setExtensionAvps
void setExtensionAvps(DiameterAvp[] avps) throws AvpNotAllowedException
Sets the set of extension AVPs with all the values in the given array. The AVPs will be added to Charging-Rule-Remove AVP in the order in which they appear in the array. Note: the array must not be altered by the caller following this call, and getExtensionAvps() is not guaranteed to return the same array instance, e.g. an "==" check would fail.- Throws:
AvpNotAllowedException- if an AVP is encountered of a type already known to this class (i.e. an AVP for which get/set methods already appear in this class)NullPointerException- ifavpsisnull.
-
removeExtensionAvps
void removeExtensionAvps()
Removes all extension AVPs from the Charging-Rule-Remove AVP. If no extension AVPs are present, this method returns silently.
-
-