* chore: create contributing guideline * chore: update pnpm spelling
5.3 KiB
(Draft) Contribute to Logto
Thanks for your interest in contributing to Logto. We respect the time of community contributors, so it'll be great if we can go through this guide which provides the necessary contribution information before starting your work.
Table of contents
Contribution Type
Bug fixes
We ensure Logto runs correctly with core unit tests, integration tests, and bug bash meetings. However, there's still a chance of missing or getting wrong on something.
If something doesn't work as expected, search in Issues to see if someone has reported the issue.
- If an issue already exists, comment to say you're willing to take it.
- If not, create one before continuing. It'll be great to let other people know you found it and will fix it.
Usually, we'll confirm the details in the issue thread, and you can work on the Pull Request in the meantime.
Warning
Do not report a security issue directly in the public GitHub Issues, since someone may take advantage of it before the fix. Send an email to security@logto.io instead.
Connectors
Connector is the standard way in Logto to connect third-party services like SMS, email, and social identity providers. See Connectors if you don't know the concept yet.
Before starting the work, join our Discord channel or email us to double-check if there's an ongoing project for your desired connector. We'll confirm with you your need and the status quo.
Since a new connector means a new Node.js package, we encourage you to separate your work into two Pull Requests:
- The initial setup of the connector package, including
package.json
, base dependencies and scripts (build, lint, etc.), and the connector class skeleton (a class extends the base class, but no implementation). - The full connector implementation with unit tests.
Core features
If you find some feature is related to customer identity and doesn't belong to a specific connector, then most likely, it's a core feature.
Since Logto is still in the early stage, it may already be in our roadmap. Until we have a publicly accessible place for the roadmap, join our Discord channel or email us to get the details.
The concept of feature varies by the situation, so we'll work with you to figure out the best way to contribute before starting.
Set up the dev environment
Prerequisites
We use the monorepo approach for development. Since pnpm supports monorepo naturally, it's the package manager for Logto.
You'll need these installed to proceed:
Clone and install dependencies
Clone the repo https://github.com/logto-io/logto in the way you like, then execute the command below in the project root:
pnpm i
It may take a while to install dependencies.
Set up environment variables (optional)
The root npm start
is optimized for public release, which carries the --from-root
parameter. In the dev environment, usually, we read .env
from the package location instead.
- If you already have a
.env
in the project root, move it intopackages/core/
before continuing. - If it's a fresh setup, no action is needed now. You can follow the command line questions afterward.
Start dev
Run the command below in the project root:
pnpm dev
The command will do several things in order:
- Compile
connectors
,schemas
, andphrases
. - Compile
core
,ui
,console
, anddemo-app
. - Watch the changes of the packages in step 2.
Note for a fresh setup
If you start dev with no .env
provided (a fresh setup), it'll have a great possibility that you'll miss the first question.
This is because parcel
uses ora
to show an in-line spinner which will overwrite the question, which asks if you'd like to generate a new cookie key.
Just press enter when you see the message like ✨ Built in 8.21s
to generate a new key by Logto.
Make changes
By default, Logto runs in http://localhost:3001
, which will redirect you to the Admin Console.
packages/console
holds the source code of Admin Console frontend (SPA). Start to make changes and see if the page reloads automatically.
I updated some code, but it doesn't work.
For now, pnpm dev
only watches four packages: core
, ui
, console
, and demo-app
. If you changed other packages like connectors or schemas, you must stop the dev command and run again.
Sorry for the inconvenience. We're working on a better dev command which watches all related packages.