Hugin is a messaging service where messages are relayed by Kryptokrona nodes. Your messages are secured with industry leading encryption so that only you and your chat partner have the possibility to read them. The purpose is not to gather any personal information about the users, unlike most apps and social media.
Hugin also packs some powerful decentralized P2P encrypted features like video, voice, screen sharing and filesharing. This is possible because we've managed to compress the requests to establish a connection (called SDP) with WebRTC from over 2000 characters to less than 200 – which means that a connection through Hugin is possible!
- Table of Contents
- Development Resources
- Technologies
- Getting Started
- CI/CD
- Contribute
- Contributors
- License
- Web: https://hugin.chat
- GitHub: https://github.com/kryptokrona
- Hugin: hugin group on
20b4821b90b2ea7355cb7ed7fa60823016eedef0e3541376888f8adc55df75f8
- It is HIGHLY recommended to join our group on Hugin Messenger if you want to contribute to stay up to date on what is happening on the project.
- Node 16 (16.16.0 currently)
- Electron
- Svelte
- WebRTC
- Hypercore Protocol
*Feel free to substitute
npm
withpnpm
oryarn
.
Install | · npm install |
Develop | · npm run dev |
To build a target we have the following options:
macOS Apple Silicon (M1) | · npm run build:mac-arm64 |
macOS Intel (x64) | · npm run build:mac-x64 |
Windows | · npm run build |
Linux | · npm run build:linux-x64 |
This project is automatically built, tested and deployed using GitHub Actions. We have two pipelines:
- Main Pipeline - This is the pipeline that runs the code merged into our main branch.
- Pull Request Pipeline - This is the pipeline that runs each time a pull request come in so the reviewer has some help evaluating if the code is good enough to be merged.
The Main Pipeline do everything the Pull Request Pipeline does in addition to building and publishing artifacts of different architectures and OS.
We appreciate all contributions whether it be small changes such as documentation of source code to major improvement of code. The easiest way is to make a fork and then make a pull request into our main branch. To make the PR go through make sure to include this information:
What does this PR do?
Why are these changes required?
This PR has been tested using (e.g. Unit Tests, Manual Testing):
Extra details?
A pull request is approved if the GitHub Actions pipeline is marked green. Otherwise it will be closed directly. Always make sure to run the unit tests before creating a pull request.
The following contributors have either helped to start this project, have contributed code, are actively maintaining it (including documentation), or in other ways being awesome contributors to this project. We'd like to take a moment to recognize them.
The license is GPL-3.0 License.