Wiki.js [![License](https://img.shields.io/badge/license-AGPLv3-blue.svg?style=flat)](https://github.com/requarks/wiki/blob/master/LICENSE) [![Standard - JavaScript Style Guide](https://img.shields.io/badge/code%20style-standard-green.svg?style=flat&logo=javascript&logoColor=white)](http://standardjs.com/) [![GitHub Sponsors](https://img.shields.io/github/sponsors/ngpixel?logo=github&color=ea4aaa)](https://github.com/users/NGPixel/sponsorship) [![Open Collective backers and sponsors](https://img.shields.io/opencollective/all/wikijs?label=backers&color=218bff&logo=opencollective&logoColor=white)](https://opencollective.com/wikijs) [![Chat on Slack](https://img.shields.io/badge/slack-requarks-CC2B5E.svg?style=flat&logo=slack)](https://wiki.requarks.io/slack) [![Twitter Follow](https://img.shields.io/badge/follow-%40requarks-blue.svg?style=flat&logo=twitter)](https://twitter.com/requarks) [![Reddit](https://img.shields.io/badge/reddit-%2Fr%2Fwikijs-orange?logo=reddit&logoColor=white)](https://www.reddit.com/r/wikijs/) [![Subscribe to Newsletter](https://img.shields.io/badge/newsletter-subscribe-yellow.svg?style=flat&logo=mailchimp)](https://blog.js.wiki/subscribe) ##### Next Generation Open Source Wiki
- **[Official Website](https://next.js.wiki/)** - **[Documentation](https://next.js.wiki/docs/)** :red_square: :warning: :warning: :red_square: **THIS IS A VERY BUGGY, INCOMPLETE AND NON-SECURE DEVELOPMENT BRANCH!** **USE AT YOUR OWN RISK! THERE'S NO UPGRADE PATH FROM THIS BUILD AND NO SUPPORT IS PROVIDED!** :red_square: :warning: :warning: :red_square: The current stable release (2.x) is available at https://js.wiki --- - [Using VS Code Dev Environment](#using-vs-code-dev-environment) *(recommended)* - [Requirements](#requirements-1) - [Usage](#usage) - [Server Development](#server-development) - [Frontend Development (Quasar/Vue 3)](#frontend-development-quasarvue-3) - [pgAdmin](#pgadmin) - [Generic Setup](#generic-setup) - [Requirements](#requirements) - [Usage](#usage-1) ## Using VS Code Dev Environment ### Requirements - [VS Code](https://code.visualstudio.com/) - [Docker Desktop](https://www.docker.com/products/docker-desktop/) - **Windows-only:** [WSL 2](https://learn.microsoft.com/en-us/windows/wsl/install) + [WSL Integration](https://docs.docker.com/desktop/wsl/) enabled in Docker Desktop ### Usage 1. Clone the project. 1. Open the project in VS Code. 1. Make sure you have **Dev Containers** extension installed. (On Windows, you need the **WSL** VS Code extension as well.) 1. Reopen the project in container (from the popup in the lower-right corner of the screen when opening the project, or via the Command Palette (Ctrl+Shift+P *or* F1) afterwards). 1. Once in container mode, make a copy of `config.sample.yml` and rename it to `config.yml`. There's no need to edit the file, the default values are ok. 1. From the Command Palette, run the task "Create terminals": - Launch the Command Palette (Ctrl+Shift+P *or* F1) - Type `Run Task` and press Enter - Select the task "Create terminals" and press Enter 1. Two terminals will launch in split-screen mode at the bottom of the screen. **Server** on the left and **UX** on the right. 1. In the right-side terminal (UX), run the command: ```sh pnpm build ``` 1. In the left-side terminal (Server), run the command: ```sh pnpm start ``` 1. Open your browser to `http://localhost:3000` 1. Login using the default administrator user: - Email: `admin@example.com` - Password: `12345678` > **DO NOT** report bugs. This build is **VERY** buggy and **VERY** incomplete. Absolutely **NO** support is provided either. ### Server Development From the left-side terminal (Server), run the command: ```sh pnpm dev ``` This will launch the server and automatically restart upon modification of any server files. Only precompiled client assets are served in this mode. See the sections below on how to modify the frontend and run in SPA (Single Page Application) mode. ### Frontend Development > Make sure you are running `npm run dev` in the left-side terminal (Server) first! Requests still need to be forwarded to the server, even in SPA mode! If you wish to modify any frontend content (under `/ux`), you need to start the Quasar Dev Server in the right-side terminal (UX): ```sh pnpm dev ``` You can then access the site at `http://localhost:3001`. Notice the port being `3001` rather than `3000`. The app runs in a SPA (single-page application) mode and automatically hot-reload any modified component. Any requests made to the `/graphql` endpoint are automatically forwarded to the server running on port `3000`, which is why both must be running at the same time. Any change you make to the frontend will not be reflected on port 3000 until you run the command `yarn build` in the right-side terminal. ### pgAdmin A web version of pgAdmin (a PostgreSQL administration tool) is available at `http://localhost:8000`. Use the login `dev@js.wiki` / `123123` to login. The server **dev** should already be available under **Servers**. If that's not the case, add a new one with the following settings: - Hostname: `db` - Port: `5432` - Username: `postgres` - Password: `postgres` - Database: `postgres` ## Generic Setup ### Requirements - PostgreSQL **11** or later *(**16** or later recommended)* - Node.js **18.x** or later - [pnpm](https://pnpm.io/installation#using-corepack) ### Usage 1. Clone the project 1. Make a copy of `config.sample.yml` and rename it to `config.yml` 1. Edit `config.yml` and fill in the database details. **You need an empty PostgreSQL database.** 1. Run the following commands to install dependencies and generate the client assets: ```sh cd server pnpm install cd ../ux pnpm install pnpm build cd ../blocks pnpm install pnpm build cd .. ``` 1. Run this command to start the server: ```sh node server ``` 1. In your browser, navigate to `http://localhost:3000` *(or the IP/hostname of the server and the PORT you defined earlier.)* 1. Login using the default administrator user: - Email: `admin@example.com` - Password: `12345678` > **DO NOT** report bugs. This build is **VERY** buggy and **VERY** incomplete. Absolutely **NO** support is provided either.