For licensing information, see the attached LICENSE file and the list of third-party licenses at wire.com/legal/licenses/.
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.
Build your own Wire client
Wire for Web
The audio, video, and signaling (AVS) library of Wire is developed in ANSI C/C++. The code is cross compiled for Android and iOS. Wrappers for interaction with upstream modules are written in Java for Android and Objective-C for iOS.
- avs: Audio-video library for calling (mostly C), then cross compiled for iOS and Android
- proteus: Axolotl Protocol Implementation in Rust, then cross compiled for iOS and Android
- cryptobox: High-level API with persistent storage for proteus
- cryptobox-haskell: Haskell bindings to cryptobox
- cryptobox-c: C-FFI to cryptobox
- hkdf: HKDF implementation (RFC 5869) in Rust, then cross compiled to iOS and Android
The Wire server components can be found in the wire-server repository.
Protocol buffer definitions are used by all clients to communicate with each other and with the backend.
- generic-message-proto: Protocol buffer definitions that are part of the cross-platform client communication protocol
- backend-api-protobuf: Protocol buffer definitions that are part of the backend communication protocol
You can contribute to Wire in several ways:
If you find a bug in how Wire apps work, please submit a ticket to our support and we will keep you informed about the progress.
Contributing to the code
If you wish to contribute source code to one of our repositories you have to sign our Contributor Agreement first.
We accept only bug fixes and code improvements. We cannot accept new features, UI or UX changes – these are decided on and built by the Wire development team.
When you submit your first pull request, you can sign the agreement electronically by filling in the required information. You will not have to sign it again for subsequent pull requests from the same GitHub account.
Translating the apps
You can help with the crowdsourced translations of Wire apps on Crowdin.