"...main/git@repo.buzztime.com:halo/external_conscrypt.git" did not exist on "7ec6fc77bbf547ae018178262453f38ff3b45974"
Preparing for move to github.
nmittler authored
Change-Id: Icc28dd498c5facd4b22e3ee24a8363f01ec681ea
7ec6fc77

Conscrypt - A Java Security Provider

Conscrypt is a fast, native alternative to the default security provider of the JDK based on BoringSSL. It was originally developed for Android, but has since been repurposed for any Java platform.

The core SSL engine has borrowed liberally from the Netty project and their work on netty-tcnative, giving Conscrypt similar performance. You can think of Conscrypt as netty-tcnative + full Java security provider.

Homepage: conscrypt.org
Mailing List: conscrypt@googlegroups.com

Download

Download JARs

You can download the JARs directly from the Maven repositories.

OpenJDK (i.e. non-Android)

Maven

Use the os-maven-plugin to add the dependency:

<build>
  <extensions>
    <extension>
      <groupId>kr.motd.maven</groupId>
      <artifactId>os-maven-plugin</artifactId>
      <version>1.4.1.Final</version>
    </extension>
  </extensions>
</build>

<dependency>
  <groupId>org.conscrypt</groupId>
  <artifactId>conscrypt-openjdk</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <classifier>${os.detected.classifier}</classifier>
</dependency>
Gradle

Use the osdetector-gradle-plugin (which is a wrapper around the os-maven-plugin) to add the dependency:

buildscript {
  repositories {
    mavenCentral()
  }
  dependencies {
    classpath 'com.google.gradle:osdetector-gradle-plugin:1.4.0'
  }
}

// Use the osdetector-gradle-plugin
apply plugin: "com.google.osdetector"

dependencies {
  compile 'org.conscrypt:conscrypt-jdk:0.0.1-SNAPSHOT:' + osdetector.classifier
}

Artifacts are available for the following platforms:

Classifier Description
windows-x86_64 Windows distribution
osx-x86_64 Mac distribution
linux-x86_64 Used for Linux

How to Build

If you are making changes to Conscrypt, see the building instructions.

Source Overview

Here's a quick readers' guide to the code to help folks get started. At a high level there are three distinct modules: Common, Android & OpenJDK.

Common

This contains the bulk of the code. It contains stub classes for platform-specific functions, which are stripped out of the final JAR.

It also contains all of the native code, but does not build any native artifacts. Instead, the platform-specific modules will include this source in their builds.

Android

This module provides the Platform class for Android and also adds compatibility classes for supporting various versions of Android. This generates an apk library artifact.

OpenJDK

This modules provides the Platform class for non-Android (OpenJDK-based) systems. It also provides a native library loader supports bundling the shared library with the JAR.