{"id":38718125,"url":"https://github.com/aisa-it/aiplan","last_synced_at":"2026-01-17T11:05:17.910Z","repository":{"id":314058213,"uuid":"1051070599","full_name":"aisa-it/aiplan","owner":"aisa-it","description":"AIPlan is an open source project management system. Import your work from Jira, use AIDoc instead of Confluence. Create workspaces and invite partners to cooperate. Form teams and solve problems.","archived":false,"fork":false,"pushed_at":"2026-01-12T14:51:23.000Z","size":102077,"stargazers_count":61,"open_issues_count":4,"forks_count":1,"subscribers_count":1,"default_branch":"main","last_synced_at":"2026-01-12T17:44:34.048Z","etag":null,"topics":["aiplan","confluence","issue-tracker","jira","jira-import","project-managment"],"latest_commit_sha":null,"homepage":"https://plan.aisa.ru","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mpl-2.0","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/aisa-it.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null,"notice":null,"maintainers":null,"copyright":null,"agents":null,"dco":null,"cla":null}},"created_at":"2025-09-05T11:53:17.000Z","updated_at":"2025-12-21T18:45:34.000Z","dependencies_parsed_at":"2025-09-10T11:06:22.542Z","dependency_job_id":"f51bdff5-0205-4268-a793-131bebb82b8b","html_url":"https://github.com/aisa-it/aiplan","commit_stats":null,"previous_names":["aisa-it/aiplan"],"tags_count":113,"template":false,"template_full_name":null,"purl":"pkg:github/aisa-it/aiplan","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/aisa-it%2Faiplan","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/aisa-it%2Faiplan/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/aisa-it%2Faiplan/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/aisa-it%2Faiplan/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/aisa-it","download_url":"https://codeload.github.com/aisa-it/aiplan/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/aisa-it%2Faiplan/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":28506596,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-01-17T10:25:30.148Z","status":"ssl_error","status_checked_at":"2026-01-17T10:25:29.718Z","response_time":85,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["aiplan","confluence","issue-tracker","jira","jira-import","project-managment"],"created_at":"2026-01-17T11:05:17.827Z","updated_at":"2026-01-17T11:05:17.893Z","avatar_url":"https://github.com/aisa-it.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"[![License: MPL 2.0](https://img.shields.io/badge/License-MPL_2.0-brightgreen.svg)](https://opensource.org/licenses/MPL-2.0)\n[![en](https://img.shields.io/badge/README-en-green.svg)](https://github.com/aisa-it/aiplan/blob/main/README.md)\n[![ru](https://img.shields.io/badge/README-ru-green.svg)](https://github.com/aisa-it/aiplan/blob/main/README.ru.md)\n[![telegram](https://img.shields.io/badge/Telegram-2CA5E0?style=for-the-badge\u0026logo=telegram\u0026logoColor=white)](https://t.me/aiplan_faq)\n# AIPlan - An open-source project management system\nGet to know AIPlan, a professional project management platform that helps teams track tasks, make phone calls, maintain documentation, and produce a high—quality product.\nThe product provides convenient tools for planning, tracking, and completing tasks, as well as for teamwork within a team.\nThe system is designed for small, medium-sized teams and for large organizations that seek to optimize work processes, improve communication and increase productivity.\n\nYou can easily transfer your work from Jira, as the **AIPlan** implements simple and convenient **project import from Jira**. The built-in **AIDoc** documentation management system offers **an analog of Confluence** with a convenient editor and the ability to collaborate on documents.\n\nThe AIPLAN is constantly being improved. Your suggestions and bug reports help us to become better. Create support requests. https://t.me/aiplan_faq .\n\n## 🌟 Key features\n1. **Task Management**:\n   - Transfer all your tasks from Jira in a few clicks.\n   - Create tasks with deadlines, priorities, and responsible persons.\n   - The ability to link tasks to each other for more detailed planning.\n   - Assigning roles and access rights to project participants.\n   - Real-time task completion status tracking.\n2. **Working on documents**:\n   - The ability to create and store documents directly in the system.\n   - A convenient text editor for editing documents.\n   - Organize documents into folders and projects for easy access.\n3. **Forms**:\n   - Create forms to collect feedback or data.\n   - Generation of unique links to forms that can be sent to users (both within the team and to external participants).\n   - Automatic saving of the received data in the system.\n4. **Calendar**:\n   - An interactive calendar for viewing all tasks and activities by day, week or month.\n   - The ability to filter tasks by responsible persons, projects or statuses.\n5. **Video Calls and Conferences**:\n   - Built-in video calling tool directly in the system.\n   - The ability to organize meetings with team members without the need to use third-party applications.\n   - Screen interaction support: screen demonstration during calls.\n   - Record meetings for later viewing or analysis.\n6. **Integration**:\n   - The ability to export data in formats .docx, .pdf.\n   - The ability to import data from Jira.\n7. **Reports and analytics**:\n   - Tracking user activity on projects.\n8. **Notifications and Reminders**:\n   - Customizable notifications about new tasks and any changes to them.\n   - Support for notifications via email, Telegram and within the system.\n\n## 📝 Documentation\nIf you have any questions and for a detailed study of the product's capabilities, you can always refer to the User's Manual, which you will find inside the product.\n\n## How to install\nThe configuration is done by .env file.\n```\ndocker-compose up -d\n```\n- The application will be available at http://localhost:8080\n- Default user (superuser) email: `DEFAULT_EMAIL`; password: `password123`\n\n## Application Parameters\n\n| Parameter                     | Description                                                                | Type   |\n|-------------------------------|----------------------------------------------------------------------------| ------ |\n| `SECRET_KEY`                  | The key for generating JWT tokens.                                         | string |\n| `AWS_REGION`                  | Minio region                                                               | string |\n| `AWS_ACCESS_KEY_ID`           | minio login                                                                | string |\n| `AWS_SECRET_ACCESS_KEY`       | minio password                                                             | string |\n| `AWS_S3_ENDPOINT_URL`         | Path to minio                                                              | string |\n| `AWS_S3_BUCKET_NAME`          | Name of the minio bucket                                                   | string |\n| `DATABASE_URL`                | DSN of the database                                                        | string |\n| `DEFAULT_EMAIL`               | Email of the standard user (password `password123` at creation)            | string |\n| `EMAIL_ACTIVITY_DISABLED`     | Disabling sending notifications to                                         | bool   |\n| `EMAIL_HOST`                  | Path to the mail server                                                    | string |\n| `EMAIL_HOST_USER`             | Mail server login                                                          | string |\n| `EMAIL_HOST_PASSWORD`         | Mail server password                                                       | string |\n| `EMAIL_PORT`                  | Mail server port                                                           | int    |\n| `EMAIL_FROM`                  | Mailing list email                                                         | string |\n| `EMAIL_WORKERS`               | Number of parallel mail notification handlers of the application           | int    |\n| `WEB_URL`                     | External address of the application                                        | string |\n| `JITSI_DISABLED`              | Disabling jitsi                                                            | bool   |\n| `JITSI_URL`                   | Address of the jitsi conferences                                           | string |\n| `JITSI_JWT_SECRET`            | Secret key for jitsi auth JWT token                                        | string |\n| `JITSI_APP_ID`                | Jitsi app ID for JWT iss field                                             | string |\n| `FRONT_PATH`                  | The path to the compiled front (if specified, the back will return static) | string |\n| `NOTIFICATIONS_PERIOD`        | Time period of a batch of email notifications                              | int    |\n| `TELEGRAM_BOT_TOKEN`          | Telegram bot token                                                         | string |\n| `TELEGRAM_COMMANDS_DISABLED`  | Disabling telegram bot commands                                            | bool   |\n| `SESSIONS_DB_PATH`            | Path to the session database file                                          | string |\n| `SIGN_UP_ENABLE`              | Enabling registration in the                                               | bool   |\n| `DEMO`                        | Demo mode                                                                  | bool   |\n| `SWAGGER`             | Enabling the Swagger API documentation at /api/swagger                     | bool   |\n| `NY_ENABLE`                   | Enabling the New Year theme                                                | bool   |\n| `CAPTCHA_DISABLED`            | Disabling captcha                                                          | bool   |\n| `LDAP_URL`                    | LDAP server URL for authentication                                         | string |\n| `LDAP_BASE_DN`                | Base DN for LDAP search                                                    | string |\n| `LDAP_BIND_DN`                | Bind DN for LDAP authentication                                            | string |\n| `LDAP_BIND_PASSWORD`          | Bind password for LDAP authentication                                      | string |\n| `LDAP_FILTER`                 | LDAP filter for user search (default: `(\u0026(uniqueIdentifier={email}))`)     | string |\n\n### nginx SSL example\n```\nserver {\n    listen 80;\n    server_name aiplan.domain;\n    return 301 https://$host$request_uri;\n}\n\nserver {\n    listen 443 ssl;\n    server_name aiplan.domain;\n\n    ssl_certificate     /etc/ssl/certs/fullchain.pem;\n    ssl_certificate_key /etc/ssl/private/privkey.pem;\n\n\n    client_max_body_size 50M;\n\n    location / {\n        # we proxy directly to the container if it was launched in the same docker-compose with the same network, otherwise we change to the container IP/machine IP/localhost\n        proxy_pass http://server:8080;\n        proxy_http_version 1.1;\n\n        proxy_set_header Host $host;\n        proxy_set_header X-Real-IP $remote_addr;\n        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;\n        proxy_set_header X-Forwarded-Proto $scheme;\n\n        # WebSocket\n        proxy_set_header Upgrade $http_upgrade;\n        proxy_set_header Connection \"upgrade\";\n    }\n}\n```\n\n## Development:\n\n```\ndocker compose -f docker-compose.yaml -f docker-compose.dev.yaml up --build\n```\n\nor shorthand:\n\n```\ndocker compose -f docker-compose.{yaml,dev.yaml} up --build\n```\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Faisa-it%2Faiplan","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Faisa-it%2Faiplan","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Faisa-it%2Faiplan/lists"}