Session Desktop - Onion routing based messenger
You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
Go to file
sachaaaaa 6e9ea52e1e add the python servers (http and websocket) and some notes 7 years ago
.github Pull request template: Fix link to Transifex project (#2534) 7 years ago
.tx Transifex config specific to electron, updated translations (#1478) 8 years ago
_locales More rebranding 7 years ago
app When iOS device has been linked, use iOS color scheme 7 years ago
build Bypass often-corrupt node_modules/.bin/grunt.cmd on windows (#1481) 8 years ago
components bower.json and Gruntfile.js cleanup 7 years ago
config config: change the default server from signal.org to localhost 7 years ago
fixtures Add style guide examples for portrait/landscape images 7 years ago
fonts Add fonts so we don't have to hit googlefonts 10 years ago
images Copy quoted message contents into quote on receipt 7 years ago
js fix encrypting message by returning fake localRegistrationID (not sure what it's for) 7 years ago
libtextsecure wip: added helper to create mock contacts, almost got a session working 7 years ago
mockup_servers add the python servers (http and websocket) and some notes 7 years ago
protos Protos: Add color field to GroupDetails 7 years ago
scripts Add `start-backup` script 7 years ago
stylesheets added identity key above the conversation box 7 years ago
test Use base64 strings for incoming message cache instead of binary 7 years ago
ts Conversations now better take advantage of wide screens 7 years ago
.aptly.conf Setup publishing to s3 8 years ago
.editorconfig Use 2 spaces for indentation 7 years ago
.eslintignore Eslintify all of libtextsecure 7 years ago
.eslintrc.js Use window.log in browser context, turn on console eslint rule 7 years ago
.gitignore Migrate to SQLCipher for messages/cache 7 years ago
.nvmrc Update to electron v2.0.1 (#2401) 7 years ago
.prettierignore Remove jshint - move everything over to eslint 7 years ago
.prettierrc.js Add `.prettierrc.js` 7 years ago
.travis.yml Update to electron v2.0.1 (#2401) 7 years ago
.yarnclean node-sqlcipher update: always build, statically link openssl 7 years ago
CONTRIBUTING.md Migrate to SQLCipher for messages/cache 7 years ago
Gruntfile.js Use window.log in browser context, turn on console eslint rule 7 years ago
LICENSE Add GPLv3 LICENSE file (#1309) 8 years ago
LOKI-NOTES.md add the python servers (http and websocket) and some notes 7 years ago
README.md Change Signal readme 7 years ago
about.html New media permission, show dialog when not enabled for voice msg 7 years ago
about_preload.js Remove jshint - move everything over to eslint 7 years ago
appveyor.yml Update to electron v2.0.1 (#2401) 7 years ago
aptly.sh aptly.sh: Fix broken switch commands - distro and config fix 7 years ago
background.html added identity key above the conversation box 7 years ago
bower.json bower.json and Gruntfile.js cleanup 7 years ago
debug_log.html New media permission, show dialog when not enabled for voice msg 7 years ago
debug_log_preload.js Update the user agent for debug log requests 7 years ago
dev-app-update.yml.sample Show dialog box when there's an update for download 8 years ago
find_broken_perms.sh Add two scripts to handle broken permissions in release dir 8 years ago
fix_broken_perms.sh Beta builds: A few updates required for successful release (#1739) 8 years ago
index.html App loading screen: show messages processed so far 8 years ago
main.js serialize message as base64 7 years ago
package.json Small rebranding 7 years ago
permissions_popup.html New media permission, show dialog when not enabled for voice msg 7 years ago
permissions_popup_preload.js Fix permissions popup; add needed function on window (#2554) 7 years ago
preload.js Add skeleton for Loki Message API. Wrap data in json (for now?) 7 years ago
prepare_beta_build.js Use window.log in browser context, turn on console eslint rule 7 years ago
prepare_import_build.js Use window.log in browser context, turn on console eslint rule 7 years ago
settings.html New option: Disable spell check 7 years ago
settings_preload.js Update the user agent for debug log requests 7 years ago
styleguide.config.js Finish new Message component, integrate into application 7 years ago
travis.sh Simplify testing and linting 7 years ago
tsconfig.json Adjust `tsconfig.json` formatting for Prettier 7 years ago
tslint.json Finish new Message component, integrate into application 7 years ago
yarn.lock Build libcrypto.a on Ubuntu 14.04 for maximum compatibility 7 years ago

README.md

Loki Messenger

Loki Messenger allows for truly decentralized and end to end and private encrypted chats, Loki Messenger is built to handle both online and fully Asynchronous offline messages , Loki messenger implements the Signal protocol for message encryption, Our Client interface is a fork of Signal Messenger. All communication that passes through Loki messenger is routed through Lokinet.

Summary

Loki messenger integrates directly with Loki Service Nodes, which are a set of distributed, decentralized and Sybil resistant nodes. Service Nodes act as both federated servers which store messages offline, and a set of nodes which allow for mixnet functionality obfuscating users IP Addresses. For a full understanding of how Loki messenger works, read the Loki whitepaper

Online Messages

If Alice and Bob are both online they can simply resolve each others public keys, to introduction sets, this functionality is handled by interfacing with Lokinet. With the appropriate introduction sets Alice and Bob can create a path and using onion routing pass messages through the Loki network without giving away personally identifiable information like their IP address.

Offline messages

Offline messaging uses Swarms, given any users public key the user can resolve a public key to a specific grouping of Service Nodes (AKA Swarm) each user in Loki Messenger belongs to a Swarm. When routing a message offline the user selects a Service node in the destination users Swarm, when the user comes online they query any node in their Swarm, if the Swarm is holding any messages for the user they disseminate those messages to the user.

Swarm Messaging

Spam protections for Loki Messenger are based on a Proof of Work which is attached to any message that exceeds a default size or Time To Live, this process is discussed further in the Loki whitepaper.

Want to Contribute? Found a Bug or Have a feature request?

Please search for any existing issues that describe your bugs in order to avoid duplicate submissions. Submissions can be made by making a pull request to our development branch, if you don't know where to start contributing , try reading the Github issues page for ideas.

License

Copyright 2018- Current, Loki Foundation Copyright 2014-2018, Open Whisper Systems Licensed under the GPLv3: http://www.gnu.org/licenses/gpl-3.0.html