Skip to content
/ envoy Public
forked from greatfire/envoy

C and Java Library derived from Chromium Cronet which can be used to make Android apps resistant to censorship

License

Notifications You must be signed in to change notification settings

cjh0613/envoy

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

C and Java Library derived from chromium cronet. Envoy can be easily added to existing Android apps using OkHttp, Volley, WebView, Cronet basic or java.net.HttpURLConnection to add censorship evasion features.

We are looking for developers to improve envoy together, please contact [email protected].

我们正在寻找开发者一同改进envoy,详情联系[email protected]

Technical details are explained here.

  • for pure c and java cronet library, see directory native/.
  • for the android library, import directory android/ from android studio or build with gradle from the command line.

Please note that this project is unrelated to the Envoy Proxy project.

Getting Started

Example Applications

Getting Envoy

Envoy and our patched Cronet are released though Maven Central. Envoy releases can be found here. Cronet releases can be found here.

Server Setup Examples

See this repo for working examples of services that can be used by Envoy

ENVOY Developer Guide

Welcome to the envoy developer guide. This document will teach you how to build Android apps using APIs in the Android framework and other libraries.

Protocols which Envoy supports

  • HTTPS: proxy all traffic through regular web servers and Content Delivery Networks with support for hardcoding DNS and adding additional headers
  • Shadowsocks: use the socks5 proxy provided by shadowsocks client/server.
  • Hysteria: QUIC based protocol that masquerades as other protocols
  • V2Ray: QUIC based protocols that masquesade as other protocols

Visit native/README.md and android/README.md for more technical details.

What is Cronet

Cronet is the networking stack of Chromium put into a library for use on mobile. This is the same networking stack that is used in the Chrome browser by over a billion people. It offers an easy-to-use, high performance, standards-compliant, and secure way to perform HTTP requests.. On Android, Cronet offers its own Java asynchronous API as well as support for the java.net.HttpURLConnection API. Cronet takes advantage of multiple technologies that reduce the latency and increase the throughput of the network requests that your app needs to work.

Cronet release schedule

The cronet builds are based on the Chromium "Extended Support" releases. They generally stick with one major version, e.g. 102.0.5005.x, until the end of the support period. The Chromium LTS end of life date can be found under "ChromeOS LTS Last Refresh" on https://chromiumdash.appspot.com/schedule

All About Envoy

Envoy is built on top of cronet which offers support for OkHttp, Volley, WebView, Cronet basic and java.net.HttpURLConnection.

We have built robust, unique, censorship-defeating tools and services that are having a big impact in some country where some website and their content are censored

This tool is derived from Cronet.

Cronet is the networking stack of Chromium put into a library for use on mobile. This is the same networking stack that is used in chrome browser by over a billion user.

So it will work with all request type which is mostly used in development. It is used to make app which is resistant to censorship

What is Envoy And Where It can be used

As name suggest envoy is a representative or messenger

Like it our tool will work as messenger or representative for certain website or web content access without worrying of censorship as our tool will work as representative.

As earlier said it can be used to make app resistant to censorship.

Also it can be used as proxy tool communication for secure web access to your app. E.g. if facebook and YouTube is not accessible to country like china and you want to make app which shows facebook content or YouTube content then you can use this tool to show your content.

It can be used as partial content showing or can be used to make whole server communication with this tool depending upon your requirement.

Also if you don't want to use envoy proxy then also you can use this tool to get benefit of cronet library hassle-free. And in future if you want then you just have to simply define envoy url to bypass censorship.

App examples

Patches for adding Envoy support to several applications can be found in the apps directory. However, these patches do not reflect the most recent versions of Envoy or the original apps and may not work as intended at this time.

  1. Wikipedia: ./gradlew clean assembleDevDebug, demo apk, and the migration guide.
  2. DuckDuckGo: ./gradlew assembleDebug, demo apk
  3. WordPress:
    1. WordPress-FluxC-Android: echo "sdk.dir=YOUR_SDK_DIR" > local.properties && ./gradlew fluxc:build
    2. WordPress-Android: set wp.oauth.app_id and wp.oauth.app_secret, then cp gradle.properties-example gradle.properties && ./gradlew assembleVanillaDebug

Wiki Unblocked has been expanded into a stand-alone application. Links to the application and source code can be found above.

Feeder Unblocked is a fork of the Feeder RSS reader with Envoy support added. It is currently in development.

You can submit more apps with git -c diff.noprefix=false format-patch --numbered --binary HEAD~.

Release steps

  1. Rebuild cronet-debug.aar and cronet-release.aar: run ./native/build_cronet.sh debug and ./native/build_cronet.sh release
  2. Rebuild envoy: ./android/build-envoy.sh
  3. Rebuild demo apps: ./apps/build-apps.sh

Building everything from source requires around 100GB of disk space and time. The whole release process is also scripted in the .gitlab-ci.yml. This can also be run using Vagrant by running vagrant up --provision --no-destroy-on-error.

History

  1. Google to reimplement curl in libcrurl | daniel.haxx.se, Simplified Chinese
  2. 973603 - [Cronet] libcurl wrapper library using Cronet API - chromium

About

C and Java Library derived from Chromium Cronet which can be used to make Android apps resistant to censorship

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Kotlin 43.0%
  • C++ 32.6%
  • Java 18.1%
  • Shell 6.2%
  • Makefile 0.1%