Huly — All-in-One Project Management Platform (alternative to Linear, Jira, Slack, Notion, Motion)
Go to file
Alexander Platov 1fceb1822a
Some checks are pending
CI / formatting (push) Blocked by required conditions
CI / test (push) Blocked by required conditions
CI / uitest (push) Waiting to run
CI / build (push) Waiting to run
CI / svelte-check (push) Blocked by required conditions
CI / uitest-pg (push) Waiting to run
CI / uitest-qms (push) Waiting to run
CI / docker-build (push) Blocked by required conditions
CI / dist-build (push) Blocked by required conditions
Changed the file type to save for Cropper (#7738)
2025-01-21 07:34:29 +07:00
.github Revert missing login to docker hub 2025-01-13 19:28:29 +07:00
.vscode Switch to Base images (#7654) 2025-01-14 12:12:15 +07:00
common UBERF-9158: Use parameters in SQL queries (#7690) 2025-01-17 15:23:13 +05:00
desktop Fix desktop BackupURL (#7701) 2025-01-17 21:49:43 +07:00
desktop-package Desktop icon update (#7637) 2025-01-15 11:03:35 +07:00
dev tool: add qms ranks (#7713) 2025-01-20 18:08:31 +07:00
models EZQMS-1234: means for transferring controlled documents between spaces (#7691) 2025-01-17 13:17:07 +03:00
packages Do not send unavailable notifications (#7737) 2025-01-21 00:38:36 +07:00
plugins Changed the file type to save for Cropper (#7738) 2025-01-21 07:34:29 +07:00
pods UBERF-9172: Fix $lookup order by (#7714) 2025-01-20 16:28:23 +07:00
qms-tests EZQMS-1317: authors signature on review and approval request & block review bypass (#7631) 2025-01-13 15:19:47 +04:00
scripts
server UBERF-9172: Fix $lookup order by (#7714) 2025-01-20 16:28:23 +07:00
server-plugins Do not send unavailable notifications (#7737) 2025-01-21 00:38:36 +07:00
services QFIX: PG query and SES (#7700) 2025-01-17 20:13:04 +07:00
templates UBERF-9158: Use parameters in SQL queries (#7690) 2025-01-17 15:23:13 +05:00
tests PresenceAvatars fixed limit for mobile (#7677) 2025-01-16 08:36:35 +07:00
workers UBERF-9172: Fix $lookup order by (#7714) 2025-01-20 16:28:23 +07:00
.gitattributes
.gitignore UBERF-8993: Part2 (#7532) 2024-12-24 17:39:51 +07:00
.npmrc fix: adjust bump script (#7121) 2024-11-07 22:08:02 +07:00
.nvmrc Switch to Base images (#7654) 2025-01-14 12:12:15 +07:00
.prettierrc
changelog.md update change log 2024-12-09 14:03:41 +07:00
cliff.toml Update changelog with proper refs 2024-08-20 23:44:07 +07:00
LICENSE
package-lock.json UBERF-8520: Test management (#7154) 2024-11-13 13:59:32 +07:00
README.md Update QMS docker-compose.yaml so it can view and download PDF files (#6507) 2024-09-11 21:21:29 +04:00
rush.json Switch to Base images (#7654) 2025-01-14 12:12:15 +07:00

Huly Platform

X (formerly Twitter) Follow GitHub License

Your star shines on us. Star us on GitHub!

About

The Huly Platform is a robust framework designed to accelerate the development of business applications, such as CRM systems. This repository includes several applications, such as Chat, Project Management, CRM, HRM, and ATS. Various teams are building products on top of the Platform, including Huly and TraceX.

Huly

Self-Hosting

If you're primarily interested in self-hosting Huly without the intention to modify or contribute to its development, please use huly-selfhost. This project offers a convenient method to host Huly using docker, designed for ease of use and quick setup. Explore this option to effortlessly enjoy Huly on your own server.

Activity

Alt

Table of Content

Pre-requisites

Verification

To verify the installation, perform the following checks in your terminal:

  • Ensure that the docker commands are available:
    docker --version
    docker compose version
    

Fast start

sh ./scripts/fast-start.sh

Installation

You need Microsoft's rush to install application.

  1. Install Rush globally using the command:
    npm install -g @microsoft/rush
    
  2. Navigate to the repository root and run the following commands:
    rush install
    rush build
    

Alternatively, you can just execute:

sh ./scripts/presetup-rush.sh

Build and run

Development environment setup requires Docker to be installed on system.

Support is available for both amd64 and arm64 containers on Linux and macOS.

cd ./dev/
rush build    # Will build all the required packages. 
# rush rebuild  # could be used to omit build cache.
rush bundle   # Will prepare bundles.
rush package  # Will build all webpack packages.
rush validate # Will validate all sources with typescript and generate d.ts files required for ts-node execution.
rush svelte-check # Optional. svelte files validation using svelte-check.
rush docker:build   # Will build Docker containers for all applications in the local Docker environment.
rush docker:up # Will set up all the containers

Be aware rush docker:build will automatically execute all required phases like build, bundle, package.

Alternatively, you can just execute:

sh ./scripts/build.sh

By default, Docker volumes named dev_db, dev_elastic, and dev_files will be created for the MongoDB, Elasticsearch, and MinIO instances.

Before you can begin, you need to create a workspace and an account and associate it with the workspace.

cd ./tool # dev/tool in the repository root
rushx run-local create-workspace ws1 -w DevWorkspace # Create workspace
rushx run-local create-account user1 -p 1234 -f John -l Appleseed # Create account
rushx run-local configure ws1 --list --enable '*' # Enable all modules, even if they are not yet intended to be used by a wide audience.
rushx run-local assign-workspace user1 ws1 # Assign workspace to user.
rushx run-local confirm-email user1 # To allow the creation of additional test workspaces.

Alternatively, you can just execute:

sh ./scripts/create-workspace.sh

Add the following line to your /etc/hosts file

127.0.0.1 host.docker.internal

Accessing the URL http://host.docker.internal:8087 will lead you to the app in development mode.

Limitations:

  • Local installation does not support sending emails, thus disabling functionalities such as password recovery and email notifications.

Run in development mode

Development mode allows for live reloading and a smoother development process.

cd dev/prod
rush validate
rushx dev-server

Then go to http://localhost:8080

Click on "Login with password" link on the bottom of the right panel and use the following login credentials:

Email: user1
Password: 1234
Workspace: ws1

Update project structure and database

If the project's structure is updated, it may be necessary to relink and rebuild the projects.

rush update
rush build

It may also be necessary to upgrade the running database.

cd ./dev/tool
rushx upgrade -f

Troubleshooting

If a build fails, but the code is correct, try to delete the build cache and retry.

# from the project root
rm -rf common/temp/build-cache

Build & Watch

For development purpose rush build:watch action could be used.

It includes build and validate phases in watch mode.

Tests

Unit tests

rush test # To execute all tests

rushx test # For individual test execution inside a package directory

UI tests

cd ./tests
rush build
rush bundle
rush docker:build
## creates test Docker containers and sets up test database
./prepare.sh
## runs UI tests
rushx uitest

To execute tests in the development environment, please follow these steps:

cd ./tests
./create-local.sh ## use ./restore-local.sh if you only want to restore the workspace to a predefined initial state for sanity.
cd ./sanity
rushx dev-uitest # To execute all tests against the development environment.
rushx dev-debug -g 'pattern' # To execute tests in debug mode with only the matching test pattern.

Package publishing

node ./common/scripts/bump.js -p projectName

Additional testing

This project is tested with BrowserStack.

© 2024 Hardcore Engineering Inc.