Openfire ${project.version}
Openfire provides comprehensive group chat and instant messaging (IM) services using the XMPP protocol.
Administrator Documentation
Basic Server Administration
Guides that are applicable to most administrators of an Openfire instance. These cover the basics.
- Installation Guide
- How to install Openfire.
- Database Installation Guide
- How to setup your database for use with Openfire.
- Upgrade Guide
- Instructions for upgrading an existing Openfire installation.
- Recovery of an Admin Password
- Instructions to recover an administrative account for which the password has been lost.
Advanced Server Administration
The following guides cover more specialized topics. These aren't necessarily applicable to every Openfire installation.
- Network Configuration Guide
- Describes how to make Openfire accessible to its users.
- TLS Guide
- A guide to setting up Openfire's TLS secure socket support.
- Separating Administrative Users Guide
- A guide to setting up Openfire to work with different user stores for admins and non-administrative users.
- Load Balancing Guide
- How to spread client and server connections over multiple instances of Openfire
- Clustered Database Guide
- Instructions on using Openfire with a database that consists of more than one server.
- Trunking (Gateway) Guide
- A guide to set up Openfire to mediate traffic that is exchanged between other XMPP domains
Integration with External Data Sources
Openfire is written to facilitate integration with existing data sources, such as external user directories or custom database. The guides in this section describe how such integration can be achieved.
- Active Directory and LDAP Integration Guide
- A guide to setting up Openfire to work with Active Directory or LDAP user stores.
- Custom Database Integration Guide
- A guide to integrating Openfire authentication, user, and group data with a custom database.
- Integrating with more than one External Data Source
- Describes how Openfire can be configured to not only one, but multiple External Data Source.
In-depth Analysis
At times, problems occur for which the cause is not immediately apparent. The follow section contains various guides that can help diagnose issues.
- Database Query Statistics Guide
- Describes how Openfire's database interaction can be analyzed to find inefficient database queries.
Developer Documentation
Generic Development Guides
Guides for developers that work with the Openfire source code.
- Building the Source
- Instructions for downloading and compiling the Openfire source code.
- Starting an auto-provisioned instance of Openfire (demoboot)
- Starting a running Openfire instance without running through the setup.
- Openfire Source Code in Visual Studio Code
- A short tutorial on how to work with the Openfire source code in the Visual Studio Code IDE.
- Plugin Developer Guide
- A guide to writing and installing plugins for Openfire.
- Translator Guide
- Information for those interested in translating the admin console of Openfire into other languages.
- Customization Guide
- Instructions on customization support within the build process for Openfire.
- Internal Networking Guide
- Guide to help developers understand Openfire's internal networking.
- Tips & tricks for working with Openfire
- Some collected tools, tips and useful links.
Data Provider / IAM Implementation Guides
Guides for implementors of custom integration of external authentication, users and other entities.
- Custom Authentication Provider Guide
- Describes how to integrate Openfire with an external authentication system.
- Custom Group Provider Guide
- Describes how to integrate Openfire with an external system that provides Group definitions.
- Custom User Provider Guide
- Describes how to integrate Openfire with an external system that provides User definitions
- Pluggable Roster Support Guide
- A guide to integrating Openfire rosters with an alternate store.
Guides for Client Developers
Openfire is an XMPP server. It can therefor be used by any application that implements this protocol. This section lists a number of minimal examples using various libraries (mostly third-party) that illustrate how they can be used to interact with Openfire. Note that there are many other libraries available than the ones listed here!
- Smack: A Minimal Working Example (in Java)
- Shows how to use a client implemented with the Smack library (Java) to connect to Openfire.
- Mellium: A Minimal Working Example (in Go)
- Shows how to use a client implemented with the Mellium library (Go) to connect to Openfire.
- moxxmpp: A Minimal Working Example (in Dart)
- Shows how to use a client implemented with the moxxmpp library (Dart) to connect to Openfire.
- StanzaJS: A Minimal Working Example (in Javascript/Typescript)
- Shows how to use a client implemented with the StanzaJS library (Javascript/Typescript) to connect to Openfire.
- Strophe.js: A Minimal Working Example (in Javascript)
- Shows how to use a client implemented with the Strophe.js library (Javascript) to connect to Openfire.
- Twisted Words: A Minimal Working Example (in Python)
- Shows how to use a client implemented with the Twisted Words library (Python) to connect to Openfire.
- XmppDotNet: A Minimal Working Example (in C# / .NET)
- Shows how to use a client implemented with the XmppDotNet library (.NET) to connect to Openfire.
- Whixp: A Minimal Working Example (in Dart)
- Shows how to use a client implemented with the Whixp library (Dart) to connect to Openfire.
Reference Documentation
- JavaDocs
- Openfire API documentation.
- Protocol Support
- Provides details on the XMPP support and XEPs that Openfire implements.
- Database Schema Guide
- A tour of the Openfire database schema for developers and database administrators.