ChatSecure
ChatSecure is a free and open source instant messaging client for iOS and Android that integrates encrypted OTR ("Off the Record") messaging support from the libotr library and the XMPPFramework to handle Jabber/GTalk (XMPP).
Cost
This project is 100% free because it is important that all people around the world have unrestricted access to privacy tools. However, developing and supporting this project is hard work and costs real money. Please help support the development of this project! We now also accept Bitcoin via Coinbase! :)
Localization
If you would like to contribute/improve a translation:
- Visit our Transifex project page and make an account if you don't have one already.
- Go to the resources subsites AppStore.strings & Localizable.strings to add a new language or improve an existing translation.
- Open an issue on Github notifying us of your translation.
Compatibility
Bold indicates it has been tested and works properly.
Native
- Adium (Mac OS X) - OTR works over both XMPP and Oscar.
- Jitsi (Cross-platform)
Plug-in
- Pidgin (cross-platform), with pidgin-otr plugin.
Phone apps
- ChatSecure Android (formerly known as Gibberbot), a free and open source Android application produced by The Guardian Project, provides OTR protocol compatible over XMPP chat.
- BEEM - Android XMPP client (compatibility unknown)
Build Instructions
Install mogenerator in order to regenerate the Core Data model files. You'll also need Cocoapods for some of our dependencies.
$ brew install mogenerator
$ gem install cocoapods
Download the source code and don't forget to pull down all of the submodules as well.
$ git clone git@github.com:chrisballinger/Off-the-Record-iOS.git
$ cd Off-the-Record-iOS/
$ git submodule update --init --recursive
$ pod
Make your own version of environment-specific data. Make OTRSecrets.m
file with blank API keys, and set your provisioning profile ID in OTR_Codesigning.xcconfig
. To find the provisioning profile ID, go to Project Settings -> Build Settings -> Code Signing -> Select Provisiong Profile -> Select Other -> Copy Profile's UUID into OTR_Codesigning.xcconfig
.
$ cp "Off the Record/OTRSecrets-Template.m" "Off the Record/OTRSecrets.m"
$ cp "Off the Record/configurations/OTR_Codesigning.xcconfig.sample" "Off the Record/configurations/OTR_Codesigning.xcconfig"
Open Off the Record.xcworkspace
in Xcode and build. Note that you don't open the .xcodeproj anymore because we use Cocoapods now.
License
Software License Agreement (GPLv3+)
Copyright (c) 2012, Chris Ballinger. All rights reserved.
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
If you would like to relicense this code to distribute it on the App Store, please contact me at chris@chatsecure.org.
Contributing
Thank you for your interest in contributing to ChatSecure! To avoid potential legal headaches and to allow distribution on Apple's App Store please sign our CLA (Contributors License Agreement). For contributing translations, please check out our Transifex page.
- Sign the CLA (odt, pdf) and email it to chris@chatsecure.org.
- Fork the project and (preferably) work in a feature branch.
- Open a pull request on GitHub.
- Thank you!
Third-party Libraries
This software additionally references or incorporates the following sources of intellectual property, the license terms for which are set forth in the sources themselves:
The following dependencies are bundled with the ChatSecure, but are under terms of a separate license:
- libotr - provides the core message encryption capabilities
- libgcrypt - handles core libotr encryption routines
- libgpg-error - error codes used by libotr
- LibOrange - handles all of the OSCAR (AIM) functionality
- XMPPFramework - XMPP support
- MBProgressHUD - a nice looking progress HUD
- MWFeedParser - Methods for escaping HTML strings
- Crittercism - crash reports, only submitted via opt-in
- SSKeychain - Utilities to store passwords securely in the iOS keychain
- Appirater - nags people to give reviews
- MagicalRecord - Core Data convenience methods
- encrypted-core-data - Core Data + SQLCipher
- UserVoice - in-app support forum
- mogenerator - creates class files for core data model
- DAKeyboardControl - support for swiping down keyboard in chat view
Acknowledgements
Thank you to everyone who helped this project become a reality! This project is also supported by the fine folks from The Guardian Project and OpenITP.
- Nick Hum - awesome icon.
- Glyphish - icons used on the tab bar.
- Adium - lock/unlock icon used in chat window, status gems.
- Sergio Sánchez López - AIM protocol icon.
- Mateo Zlatar - World Icon
- Goxxy - Google Talk icon.
- AcaniChat - help on setting up chat view input box
- Localizations
- Jiajuan Lin (Chinese)
- Jan-Christoph Borchardt (German)
- vitalyster (Russian)
- burhan teoman (Turkish)
- shikibiomernok (Hungarian)
- Many many more!