Interface AdditionalContentInformation

  • All Superinterfaces:
    Cloneable, DiameterAvp, GroupedAvp

    public interface AdditionalContentInformation
    extends GroupedAvp
    Defines an interface representing the Additional-Content-Information grouped AVP type. From the Diameter Ro Reference Point Protocol Details (3GPP TS 32.299 V9.6.0) specification:
     7.2.5       Additional-Content-Information AVP
     The Additional-Content-Information AVP (AVP code 1207) is of type Grouped
     and identifies any subsequent content types. It is used to identify each
     content (including re-occurences) within an MM when the Type-Number AVP or
     Additional-Type-Information AVP from the Content-Type AVP indicate a multi-
     part content.
     It has the following ABNF grammar:
     
         Additional-Content-Information::=      < AVP Header: 1207 >
                                                [ Type-Number ]
                                                [ Additional-Type-Information ]
                                                [ Content-Size ]
     
    Note:
    The support for extension AVPs is present even thou the ABNF grammar for this AVP does not contain the "* [ AVP ]" line. Be aware that adding any extension AVPs may result in interoperability problems with products that strongly validate the incoming diameter message for it's adherence to the specification.
    • Method Detail

      • hasTypeNumber

        boolean hasTypeNumber()
        Returns true if the Type-Number AVP is present in the Additional-Content-Information AVP.
      • getTypeNumber

        TypeNumber getTypeNumber()
        Returns the value of the Type-Number AVP, of type Enumerated.
        Returns:
        the value of the Type-Number AVP, or null if it has not been set.
      • setTypeNumber

        void setTypeNumber​(TypeNumber typeNumber)
        Sets the value of the Type-Number AVP, of type Enumerated.
        Throws:
        NullPointerException - if typeNumber is null.
      • removeTypeNumber

        void removeTypeNumber()
        Removes the Type-Number AVP from the Additional-Content-Information AVP. If the Type-Number AVP is not present, this method returns silently.
      • hasAdditionalTypeInformation

        boolean hasAdditionalTypeInformation()
        Returns true if the Additional-Type-Information AVP is present in the Additional-Content-Information AVP.
      • getAdditionalTypeInformation

        String getAdditionalTypeInformation()
        Returns the value of the Additional-Type-Information AVP, of type UTF8String.
        Returns:
        the value of the Additional-Type-Information AVP, or null if it has not been set.
      • setAdditionalTypeInformation

        void setAdditionalTypeInformation​(String additionalTypeInformation)
        Sets the value of the Additional-Type-Information AVP, of type UTF8String.
        Throws:
        NullPointerException - if additionalTypeInformation is null.
      • removeAdditionalTypeInformation

        void removeAdditionalTypeInformation()
        Removes the Additional-Type-Information AVP from the Additional-Content-Information AVP. If the Additional-Type-Information AVP is not present, this method returns silently.
      • hasContentSize

        boolean hasContentSize()
        Returns true if the Content-Size AVP is present in the Additional-Content-Information AVP.
      • getContentSize

        long getContentSize()
        Returns the value of the Content-Size AVP, of type Unsigned32. Use hasContentSize() to check the existence of this AVP.
        Returns:
        the value of the Content-Size AVP
        Throws:
        IllegalStateException - if the Content-Size AVP has not been set.
      • setContentSize

        void setContentSize​(long contentSize)
        Sets the value of the Content-Size AVP, of type Unsigned32.
      • removeContentSize

        void removeContentSize()
        Removes the Content-Size AVP from the Additional-Content-Information AVP. If the Content-Size AVP is not 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 Additional-Content-Information 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 Additional-Content-Information 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 - if avps is null.
      • removeExtensionAvps

        void removeExtensionAvps()
        Removes all extension AVPs from the Additional-Content-Information AVP. If no extension AVPs are present, this method returns silently.