• Stars
    star
    2,820
  • Rank 15,533 (Top 0.4 %)
  • Language
    Rust
  • License
    GNU Affero Genera...
  • Created over 3 years ago
  • Updated 2 months ago

Reviews

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

Repository Details

Home to the Signal Protocol as well as other cryptographic primitives which make Signal possible.

Overview

libsignal contains platform-agnostic APIs used by the official Signal clients and servers, exposed as a Java, Swift, or TypeScript library. The underlying implementations are written in Rust:

  • libsignal-protocol: Implements the Signal protocol, including the Double Ratchet algorithm. A replacement for libsignal-protocol-java and libsignal-metadata-java.
  • signal-crypto: Cryptographic primitives such as AES-GCM. We use RustCrypto's where we can but sometimes have differing needs.
  • device-transfer: Support logic for Signal's device-to-device transfer feature.
  • attest: Functionality for remote attestation of SGX enclaves and server-side HSMs.
  • zkgroup: Functionality for zero-knowledge groups and related features available in Signal.
  • zkcredential: An abstraction for the sort of zero-knowledge credentials used by zkgroup, based on the paper "The Signal Private Group System" by Chase, Perrin, and Zaverucha.
  • poksho: Utilities for implementing zero-knowledge proofs (such as those used by zkgroup); stands for "proof-of-knowledge, stateful-hash-object".
  • pin: Functionality for consistently using PINs as passwords in Signal's Secure Value Recovery system.
  • usernames: Functionality for username generation, hashing, and proofs.
  • media: Utilities for manipulating media.

This repository is used by the Signal client apps (Android, iOS, and Desktop) as well as server-side. Use outside of Signal is unsupported. In particular, the products of this repository are the Java, Swift, and TypeScript libraries that wrap the underlying Rust implementations. All APIs and implementations are subject to change without notice, as are the JNI, C, and Node add-on "bridge" layers. However, backwards-incompatible changes to the Java, Swift, TypeScript, and non-bridge Rust APIs will be reflected in the version number on a best-effort basis.

Building

To build anything in this repository you must have Rust installed, as well as Clang, libclang, CMake, and Make. On a Debian-like system, you can get these extra dependencies through apt:

$ apt-get install clang libclang-dev cmake make

The build currently uses a specific version of the Rust nightly compiler, which will be downloaded automatically by cargo. To build and test the basic protocol libraries:

$ cargo build
...
$ cargo test
...

Java/Android

To build for Android you must install several additional packages including a JDK, the Android NDK/SDK, and add the Android targets to the Rust compiler, using

rustup target add armv7-linux-androideabi aarch64-linux-android i686-linux-android x86_64-linux-android

To build the Java/Android jar and aar, and run the tests:

$ cd java
$ ./gradlew test
$ ./gradlew build # if you need AAR outputs

Alternately, a build system using Docker is available:

$ cd java
$ make java_test

When exposing new APIs to Java, you will need to run rust/bridge/jni/bin/gen_java_decl.py in addition to rebuilding.

Swift

To learn about the Swift build process see swift/README.md

Node

You'll need Node installed to build. If you have nvm, you can run nvm use to select an appropriate version automatically.

We use yarn as our package manager. The Rust library will automatically be built when you run yarn install.

$ cd node
$ nvm use
$ yarn install
$ yarn tsc
$ yarn test

When testing changes locally, you can use yarn build to do an incremental rebuild of the Rust library.

When exposing new APIs to Node, you will need to run rust/bridge/node/bin/gen_ts_decl.py in addition to rebuilding.

Contributions

Signal does accept external contributions to this project. However unless the change is simple and easily understood, for example fixing a bug or portability issue, adding a new test, or improving performance, first open an issue to discuss your intended change as not all changes can be accepted.

Contributions that will not be used directly by one of Signal's official client apps may still be considered, but only if they do not pose an undue maintenance burden or conflict with the goals of the project.

Signing a CLA (Contributor License Agreement) is required for all contributions.

Legal things

Cryptography Notice

This distribution includes cryptographic software. The country in which you currently reside may have restrictions on the import, possession, use, and/or re-export to another country, of encryption software. BEFORE using any encryption software, please check your country's laws, regulations and policies concerning the import, possession, or use, and re-export of encryption software, to see if this is permitted. See http://www.wassenaar.org/ for more information.

The U.S. Government Department of Commerce, Bureau of Industry and Security (BIS), has classified this software as Export Commodity Control Number (ECCN) 5D002.C.1, which includes information security software using or performing cryptographic functions with asymmetric algorithms. The form and manner of this distribution makes it eligible for export under the License Exception ENC Technology Software Unrestricted (TSU) exception (see the BIS Export Administration Regulations, Section 740.13) for both object code and source code.

License

Copyright 2020-2023 Signal Messenger, LLC.

Licensed under the AGPLv3: https://www.gnu.org/licenses/agpl-3.0.html

More Repositories

1

Signal-Android

A private messenger for Android.
Java
24,766
star
2

Signal-Desktop

A private messenger for Windows, macOS, and Linux.
TypeScript
13,934
star
3

Signal-iOS

A private messenger for iOS.
Swift
10,405
star
4

Signal-Server

Server supporting the Signal Private Messenger applications on Android, Desktop, and iOS
Java
8,781
star
5

