• Stars
    star
    260
  • Rank 157,189 (Top 4 %)
  • Language
    Kotlin
  • License
    MIT License
  • Created over 4 years ago
  • Updated over 1 year ago

Reviews

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

Repository Details

Small application to help android developers to quickly enable and disable proxy settings

Build Check Codecov report Android Version License

Proxy Toggle

Small application to help Android and Test Engineers to quickly enable/disable global proxy settings without the faff of going through the annoying Network Settings path.


It's everyone's responsibility to keep this document up to date as part of each release, or if you find something that needs updating.

App installation

If you're only interested in using the app, you can grab the latest release, connect your device and execute the installation script from your Terminal:

./installAndGrantPermission.sh

Android 5.x

Because of old adb limitations, if you want to install the app in devices running Android 5.x, you must run two commands separately:

adb install -t -r proxy-toggle.apk
adb shell pm grant com.kinandcarta.create.proxytoggle android.permission.WRITE_SECURE_SETTINGS

Project setup

No special setup required. Just clone the repository and it should build out of the box. At the moment of writing this, the project is being created using Android Studio 4.2 Canary 3.

About the app

Supported devices

This app supports Android 5.0 and above.

Architecture

The project has a small app module and the different features (manager screen, widget, tile) each have their own module. Things used by several modules are included in core module. Finally, there's a test-utils module for things shared by many modules' test source-trees.

The app follows MVVM Clean Architecture principles.

Dependency Injection

We currently use Hilt for Dependency Injection.
Each Activity and Fragment that use DI must be annotated with @AndroidEntryPoint.
Each ViewModel must be injected using @ViewModelInject in order to be provided using by viewModels().

Testing

We use Github Actions to execute all Unit Tests in the project for every PR against the main branch. JaCoCo is setup to run test coverage. We should aim to increase test coverage on each PR. At the moment of writing this, Hilt and JaCoCo are not totally compatible, so the total coverage shown is not accurate.

Features

Quick proxy setup

Easy setup: just add your desired IP and port, enable the proxy and voilà!, all done, your whole device will be proxied.

Home Screen Widget

The app features a Home Screen widget that the user can use to quickly toggle the proxy with the last used setup, without having to even open the app. It will also allow the user to launch the app to configure the proxy settings, if needed.

Quick Setting Tile

Similarly to the widget, Android 7.0 and above users will have the option to add a Quick Settings Tile in their Notification Drawer. This tile will allow the users to toggle the proxy even without having to leave the current application they are using.

Caveats

WRITE_SECURE_SETTINGS permission

The app will make use of Settings.Global. Since this is a system setting, it's normally a read-only setting. This small inconvenience is bypassed by granting the app WRITE_SECURE_SETTINGS special permission.

Note: this is a protected permission that only System apps should be granted. Be extra careful when you grant this permission for unknown sources apps.

In order to grant this permission once the app is installed, connect the device to your computer and execute the following command on your Terminal:

adb shell pm grant com.kinandcarta.create.proxytoggle android.permission.WRITE_SECURE_SETTINGS

Alternatively, you can grant the permission when installing the app via the command adb install -g App.apk or just use the provided installAndGrantPermission.sh script.

Be careful when uninstalling the app

Uninstalling the app with the proxy enabled will permanently leave your device with this setup (as it's a Settings.Global configuration!). 

You should make sure the proxy is disabled before uninstalling the app!

Since we can't guarantee this is going to happen, we also provide the uninstallAndCleanUp.sh script for making sure everything is in a clean state after uninstalling the app.

Alternatively, you could run the following commands on your Terminal to clean up the proxy setting:

adb shell settings delete global http_proxy
adb shell settings delete global global_http_proxy_host
adb shell settings delete global global_http_proxy_port

License

Proxy Toggle is available under the MIT license. See the LICENSE file for more info.

More Repositories

1

ConfigGenerator

Configuration file code generator for use in Xcode projects
Swift
157
star
2

android-permission-manager

Kotlin
109
star
3

TABTestKit

Library designed to make writing and maintaining automated tests for iOS applications. This includes automation of bio-metrics and controlling of mock servers
Swift
54
star
4

accessibility-guidelines

Plain language summary of the Web Content Accessibility Guidelines
HTML
47
star
5

MasterFastfile

Master Fastfile used for internal builds
Ruby
34
star
6

TABResourceLoader

Framework for loading resources from a network service
Swift
29
star
7

TABSwiftLayout

Provides a flexible, yet minimal API for dealing with AutoLayout programatically
Swift
14
star
8

kc-android

KC Android App
Java
12
star
9

where-to-learn-about-accessibility

Here are some of the best resources to start learning about accessibility and inclusive design.
10
star
10

engineering-challenge

Coding challenge for engineers interested in joining our passionate team
Swift
7
star
11

TABScrollingContentView

A scroll view whose content size is determined based on the auto layout constraints of its subviews.
Swift
6
star
12

engineering-reading-list

A collection of podcasts, publications, tutorials, blogs and industry leaders recommended by the Kin + Carta Engineering CoP (Community of Practice).
5
star
13

TABCommunicate

Lightweight strongly typed wrapper around Multipeer Connectivity
Swift
5
star
14

Android-Code-Guidelines

3
star
15

ARKit-Glasses

Swift
2
star
16

github-actions-demo

Github Actions Demo for Android COP
Kotlin
1
star
17

iOS-Style-Guide

Our coding style guide for Objective C and Swift
1
star
18

kap-shopping-app

kap shopping app
TypeScript
1
star
19

ios-challenge

[OLD] Coding challenge for iOS engineers looking to join our passionate team
1
star
20

patios

Manage large Open API specifications and automatically generate TypeScript definitions from them.
TypeScript
1
star
21

Tracy

An example of how to create a simple Contact Tracing app for iOS and Android using Bluetooth LE
Kotlin
1
star
22

chef-zypper

Ruby
1
star
23

ModularSlothCreator

Modular Sloth Creator project for DocC and Danger Blog Posts on https://medium.com/kinandcartacreated/
Swift
1
star