All Projects → wireapp → Wire Ios

wireapp / Wire Ios

Licence: gpl-3.0
📱 Wire for iOS (iPhone and iPad)

Programming Languages

swift
15916 projects

Projects that are alternatives of or similar to Wire Ios

adamant-iOS
iOS native client for ADAMANT Decentralized Messenger
Stars: ✭ 20 (-99.35%)
Mutual labels:  privacy, encryption, communication, messenger
Qtox
qTox is a chat, voice, video, and file transfer IM client using the encrypted peer-to-peer Tox protocol.
Stars: ✭ 3,843 (+24.81%)
Mutual labels:  audio, communication, privacy, encryption
Messenger
Open source, native iOS Messenger, with realtime chat conversations (full offline support).
Stars: ✭ 4,264 (+38.49%)
Mutual labels:  messenger, instant-messaging, swift5
Applozic Android Sdk
Android Real Time Chat & Messaging SDK
Stars: ✭ 611 (-80.16%)
Mutual labels:  messenger, communication, messenger-platform
Discordcrypt
End-To-End File & Message Encryption For Discord
Stars: ✭ 150 (-95.13%)
Mutual labels:  messenger, privacy, encryption
Chat Ui Kit React
Build your own chat UI with React components in few minutes. Chat UI Kit from chatscope is an open source UI toolkit for developing web chat applications.
Stars: ✭ 131 (-95.75%)
Mutual labels:  messenger, communication, instant-messaging
Magicpad
MagicPad is an encryption suite for beginners. It is designed to be run standalone via the browser or executable (Electron).
Stars: ✭ 174 (-94.35%)
Mutual labels:  privacy, encryption, mobile
Xabber Android
Open-source XMPP client for Android
Stars: ✭ 1,773 (-42.42%)
Mutual labels:  messenger, mobile, otr
Sdk Js
Tanker client-side encryption SDK for JavaScript
Stars: ✭ 786 (-74.47%)
Mutual labels:  privacy, encryption, end-to-end
Berty
Berty is a secure peer-to-peer messaging app that works with or without internet access, cellular data or trust in the network
Stars: ✭ 5,101 (+65.67%)
Mutual labels:  mobile-app, privacy, encryption
Eeui
📱 使用 Vue.js 跨平台开发高质量原生(Android/iOS)应用。
Stars: ✭ 475 (-84.57%)
Mutual labels:  mobile-app, mobile, app
Flutter parallax scroll
Flutter UI challenge- Parallax scroll effect
Stars: ✭ 172 (-94.41%)
Mutual labels:  mobile-app, mobile, app
Mangosta Ios
MongooseIM client for iOS
Stars: ✭ 28 (-99.09%)
Mutual labels:  mobile-app, instant-messaging, mobile
Fultter Example App
一个功能完整齐全的Bloc模式Flutter App项目。🍨更关注架构的SPA应用。,使用Node作为后台系统,使用了部分官方plugin,大体功能自己封装。🥰 有用请Star。
Stars: ✭ 248 (-91.95%)
Mutual labels:  mobile-app, mobile, app
mandarin-android
🍊 Android mobile IM client
Stars: ✭ 26 (-99.16%)
Mutual labels:  messenger, instant-messaging
Channelize-iOS-Chat-SDK-Sample
Open-source JavaScript SDK to enable Real-time Messaging
Stars: ✭ 30 (-99.03%)
Mutual labels:  communication, messenger
DiscordEncryption
🔐 Configurable end to end encryption for Discord
Stars: ✭ 30 (-99.03%)
Mutual labels:  encryption, end-to-end
iGap-Plus
An alternative official version iGap messenger client
Stars: ✭ 20 (-99.35%)
Mutual labels:  messenger, instant-messaging
iGap-Android
iGap Client for Android Source Code
Stars: ✭ 54 (-98.25%)
Mutual labels:  messenger, instant-messaging
facebook-send-api-emulator
Facebook Messenger Emulator & Facebook Send API Emulator functionality allowing you to test web hooks on developer's machine.
Stars: ✭ 24 (-99.22%)
Mutual labels:  messenger, messenger-platform