libsignal-protocol-javascript

This library is no longer maintained. libsignal-protocol-javascript was an implementation of the Signal Protocol, written in JavaScript. It has been replaced by libsignal-client’s typesafe TypeScript API.
JavaScript
1,963
star
6

libsignal-protocol-java

Java
1,814
star
7

libsignal-protocol-c

C
1,406
star
8

BitHub

BTC + BitHub = An experiment in funding privacy OSS.
Java
999
star
9

libsignal-service-java

A Java/Android library for communicating with the Signal messaging service.
Java
574
star
10

Signal-TLS-Proxy

Dockerfile
552
star
11

ringrtc

Rust
522
star
12

Signal-Calling-Service

Forwards media from 1 group call device to N group call devices.
Rust
409
star
13

Flock

Private contact and calendar sync for Android.
Java
359
star
14

ContactDiscoveryService

C
277
star
15

SecureValueRecovery

Rust
276
star
16

gradle-witness

A gradle plugin that enables static verification for remote dependencies.
Groovy
228
star
17

curve25519-java

Pure Java and JNI backed Curve25519 implementation.
C
225
star
18

SignalProtocolKit

This library is no longer maintained. SignalProtocolKit was an implementation of the Signal Protocol, written in Objective-C. It has been replaced by libsignal-client’s type safe Swift API.
Objective-C
214
star
19

webrtc

C++
127
star
20

PushServer

A microservice for communicating with push gateways.
Java
115
star
21

WhisperYAFFS

Encrypted Filesystem Support For YAFFS2
C
103
star
22

jobmanager

Android library for executing tasks.
Java
103
star
23

WebSocket-Resources

A Dropwizard library that lets you use Jersey-style Resources over WebSockets
Java
91
star
24

better-sqlite3

C++
68
star
25

SignalServiceKit

SignalServiceKit has moved to Signal-iOS. See README.md for details.
Objective-C
68
star
26

libwebrtc-android

Android WebRTC Packages
Java
58
star
27

Signal-Pods

Pods dependency tracker for Signal-iOS
C
54
star
28

signal-ringrtc-node

TypeScript
48
star
29

gcm-sender-async

Asynchronous Google Cloud Messaging (GCM) Library
Java
48
star
30

zkgroup

41
star
31

libsignal-protocol-rust

Rust
38
star
32

Signal-Design

A place to archive design assets used by Signal.
35
star
33

curve25519-dalek

Rust
34
star
34

Argon2

Java
34
star
35

signal-webrtc-ios

Python
33
star
36

SignalCoreKit

Swift
31
star
37

storage-service

Java
28
star
38

libpastelog

Java
27
star
39

maven

26
star
40

Signal-FTS5-Extension

A FTS5 extension for signal_tokenizer.
Rust
26
star
41

ContactDiscoveryService-Icelake

C
25
star
42

SecureValueRecovery2

C++
23
star
43

dropwizard-simpleauth

Dropwizard library for simple @Auth annotations that support multiple types
Java
22
star
44

CLAServer

GitHub Integration for managing CLA signatures
Java
22
star
45

Mock-Signal-Server

TypeScript
21
star
46

mio

Rust
20
star
47

AES-GCM-Provider

A BoringSSL-backed AES-GCM provider for Android with support for "incremental" encryption/decryption
Java
19
star
48

registration-service

Registration Service for Signal
Java
17
star
49

libaxolotl-j2me

Axolotl J2ME
Java
17
star
50

signal-webrtc-ios-artifacts

Objective-C
17
star
51

tus-server

An implementation of the TUS server protocol for resumable uploads
TypeScript
15
star
52

SQLCipherVsSharedData

Demo Project to demonstrate a bug in SQLCipher
Objective-C
15
star
53

Signal-Art-Creator

Sticker Pack Creator Web App
TypeScript
15
star
54

dropwizard-wavefront

Dropwizard Metrics Reporter For Wavefront
Java
14
star
55

SignalMetadataKit

Swift
13
star
56

sgx_common

Rust
13
star
57

Signal-Carthage

Objective-C
12
star
58

emoji-search-index

Static assets used for to generate a search index for emoji within Signal.
11
star
59

libsignal-client-node

11
star
60

redis-dispatch

Java
11
star
61

libsignal-metadata-java

Java
10
star
62

libmobilecoin-ios-artifacts

Swift
10
star
63

signal-zkgroup-node

TypeScript
9
star
64

poksho

9
star
65

AccountStream

Java
7
star
66

jekyll-simple-i18n

Ruby
7
star
67

s3-upload-maven-plugin

Maven plugin to upload files to s3
Java
6
star
68

mp4san

A Rust MP4 format sanitizer
Rust
6
star
69

sqlcipher

C
5
star
70

libsignal-ffi

Rust
4
star
71

HsmEnclave

HSM-backed remote-attestable enclave.
C
4
star
72

signal-zkgroup-swift

Swift
4
star
73

sqlcipher-android

A light fork of https://github.com/sqlcipher/sqlcipher-android
C
4
star
74

partial-default

Provides PartialDefault, a Rust trait similar to Default but with fewer guarantees
Rust
2
star
75

libsignal-protocol-swift

Swift
2
star
76

storage-manager

Manage objects inside a cdn
TypeScript
1
star