Mirror of https://github.com/syphon-org/syphon.git to allow for building of hourly unofficial dev versions of the app https://syphon.org
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
taylor 0aaf740465
[fixes] MacOS Builds (#261)
1 week ago
.fvm fix|refactor: issues creating new direct rooms, renamed screen files to make more sense 3 weeks ago
.github feat: auto requesting pre-key messages if none found for a message 3 weeks ago
.vscode single sign on UI and clean up for login/signup flows 5 months ago
android fix: android builds, notification group testing 3 weeks ago
assets feat|refactor: tons of refactoring regarding file organization, started working on key requests feature 3 weeks ago
fastlane/metadata/android add 163 FDroid changelog 4 months ago
ios fix: service notification should now always appear, ability for background thread room name fetch, other notification improvements 3 weeks ago
lib [fixes] MacOS Builds (#261) 1 week ago
linux refactor:initial upgrade to dart null-saftey 2 months ago
macos [fixes] MacOS Builds (#261) 1 week ago
scripts [feature] Desktop Builds (#212) 6 months ago
test renaming package to syphon 12 months ago
.gitignore fix|refactor: issues creating new direct rooms, renamed screen files to make more sense 3 weeks ago
.gitmodules attempting to use a dart olm impl 1 year ago
.metadata init commit 2 years ago
analysis_options.yaml refactor: massive lint fix, setting code standards 3 weeks ago
changelog.md better media managment and cold storage probing 6 months ago
license.md adding license + touch ups 12 months ago
pubspec.lock fix: key signatures and uploads working again 3 weeks ago
pubspec.yaml fix: key signatures and uploads working again 3 weeks ago
readme.md Updates for desktop builds 1 week ago
updates.md add TWIM update template 4 months ago
version.txt Update version.txt 4 months ago

readme.md


a privacy centric matrix client - now in open alpha*

Get it on Google Play Download on the App Store


Syphon is still in alpha and we do not recommend
using it where proven and independently verified security is required.


🤔 Why

Syphon aims to be built on the foundations of privacy, branding, and user experience
in an effort to pull others away from proprietary chat platforms to the matrix protocol.

Matrix has the potential to be a standardized peer-to-peer chat protocol, and in a way already is, that allows people to communicate and control their conversation data. Email has been standardized in this way for a long time. For example, someone using Outlook can still email someone using Gmail. Most popular proprietary chat platforms do not adhere to a federated or decentralized protocol, and as a result have too much control over users data.

If the goal for Matrix is adoption, a network effect is required for this paradigm shift. Syphon makes the bet that the best way to attract new users is through strong branding and user experience. I hope that contributing and maintaining Syphon will help kick start this process and help those in need.

Syphon will always be a not for profit, community driven application.

Features

  • no analytics. period.
  • no proprietary third party services
    • iOS will have APNS support, but will be made clear to the user
  • all data is AES-256 encrypted at rest
  • E2EE for direct chats using Olm/Megolm
  • all indicators of presence are opt-in only (typing indicators, read receipts, etc)
  • customize themes and colors throughout the app

🚀 Goals

  • desktop clients meet parity with mobile
  • screen lock and pin protected cache features
  • P2P messaging through a locally run server on the client
  • allow transfering user data from one homeserver to another, or from local to remote servers
  • cli client using ncurses and the same redux store contained here (common)

🏗️ Building

You may notice Syphon does not look very dart-y (for example, no _private variable declarations, or using redux instead of provider) in an effort to reduce the learning curve from other languages or platforms. The faster one can get people contributing, the easier it will be for others to maintain or oversee a tool that does not exploit the user.

general

  • you'll to do several things to setup the environment for Syphon
    • install flutter (stable channel for ios/android)
    • install android studio
    • install cmake version for workstation platform (for olm/megolm)
    • install libs needed for cmake
      • macos -> brew install ninja
      • linux -> sudo apt install ninja-build
    • clone repo and init submodules
      • git submodule update --init --recursive
    • run the following prebuild commands
      • flutter pub get
      • flutter pub run build_runner build

ios/android

  1. pull dependencies needed
    • flutter pub get
  2. generate json conversion for models
    • flutter pub run build_runner build --delete-conflicting-outputs
  3. generate json conversion for models
    • flutter run

macos

  1. flutter config --enable-macos-desktop
  2. brew install libolm to install native olm dependencies
  3. follow instructions for linking the dylib generated from brew to the Syphon project
  1. flutter build macos to build the .app bundle

linux

  1. flutter config --enable-linux-desktop
  2. apt install libolm3 libsqlite3-dev or pacman -S libolm or platform equivalent for libolm
  3. flutter build linux && flutter build bundle
  4. navigate to release at $SYPHON_ROOT/build/linux/release/bundle
  5. Confirm build works with running $SYPHON_ROOT/build/linux/release/bundle/syphon

windows

  • not currently supported, feel free to reach out if you can support making builds!

📐 Architecture

store

  • views (flutter)
  • state (redux)
  • cache (redux_persist + json_serializable + sembast)
  • storage (sembast + sqflite + codec cipher)

assets

  • Looking for branding or design files? They can all be found here, in the top level assets folder.

integrations

  • Notifications
    • utitlizes android_alarm_manager on Android to run the matrix /sync requests in a background thread and display notifications with flutter_local_notifications
    • no third party notification provider will ever be used outside Apples APNS for iOS only
  • Equatable
    • This library allows comparisons of objects within Flutter to tell if they have changed.
  • JsonSerializable
    • Unfortunately, Json is not integrated directly in Dart/Flutter for your own objects. Code generation is required, for now, and will convert Syphon's custom objects to a 'Map' of respective json fields
  • Freezed (future)
    • Because every object in Syphon is immutable, freezed will help create objects doing the same thing all the 'copyWith' helper functions do today, with the improvement of allowing 'null' values to overwrite non-null values
  • Fastline Directory
    • fastline is not used as tool, but is there to provide a schema of metadata to FDroid

references

decoration: BoxDecoration(
   border: Border.all(width: 1, color: Colors.white),
),
  • understanding why olm chose the world 'pickle' for serialization, its from python

📝 contributing

  • email hello@syphon.org if you'd like to get involved. there's a lot to do.
  • donations are welcome, but not required. Syphon will always be a not for profit, community driven application not owned or sold by a corporation.

from those who made it possible

lub youu