Skip to content

Testing playground to support the peernet protocol on android phones.

Notifications You must be signed in to change notification settings

PeernetOfficial/core-android

Repository files navigation


Core Android


image

Topics

  1. Introduciton
  2. Disclaimer
  3. Current features
  4. Build from gomobile
  5. Implementation
  6. Indentified issues
  7. Potential fixes/improvements

Introduction

Testing playground to support the peernet protocol on android phones. The implementation above is a proof of concept android application. There is currently no modifications done to the peernet core to get it running on android phones. As a brief the entire project is done using Kotlin with Go mobile.

Screenshots:

image


Disclaimer:

It is important to note that there could be scenarios where the phone could potencially freeze. The current commits are currently unstable.


Current Features:

  1. User perpective:
    • Upload file to peernet
      1. Add files to warehouse
      2. Add file to blockchain
    • Download file from peernet
    • View latest files uploaded
  2. Developers perpective
    • Full support of peernet core (till Api level 29)
    • Ability to interact with peernet core via API calls from peernet server running inside the phone.

Build from gomobile:

The following steps below demonstrate how to build the application:

  • Create go project with the package called mobile

The following applies for linux

  • clone the following repo
git clone https://github.com/PeernetOfficial/core-android
  • add the following files(i.e mobile.aar,mobile-sources.jar) to the following path. Overwrite it if the file already exists.

Instructions to generate .aar and .jar files: https://github.com/PeernetOfficial/Core-Mobile#readme.

/<path of the repo>/core-android/app/libs/
  • Open the project in android studio and click the play button. image

  • Before opening the app ensure internal storage is enabled.

image


Implementation

The following is built using Kotlin, gomobile. Go code is the peernet core protocol. The Kotlin interacts with the with generated .aar (i.e which is the output when compiling using gomobile). The .aar is the peernet core protocol implementation. The interactions with the Go code are the following:

  • Call the exported function MobileMain(<android application storage path>). This is the only function binded to the koltin code. The application path is dervired from the kotlin code.
  • On calling MobileMain(<android application storage path>) peernet core is started and the webapi is started as well. The api address is the following http://127.0.0.1:5125.
  • The kotlin code only interacts with api calls from the following steps.

Note: The gomobile core only currently runs the foreground when the application is open.

Permissions manually needed to be enabled

  • Internal storage

Android manifest information

  • android.permission.READ_EXTERNAL_STORAGE
  • android.permission.WRITE_EXTERNAL_STORAGE
  • android.permission.INTERNET
  • android.permission.ACCESS_NETWORK_STATE
  • android.permission.ACCESS_WIFI_STATE
  • Due to http traffic:
    1. android:usesCleartextTraffic="true"

Indentified issues

The core-android only supports upto Android API level 29.

Api level 30 issue

The following is a list of the ways that apps are affected by this change (from Api level 30 onwards):

  • NetworkInterface.getHardwareAddress() returns null for every interface.
  • Apps cannot use the bind() function on NETLINK_ROUTE sockets.
  • The ip command does not return information about interfaces.
  • Apps cannot send RTM_GETLINK messages.

source (https://developer.android.com/training/articles/user-data-ids#mac-11-plus)


Possible solution

" SDK 30 prohibits syscall.NetlinkRIB(syscall.RTM_GETADDR, ...) which Go's net.Interfaces uses. Implement an Android specific version of net.Interfaces to use instead.

Passing primitive types across JNI is relatively straightforward, passing a single object of a complex class is annoying but still possible, but passing lists and other more complex data structures is way harder. As such, this commit added a Java routine to render the interface information to a string and pass that across JNI as a primitive type for Go code to parse. " PR with a solution: tailscale/tailscale-android#21

Track issue

Potential fixes/improvements

  • Providing compatability to API level 30.
  • Cleaning up android core code for lesser redundency and readability.
  • Running the core as a background process.
  • UI improvements for ease of use
  • Displaying downloaded files in the app itself

About

Testing playground to support the peernet protocol on android phones.

Resources

Stars

Watchers

Forks

Packages

No packages published