Skip to content

Latest commit

 

History

History
297 lines (221 loc) · 9.51 KB

CONTRIBUTING.md

File metadata and controls

297 lines (221 loc) · 9.51 KB

Contributing

Personal Note

The code is kind of a mess right now but is cleaned little by little in preparation for the v0.4.0.

Even though I'm 20y+ experienced in development, I'm a beginner in Rust and in "low level" languages. Once the code will start to stabilize (starting from v0.4.0 release), I'll be happy to welcome any experienced Rust developer who wished to contribute with better patterns, dryer code and some optimizations.

I'll also be happy to welcome any contributor/ion in general! I know I won't be able to handle everything alone on my free time. Just be prepared, I am nit-picky regarding the harmony of naming, structures and conventions (from code to commit messages) despite the current state of the codebase. But I'm trying to take it easier!

Also, at some point in the future, I do hope to find a good UX/UI designer willing to contribute because I think opensource can look fancy (yes it matters for non-power users!) while being accessible to the largest number possible. And let's say the my truth, most opensource softwares are not really appealing in terms of both UX & UI (which doesn't make these projects and their contributors any less amazing, it's just a personal take on this matter).

As a final note, you'll notice that you have to install ClamAV binaries separately before being able to use ClamAV Desktop. I talked with one core ClamAV contributors (a year ago) and we may hopefully work together at some point, so that they can help us build and embed the binaries to make end-users life easier with an almost-single-click installation.

Getting started

Mandatory Requirements

Optional Requirements

  • cargo-deb for debian bundle packaging.
  • cargo-edit. for cargo upgrade-related commands (i.e.: make upgrade)
  • cargo-watch for cargo watch-related commands (i.e.: make test-*-watch).
  • ggshield for yarn test:sec command.

Debian-based OS

  • nsis:
    sudo apt-get install nsis

First setup

Important

If you're under Windows, you nust run all CLI commands under a Linux shell-like terminal (i.e.: WSL or Git Bash).

1. Git (with submodules)

Then run:

git clone https://github.com/ivangabriele/clamav-desktop.git # or your fork
cd ./clamav-desktop

2. Webview

yarn

3. Core

You will to not only have to build ClamAV Desktop itself but also ClamAV binaries as well as the ClamAV Desktop Daemon.

I tried to simplify all these processes with automated command that will hopefully work as is:

  • Debian:
    • Setup automated ClamAV binaries build: sudo make setup-debian
    • Uninstall if exists, build, install and start ClamAV Desktop Daemon service: yarn dev:daemon:linux
  • macOS:
    • Setup automated ClamAV binaries build: sudo make setup-macos
    • Uninstall if exists, build, install and start ClamAV Desktop Daemon service: yarn dev:daemon:macos
  • Windows:
    • No need to setup ClamAV binaries build on Windows for now since their official standalone bundles are directly downloaded from their Github repository.
    • Uninstall if exists, build, install and start ClamAV Desktop Daemon service: yarn dev:daemon:windows

Once you're ready, you can copy the custom Core dev config file:

cp ./src-tauri/.cargo/config.toml.example ./src-tauri/.cargo/config.toml

and customize the content to match your local environment.

Tip

If you want to check that your Core builds separately from the webview, you can just run cd ./src-tauri && cargo build.

4. Run Check

You should now be able to run yarn dev which will launch the application (serving first the Webview on port 1420 and then launching the Core desktop app embedding this Webview).

5. Core & E2E Testing

First check and install the requirements related to WebDriver:

Once you're ready, you can check core & e2e tests by running:

yarn test:unit:core # or `make test`
yarn test:e2e

Local development

This will watch for file changes and automatically re-hydrate the webapp on the go:

yarn dev:daemon:[linux|macos|windows] # if updated
yarn dev

Build a release

Keep in mind that building a release on your OS generally restrict the release generation to your OS (you can't natively release a macOS .dmg under Ubuntu for example) but you can circumvent that by using VirtualBox (Docker is a hassle to embed macOS & Windows environments).

Binary (standalone)

yarn bundle:bin

Debian-based OS (deb)

yarn bundle:deb

macOS (dmg)

yarn bundle:dmg

Windows 10+ (msi)

yarn bundle:msi:arch64
yarn bundle:msi:x32
yarn bundle:msi:x64

Tests

Core unit tests

yarn test:unit:core

Webview unit tests

yarn test:unit:webview

E2E tests

yarn bundle:bin
yarn test:e2e

Style Guide & Conventions

Tests

For Rust unit tests, to avoid overwhelming main files with tests code, we follow Google's C++ Style Guide and split unit test files into a separate filename_test.rs.

The idea comes from this Karol Kuczmarski's blog post.

Commit messages

Conventional Commit Types

Commit messages must follow Conventional Commits with this types:

  • build: Anything related to application run or build (build configs, dev configs, scripts, dependencies, etc).
  • ci: Anything related to continuous integration, including locally (Github Actions, husky, Git, etc).
  • docs: Anything related to documentation (readme, contributing, website).
  • feat: Any feature addition, edition or removal.
  • fix: Anything related to documentation (readme, contributing, website).
  • perf: Any application performance-related change.
  • refactor: Any change in the structure/codebase that doesn't add or change a feature.
  • style Any application UI-releated change (components, styles, assets, etc).
  • test: Any unit or integration tests change.

feat, fix, perf, refactor, style & test types only concerns fixes related to the application istself, as defined by the scopes below.

For everything else (i.e.: a CI fix, a performance improvement for a script, etc), use either build, ci or docs, depending on the context.

You have to keep in mind that feat, fix, perf and style will end up in the end-users changelog while other will not. It's there to help them understand what changed since the last version when a new release is published.

Conventional Commit Scopes

Our official feat, fix, perf, refactor, style & test scopes are:

  • cloud: Any change impacting the Cloud screen.
  • dashboard: Any change impacting the Dashboard screen.
  • daemon: Any change impacting the Dashboard screen.
  • scanner: Any change impacting the Scanner screen.
  • settings: Any change impacting the Settings screen.

IDEs Configuration

Visual Studio Code

.vscode/extensions.json

{
  "recommendations": [
    "biomejs.biome",
    "coolbear.systemd-unit-file",
    "fill-labs.dependi",
    "editorconfig.editorconfig",
    "esbenp.prettier-vscode",
    "idleberg.nsis",
    "rust-lang.rust-analyzer",
    "tamasfe.even-better-toml",
    "tauri-apps.tauri-vscode"
  ]
}

.vscode/settings.json

{
  "editor.defaultFormatter": "biomejs.biome",
  "[javascript]": {
    "editor.defaultFormatter": "biomejs.biome"
  },
  "[javascriptreact]": {
    "editor.defaultFormatter": "biomejs.biome"
  },
  "[json]": {
    "editor.defaultFormatter": "esbenp.prettier-vscode"
  },
  "[typescript]": {
    "editor.defaultFormatter": "biomejs.biome"
  },
  "[typescriptreact]": {
    "editor.defaultFormatter": "biomejs.biome"
  }
}