Atlas CMMS is a powerful, self-hosted maintenance management system designed for both web and mobile platforms using Docker. It simplifies and automates the management of maintenance activities, making it ideal for IT managers or developers looking to implement solutions that keep their organization's assets running smoothly. Think of it like Jira for technicians.
Example industries
- Facilities Managers (buildings, property, real estate)
- Manufacturing/Production Teams (machinery and equipment)
- Healthcare Facilities (medical equipment maintenance)
- Hospitality Managers (hotels and resorts)
- Public Sector (infrastructure and public buildings)
- Educational Institutions (campus maintenance)
- Utility Companies (power, water, and energy systems)
Demo website
Screenshots:
- π Create, assign, and track work orders.
- β±οΈ Log time, set priorities, and track history.
- π€ Automate work orders with triggers.
- π Export reports and view analytics.
- πΌ Work order compliance and cost analysis.
- π οΈ Equipment downtime and reliability insights.
- π΅ Cost trends and labor tracking.
- βοΈ Track equipment, downtime, and maintenance costs.
- π¦ Manage inventory with stock alerts.
- π Automate purchase orders and approvals.
- π₯ Assign tasks to teams or service providers.
- π§βπΌ Customizable user roles and permissions.
- π Define workflows with automation logic.
- π Manage locations with Google Maps integration.
- π Create and track service requests.
You can check out the complete list of features.
We'd love to have new contributors, so feel free to join us!
β Star this repo to support us!
git clone https://github.com/grashjs/cmms.git
cd cmms
Configure the environment variables in this file .env At the moment all variables are optional. Do not delete the .env file
Name | Required | Description | Default Value |
---|---|---|---|
SMTP_PWD | No | The SMTP password after creating an app password with Google. Learn how to create an app password. To be able to invite people you have to configure it. | (empty) |
SMTP_USER | No | The SMTP username after creating an app password with Google. Learn how to create an app password | (empty) |
JWT_SECRET_KEY | No | JWT secret key | your_jwt_secret |
REACT_APP_GOOGLE_KEY | No | Google Maps API key | (empty) |
REACT_APP_GOOGLE_TRACKING_ID | No | Google Analytics tracking ID | (empty) |
PUBLIC_FRONT_URL | No | Frontend URL in this format http://your.public.ip:3000 |
http://localhost:3000 |
PUBLIC_API_URL | No | Public API URL in this format http://your.public.ip:8080 |
http://localhost:8080 |
STORAGE_TYPE | No | Type of storage either local MinIO or Google Cloud Storage gcp or minio |
minio |
PUBLIC_MINIO_ENDPOINT | No | Public Mini endpoint in format http://public.ip:9000 |
http://localhost:9000 |
GCP_JSON | No | The Google Cloud JSON key after following these instructions. | (empty) |
GCP_PROJECT_ID | No | The Google Cloud project ID, also found in the GCP_JSON file. |
(empty) |
GCP_BUCKET_NAME | No | GCP Bucket Name | (empty) |
MAIL_RECIPIENTS | No | Comma-separated email addresses of the super admins where to send information emails like new signups. You can provide your email address. | (empty) |
REACT_APP_MUI_X_LICENSE | No | Mui Pro license key | (empty) |
After changing any env variable starting with REACT_APP_
or PUBLIC_API_URL
you should run docker compose up -d --no-deps --build frontend
- You need to update every env variable starting with
PUBLIC_
. - You must also update every env variable starting with
SMTP
. - Open ports if necessary: make sure to open
REACT_APP_API_URL
,PUBLIC_FRONT_URL
ports numbers by default 8080, and 3000. Same forPUBLIC_MINIO_ENDPOINT
port 9000 if you use Minio.
docker-compose up -d
Now, go to http://localhost:3000 or your custom PUBLIC_FRONT_URL
Celebrate on how easy this was
If you still have questions after reading the docs, concerns, bug reports, etc, please file an issue in this repository's Issue Tracker or send an email at ibracool99@gmail.com.
- English
- Spanish
- French
- Turkish
- Portuguese (Brazil)
Don't want to handle the maintenance and management yourself? We offer a complete done-for-you service. Please reach out to us
We welcome contributions! You can help by:
- β Reporting bugs
- β Suggesting new features
- β Improving documentation
- β Submitting pull requests
Check CONTRIBUTING.md inside each subproject for details.
You can also join our Discord server