• Stars
    star
    3,130
  • Rank 14,360 (Top 0.3 %)
  • Language
    Objective-C
  • License
    Other
  • Created over 13 years ago
  • Updated 4 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

ChatSecure is a free and open source encrypted chat client for iOS that supports OTR and OMEMO encryption over XMPP.

ChatSecure

Build Status

ChatSecure is a free and open source XMPP messaging client for iOS that integrates OTR and OMEMO encrypted messaging support, and has optional integrated support for connectivity via the Tor network.

download chatsecure on the app store

Cost

Redistributing ChatSecure Code on the App Store

Even though this project is open source, this does not mean you can reuse this code when distributing closed source commercial products. Please contact us to discuss licensing options before you start building your product.

If you are an open source project, please contact us to arrange for an App Store redistribution exception. For more information about why this is required, please read this blog post from Open Whisper Systems.

Cost for End Users

Downloading the ChatSecure app 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!

Localization

If you would like to contribute/improve a translation:

  1. Visit our Transifex project page and make an account if you don't have one already.
  2. Go to the resources subsites AppStore.strings & Localizable.strings to add a new language or improve an existing translation.
  3. Open an issue on Github notifying us of your translation.

Compatibility

There's a more full list of OTR clients on Wikipedia. A smaller list of clients support the mobile-friendly OMEMO Encryption.

Desktop

  • dino (Linux, macOS, Windows) Supports OMEMO

Mobile

Build Instructions

You'll need CocoaPods installed for most of our dependencies.

$ gem install cocoapods

Download the source code and don't forget to pull down all of the submodules as well.

$ git clone https://github.com/ChatSecure/ChatSecure-iOS.git
$ cd ChatSecure-iOS/
$ git submodule update --init --recursive

Now you'll need to build the dependencies.

$ bash ./Submodules/CPAProxy/scripts/build-all.sh
$ bash ./Submodules/OTRKit/scripts/build-all.sh
$ pod repo update
$ pod install

Next you'll need to create your own version of environment-specific data. Make a copy of Secrets-template.plist as Secrets.plist:

$ cp OTRResources/Secrets-template.plist OTRResources/Secrets.plist

You'll need to manually change the Team ID under Project -> Targets -> ChatSecure -> Signing. The old .xcconfig method doesn't seem to work well anymore.

Open ChatSecure.xcworkspace in Xcode and build.

Note: Don't open the .xcodeproj because we use Cocoapods now!

If you're still having trouble compiling check out the Travis-CI build status and .travis.yml file.

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).

  1. Sign the CLA (odt, pdf) and email it to [email protected].
  2. Fork the project and (preferably) work in a feature branch.
  3. Open a pull request on GitHub.
  4. Thank you!

License

Software License Agreement (GPLv3+)

Copyright (c) 2015, 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 [email protected].

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:

For a more complete list, check the Podfile and Cartfile.

Regenerating Acknowledgements

To regenerate the acknowledgements in Settings.app use LicensePlist and copy the output to Settings.bundle.

$ brew install mono0926/license-plist/license-plist
$ license-plist --add-version-numbers --output-path ChatSecure/Settings.bundle --suppress-opening-directory

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, OpenITP, and the Open Technology Fund.

More Repositories

1

OTRKit

An Objective-C Off-the-Record library for iOS.
Objective-C
135
star
2

ChatSecure-Push-Server

An experimental design for a privacy-minded push server.
Python
112
star
3

OnionKit

Objective-C Tor Wrapper Framework for iOS
Shell
41
star
4

xmpp-server-list

Public XMPP server list and metadata in JSON format
28
star
5

ChatSecure-Push-Android

The Android SDK for ChatSecure-Push-Server
Java
17
star
6

ChatSecure-Push-iOS

The iOS SDK for ChatSecure-Push-Server
Swift
16
star
7

RubDub

A Node XMPP Push Service for XEP-0357: Push Notifications
JavaScript
15
star
8

IOCipher-ObjC

IOCipher for iOS and OS X
Objective-C
15
star
9

SignalProtocol-ObjC

Unofficial Objective-C wrapper for libsignal-protocol-c
Objective-C
12
star
10

SignalProtocolC

Unofficial podspec and framework for libsignal-protocol-c
Ruby
12
star
11

apns-client

Python client for Apple Push Notification service (APNs).
Python
7
star
12

chatsecure-web

Deprecated in favor of Jekyll https://github.com/chatsecure/chatsecure.github.io
Python
6
star
13

tor

Fork of https://git.torproject.org/tor.git for use in OnionKit
C
5
star
14

chef-chatsecure

Chef Repo for chatsecure.org
Ruby
4
star
15

Zom-iOS

Zom - whitelabel fork of ChatSecure for the Tibetan community
Objective-C
4
star
16

OpenSSL

Mirror of OpenSSL for including as a submodule
C
4
star
17

ChatSecure-Core

Splitting apart the non-UI code from ChatSecure iOS
3
star
18

ChatSecure-Metadata

Various metadata for ChatSecure
Ruby
3
star
19

Crittercism-SDK

Unofficial Mirror of Crittercism SDK to include as a submodule
Objective-C
2
star
20

chatsecure-users-cookbook

Chef cookbook for managing users
Ruby
2
star
21

PLCrashReporter

Mirror of PLCrashReporter
Objective-C
1
star
22

ChatSecure-Presentations

Slides and such.
1
star