Skip to content

feat: add env editor diff gutter indicators#4492

Open
mhbdev wants to merge 22 commits into
Dokploy:canaryfrom
mhbdev:enhance-env-editor
Open

feat: add env editor diff gutter indicators#4492
mhbdev wants to merge 22 commits into
Dokploy:canaryfrom
mhbdev:enhance-env-editor

Conversation

@mhbdev
Copy link
Copy Markdown
Contributor

@mhbdev mhbdev commented May 26, 2026

Summary

This PR adds line-level gutter indicators to env editors so unsaved changes are easier to spot and scan.
It introduces a reusable diff-gutter capability in the shared editor and enables it across Environment-related screens.

What changed

  • Added reusable diff gutter support to shared CodeEditor:
    • showDiffGutter
    • diffOriginalValue
  • Added visual gutter markers for:
    • added lines
    • modified lines
    • removed lines
  • Enabled indicators in env editing flows:
    • Environment Variables modal
    • Project Environment modal
    • Service Environment editor
    • Traefik env editor
    • Secrets-based env sections (including preview settings)
  • Added global styles for marker visibility in light/dark themes.
  • Fixed noisy behavior by not marking blank spacer lines and by anchoring removal markers to nearest non-blank lines.

Why

Env editors can become hard to review quickly, especially with multiline values and spacing.
These indicators make diffs and unsaved edits immediately observable without changing existing save behavior.

UX impact

  • Clear line-level change hints in the gutter.
  • Less false/noisy markers from blank lines.
  • Better confidence when reviewing env changes before save.

Validation

  • Typecheck passed (pnpm --filter dokploy typecheck).
  • Manual verification on local dev server for env editors.

Notes

  • No API/schema changes.
  • No behavior change to save/update mutations; this is UI observability only.

Related issues

fixes and closes #4491

ngenohkevin and others added 22 commits May 12, 2026 21:35
The empty-records branch of `main()` returned without calling
`process.exit(0)`, leaving the Drizzle Postgres connection pool
holding the event loop open. The `migrate-auth-secret` process
then hangs indefinitely after printing "No 2FA records found,
nothing to migrate." causing the upstream `0.29.3.sh` security
migration script (which calls this via `docker exec`) to never
reach its final `docker service update` step that mounts the new
Docker Secret. Operators end up with the new secret created but
the dokploy service still configured with the hardcoded
`BETTER_AUTH_SECRET`, while believing the migration completed.

Match the success branch a few lines below which already does
`process.exit(0)`, and the pattern used in sibling scripts
`reset-password.ts` and `reset-2fa.ts`.

Closes Dokploy#4392
…ret-exit-on-empty

fix(migrate-auth-secret): exit cleanly when there are no 2FA records
Adds an "Import" option to the Create Service dropdown that lets users
paste a base64-encoded compose export, preview the template (compose YAML,
domains, envs, mounts) before confirming, and create the service only on
confirm. Adds a `previewTemplate` tRPC procedure that processes the base64
without touching the DB, with server access validation via session.
…-base64

feat(compose): add import from base64 in create service dropdown
- Updated the GitHub Actions workflow to sync versioning across MCP, CLI, and SDK repositories.
- Added steps to bump the version in the SDK repository and regenerate tools from the latest OpenAPI spec.
- Improved commit message formatting to include source and release information for all repositories.
- Ensured successful synchronization messages for each repository after the version update.
- Introduced a new `readLogs` procedure that allows users to retrieve logs for a specific deployment by providing the deployment ID and an optional tail parameter.
- Implemented permission checks to ensure users have access to the requested logs.
- Enhanced log retrieval for both cloud and non-cloud environments, utilizing appropriate commands based on the server context.

Resolve Dokploy/mcp#14
- Implemented server access validation in deployment procedures to ensure users can only access deployments associated with their active organization.
- Added checks to throw an UNAUTHORIZED error if a user attempts to access a deployment linked to a server outside their organization.

This enhancement improves security and access control within the deployment management system.
- Added validation to prevent users from being invited with the owner role in the organization and user routers.
- Implemented TRPCError responses to ensure proper error handling when attempting to assign the owner role.
This change enhances role management and security within the organization structure.

https://github.com/Dokploy/dokploy/security/advisories/GHSA-fm9p-wmpw-gxjh
- Added functionality to delete old sessions when a user updates their password, ensuring that only the current session remains active.
- This change enhances security by preventing unauthorized access from previous sessions after a password change.

Close here https://github.com/Dokploy/dokploy/security/advisories/GHSA-rr9m-w87g-46f3
* fix: copy Dokploy server IP when clicking server badge

When a service runs on the local Dokploy server (no remote server),
clicking the server badge did nothing because `data.server` is null.
Now falls back to the server IP from settings so the badge always
copies an IP address.

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>

* feat(copy-ip): implement IP address copying functionality across database service components

- Added the ability to copy the server IP address to the clipboard when clicking the server badge in various database service components (Libsql, MariaDB, MongoDB, MySQL, PostgreSQL, Redis).
- Integrated the `copy-to-clipboard` library and `sonner` for user feedback upon successful copy action.
- Ensured fallback to the server IP from settings when the service data is not available, enhancing user experience and functionality.

---------

Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
Co-authored-by: Mauricio Siu <siumauricio@icloud.com>
Signed-off-by: Nahidujjaman Hridoy <hridoyboss12@gmail.com>
… routes (Dokploy#4468)

* fix: allow square brackets in zip drop path validation for Next.js dynamic routes

ZIP uploads containing Next.js dynamic route files (e.g. app/api/[id]/route.ts,
pages/[slug].tsx) were rejected by readValidDirectory because the path regex
did not include square bracket characters.

* [autofix.ci] apply automated fixes

---------

Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com>
…es (Dokploy#4470)

shouldDeploy passed undefined/null entries from commit.modified straight
into micromatch, which throws "Expected input to be a string" and fails
every webhook deployment when watch paths are configured. Filter out
non-string values before matching.
…t accidental submission (Dokploy#4422)

Co-authored-by: Maks Pikov <mixelburg@users.noreply.github.com>
…ploy#4018) (Dokploy#4474)

* fix: add tls=true label for compose domains when certificateType is none (Dokploy#4018)

* test: cover tls=true label for certificateType none, require https

* fix: scope tls fix to compose labels, leave traefik file config unchanged (Dokploy#4018)
Upgraded next dependency in apps/dokploy to 16.2.6 exactly. Verified typescript typecheck passes successfully.
- add reusable CodeMirror diff gutter support in shared `CodeEditor`
  via `showDiffGutter` + `diffOriginalValue`
- render visual line markers for added/modified/removed lines
- enable indicators in environment editors:
  - environment-level vars
  - project-level vars
  - service env editors
  - Traefik env editor
  - shared `Secrets`-based env inputs
- style gutter markers for light/dark themes
- reduce noise by ignoring blank spacer lines in marker placement
  and anchoring removals to nearest non-blank line

This improves visibility of unsaved env edits and line-level diffs
across Environment-related tabs.
@mhbdev mhbdev requested a review from Siumauricio as a code owner May 26, 2026 14:45
@dosubot dosubot Bot added size:L This PR changes 100-499 lines, ignoring generated files. enhancement New feature or request labels May 26, 2026
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

enhancement New feature or request size:L This PR changes 100-499 lines, ignoring generated files.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Add gutter indicators to env var and code editors

8 participants