1
0
mirror of https://github.com/NekoX-Dev/NekoX.git synced 2024-12-14 04:49:46 +01:00
Go to file
2021-01-18 21:20:00 +08:00
.github
bin Bump version 2021-01-17 18:25:43 +08:00
gradle/wrapper
openpgp-api
ss-rust Fix shadowsocks 2021-01-12 11:13:37 +08:00
ssr-libev
TMessagesProj Bump version 2021-01-18 21:20:00 +08:00
Tools
.gitignore
.gitmodules
apkdiff.py
build.gradle Bump kotlin-gradle-plugin from 1.4.21 to 1.4.21-2 (#311) 2020-12-30 18:11:58 +08:00
crowdin.yml
Dockerfile
gradle.properties
gradlew
gradlew.bat
LICENSE
README.md Update build scripts 2021-01-17 10:45:09 +08:00
run Allow hide phone and id 2021-01-17 19:39:32 +08:00
settings.gradle

NekoX

NekoX is an open source third-party Telegram client, based on Telegram-FOSS with features added.

The play store version is outdated due to the target api level 29 is not supported yet. Otherwise, the play version won't be able to read photos and files (like other 3rd apps do).

NekoX Changes

  • Most of Nekogram's features
  • OpenCC Chinese Convert
  • Built-in Vmess, Shadowsocks, SSR proxies support
  • Built-in public proxy list / Proxy subscription support.
  • Proxies import and export, remarks, speed measurement, sorting, delete unusable nodes, etc.
  • Scan the qrcode (any link, can add a proxy).
  • The ( vemss / vmess1 / ss / ssr / rb ) proxy link in the message can be clicked.
  • Allow auto disable proxy when VPN is enabled
  • Proxy automatic switcher
  • Add stickers without sticker pack
  • Allow disable vibration
  • Sticker set list backup / restore / share
  • Full InstantView translation support
  • Translation support for selected text on input and in messages
  • Delete all messages in group
  • Dialog sorting is optional "Unread and can be prioritized for reminding" etc.
  • Allow to skip "regret within five seconds"
  • Unblock all users support
  • Login via QR code
  • Scan and confirm the login QR code directly
  • Allow clear application data
  • Option to not send comment first when forwarding
  • 0ption to use nekox chat input menu: replace record button with a menu which contains an switch to control link preview (enabled by default)
  • Option to disable link preview by default: to prevent the server from knowing that the link is shared through Telegram.
  • Option to ignore Android-only content restrictions (except for the Play Store version).
  • OpenKaychain client ( sign / verify / decrypt / import )
  • Google Cloud Translate / Yandex.Translate support
  • Custom cache directory (supports external storage)
  • Custom AppId and Hash (optional NekoX / Andorid / Android X or Manual input)
  • Custom server (official, test DC or Manual input)
  • Keep the original file name when downloading files
  • View the data center you belong to when you don't have an avatar
  • Proxies, groups, channels, sticker packs are able to shared as QRCodes.
  • Force English emoji keywords to be loaded
  • Add "@Name" when long press @ user option
  • Enhanced notification service, optional version without Google Services.
  • Don't alert "Proxy unavailable" for non-current account
  • Tgx style message unpin menu
  • Built-in Material Design themes / Telegram X style icons

Compilation Guide

NOTE: Building on Windows is, unfortunately, not supported. Consider using a Linux VM or dual booting.

Important:

  1. Install Android Sdk and NDK ( default location is $HOME/Android/Sdk, otherwise you need to specify $ANDROID_HOME for it )

It is recommended to use AndroidStudio to install. here is how to install AndroidStudio.

  1. Install golang ( >= 1.15.5 ).
apt install -y golang
  1. Install rust and its stdlib for android abis, add environment variables for it.

It is recommended to use the official script, otherwise you may not find rustup.

curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- --default-toolchain none -y
echo "source \$HOME/.cargo/env" >> $HOME/.bashrc && source $HOME/.cargo/env

cd ss-rust/src/main/rust/shadowsocks-rust
rustup target install armv7-linux-androideabi aarch64-linux-android i686-linux-android x86_64-linux-android
  1. Build native dependencies: ./run init libs
  2. Build external libraries and native code: ./run libs update
  3. Fill out TELEGRAM_APP_ID and TELEGRAM_APP_HASH in local.properties
  4. Replace TMessagesProj/google-services.json if you want fcm to work.
  5. Replace release.keystore with yours and fill out ALIAS_NAME, KEYSTORE_PASS and ALIAS_PASS in local.properties if you want a non-debug build.

./gradlew assemble<Full/Mini><Debug/Release/ReleaseNoGcm>

FAQ

What is the relationship between NekoX and Nekogram?

More features, without additional trackers.

What is the difference between Full and Mini version?

The full version comes with built-in proxy support for v2ray, shadowsocks, and shadowsocksr, which is usually provided to advanced users to help friends who have no computer knowledge in mainland China to bypass censorship. Don't complain about imperfect functions or ask to add other rare proxy types, you can use their clients directly.

What if I don't need a proxy?

Then it is recommended to use the Mini version.

How can I help with Localization?

Join the project at https://nekox.crowdin.com/nekox.

Credits