Merge remote-tracking branch 'origin/third-party-review'
tree: 07c42f6a9b8935540426fc097de2052b71705c70
  1. .github/
  2. build-logic/
  3. config/
  4. gradle/
  5. jxmpp-core/
  6. jxmpp-jid/
  7. jxmpp-repl/
  8. jxmpp-stringprep-icu4j/
  9. jxmpp-stringprep-libidn/
  10. jxmpp-stringprep-rocksxmppprecis/
  11. jxmpp-strings-testframework/
  12. jxmpp-util-cache/
  13. misc/
  14. .gitignore
  15. .travis.yml
  16. Android.bp
  17. build.gradle
  18. gradlew
  19. gradlew.bat
  20. LICENSE
  21. Makefile
  22. METADATA
  23. MODULE_LICENSE_APACHE2
  24. OWNERS
  25. README.md
  26. repl
  27. settings.gradle
  28. test-xmpp-strings
  29. version
README.md

JXMPP

Project Stats

About

JXMPP is an Open Source Java base library for XMPP. It provides often used functionality needed to build an XMPP stack.

Resources

JXMPP Components

JXMPP consists of several components, you can use all of them or decide to pick only the ones that suit your needs.

jxmpp-core

Provides core functionality most software that interacts with XMPP requires. Highlights include

XmppDateTime

A utility to parse date/time Strings in the various formats used within XMPP to a Date instance in a efficient manner without depending on third party libraries

XmppStringUtils

Contains various String operations often needed when using XMPP

XmppStringPrepUtil

A utility to apply the various string transformation profiles required by XMPP in a efficient manner. Does also utilize a Cache for maximum efficiency.

jxmpp-jid

This part of the API abstracts XMPP JIDs with Java classes, performing string preparation and validation. Although JIDs are split over five classes, jxmpp-jid is designed so that you often only need to use the simple Jid type. It therefore combines the simplicity of the single JID class approach, where JIDs are represented by a single class no matter what kind of JID they are, which the expressiveness of the JID class hierarchy approach, where you can express in a method signature the required JID type (e.g. foo(BareJid bareJid)).

Jid instances are created with the help of the JidCreate utility:

Jid jid = JidCreate.from("[email protected]");
         ,______Jid______,
        /       / \       \
EntityFullJid  /   \     DomainFullJid
              /     \
     EntityBareJid  DomainBareJid

There are also the BareJid, FullJid, EntityJid and DomainJid interfaces, which are implemented by the Jid types as follows:

         BareJid                            FullJid
         /    \                             /   \
        /      \                           /     \
EntityBareJid  DomainBareJid     EntityFullJid  DomainFullJid

        EntityJid                         DomainJid
         /    \                             /   \
        /      \                           /     \
EntityBareJid  EntityFullJid     DomainBareJid  DomainFullJid
Example JIDJXMPP JID Type
example.orgDomainBareJid
example.org/resourceDomainFullJid
[email protected]EntityBareJid
[email protected]/resourceEntityFullJid

jxmpp-stringprep-libidn

Perform XMPP's StringPrep with the help of libidn.

Use LibIdnXmppStringprep.setup() to make XmppStringPrepUtil use libidn.

jxmpp-util-cache

Provides a lightweight and efficient Cache without external dependencies used by various JXMPP Components.

jxmpp-strings-testframework

A framework to test “XMPP Strings”.

Simply run

$ ./test-xmpp-strings

to run the testframework.