Wire™

Wire logo

Build Status

This repository is part of the source code of Wire. You can find more information at wire.com or by contacting [email protected].

You can find the published source code at github.com/wireapp/wire.

For licensing information, see the attached LICENSE file and the list of third-party licenses at wire.com/legal/licenses/.

If you compile the open source software that we make available from time to time to develop your own mobile, desktop or web application, and cause that application to connect to our servers for any purposes, we refer to that resulting application as an “Open Source App”. All Open Source Apps are subject to, and may only be used and/or commercialized in accordance with, the Terms of Use applicable to the Wire Application, which can be found at https://wire.com/legal/#terms. Additionally, if you choose to build an Open Source App, certain restrictions apply, as follows:

a. You agree not to change the way the Open Source App connects and interacts with our servers; b. You agree not to weaken any of the security features of the Open Source App; c. You agree not to use our servers to store data for purposes other than the intended and original functionality of the Open Source App; d. You acknowledge that you are solely responsible for any and all updates to your Open Source App.

For clarity, if you compile the open source software that we make available from time to time to develop your own mobile, desktop or web application, and do not cause that application to connect to our servers for any purposes, then that application will not be deemed an Open Source App and the foregoing will not apply to that application.

No license is granted to the Wire trademark and its associated logos, all of which will continue to be owned exclusively by Wire Swiss GmbH. Any use of the Wire trademark and/or its associated logos is expressly prohibited without the express prior written consent of Wire Swiss GmbH.

Wire iOS

The Wire mobile app has an architectural layer that we call sync engine. It is the client-side layer that processes all the data that is displayed in the mobile app. It handles network communication and authentication with the backend, push notifications, local caching of data, client-side business logic, signaling with the audio-video libraries, encryption and decryption (using encryption libraries from a lower level) and other bits and pieces.

The user interface layer of the mobile app is built on top of the sync engine, which provides the data to display to the UI. The sync engine itself is built on top of a few third-party frameworks, and uses Wire components that are shared between platforms for cryptography (Proteus/Cryptobox) and audio-video signaling (AVS).

Mobile app architecture

Documentation

Additional documentation is available in the Wire iOS wiki.

How to build the open source client

What is included in the open source client

The project in this repository contains the Wire iOS client project. You can build the project yourself. However, there are some differences with the binary Wire iOS client available on the App Store. These differences are:

  • the open source project does not include the API keys of Vimeo, Localytics, HockeyApp and other 3rd party services.
  • the open source project links against the open source Wire audio-video-signaling (AVS) library. The binary App Store client links against an AVS version that contains proprietary improvements for the call quality.

Prerequisites

In order to build Wire for iOS locally, it is necessary to install the following tools on the local machine:

The setup script will automatically check for you that you satisfy these requirements

How to build locally

  1. Check out the wire-ios repository.
  2. From the checkout folder, run ./setup.sh. This will pull in all the necessary dependencies with Carthage and verify that you have the right version of the tools installed.
  3. Open the project Wire-iOS.xcodeproj in Xcode
  4. Click the "Run" button in Xcode

These steps allow you to build only the Wire umbrella project, pulling in all other Wire frameworks with Carthage. If you want to modify the source/debug other Wire frameworks, you can open the Carthage/Checkouts subfolder and open the individual projects for each dependency there.

You can then use carthage bootstrap --platform ios --use-xcframeworks to rebuild the dependency and use it in the umbrella project.

Known limitations

Notifications send through Apple Push Notification service can only be received by the App Store Wire client, which is code signed with Wire's own certificate. This is a security feature enforced by Apple, as documented in Apple's Local and Remote Notification Programming Guide. Any client build from source will not be able to receive notifications.

Translations

All Wire translations are crowdsourced via CrowdIn: https://crowdin.com/projects/wire

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].