2
0
Files
gitcaddy-server/templates/shared/secrets/add_list.tmpl
logikonline e89647bfab
Some checks failed
Build and Release / Create Release (push) Successful in 0s
Build and Release / Integration Tests (PostgreSQL) (push) Successful in 2m44s
Build and Release / Unit Tests (push) Successful in 5m1s
Build and Release / Lint (push) Successful in 5m8s
Build and Release / Build Binaries (amd64, linux, linux-latest) (push) Successful in 3m12s
Build and Release / Build Binaries (amd64, windows, windows-latest) (push) Successful in 8h5m40s
Build and Release / Build Binaries (amd64, darwin, macos) (push) Successful in 7m6s
Build and Release / Build Binaries (arm64, darwin, macos) (push) Successful in 7m21s
Build and Release / Build Binary (linux/arm64) (push) Failing after 12m35s
feat(secrets): show org secrets in repo settings as read-only
Displays organization-level secrets in repository settings as read-only when the repo belongs to an organization. Helps users understand which secrets are inherited from the org scope without allowing modification. Adds separate section with org icon and read-only badge.
2026-02-02 09:25:13 -05:00

217 lines
7.0 KiB
Handlebars

{{if .GlobalSecrets}}
<h4 class="ui top attached header">
{{ctx.Locale.Tr "secrets.global_secrets"}}
<span class="ui basic label tw-ml-2">{{ctx.Locale.Tr "secrets.read_only"}}</span>
</h4>
<div class="ui attached segment">
<p class="tw-text-sm tw-text-gray-500 tw-mb-4">{{ctx.Locale.Tr "secrets.global_secrets.description"}}</p>
<div class="flex-list">
{{range .GlobalSecrets}}
<div class="flex-item tw-items-center">
<div class="flex-item-leading">
{{svg "octicon-globe" 32}}
</div>
<div class="flex-item-main">
<div class="flex-item-title">
{{.Name}}
</div>
<div class="flex-item-body">
{{if .Description}}{{.Description}}{{else}}-{{end}}
</div>
<div class="flex-item-body">
******
</div>
</div>
<div class="flex-item-trailing">
<span class="color-text-light-2">
{{ctx.Locale.Tr "settings.added_on" (DateUtils.AbsoluteShort .CreatedUnix)}}
</span>
</div>
</div>
{{end}}
</div>
</div>
{{end}}
{{if .OrgSecrets}}
<h4 class="ui top attached header">
{{ctx.Locale.Tr "secrets.org_secrets"}}
<span class="ui basic label tw-ml-2">{{ctx.Locale.Tr "secrets.read_only"}}</span>
</h4>
<div class="ui attached segment">
<p class="tw-text-sm tw-text-gray-500 tw-mb-4">{{ctx.Locale.Tr "secrets.org_secrets.description"}}</p>
<div class="flex-list">
{{range .OrgSecrets}}
<div class="flex-item tw-items-center">
<div class="flex-item-leading">
{{svg "octicon-organization" 32}}
</div>
<div class="flex-item-main">
<div class="flex-item-title">
{{.Name}}
</div>
<div class="flex-item-body">
{{if .Description}}{{.Description}}{{else}}-{{end}}
</div>
<div class="flex-item-body">
******
</div>
</div>
<div class="flex-item-trailing">
<span class="color-text-light-2">
{{ctx.Locale.Tr "settings.added_on" (DateUtils.AbsoluteShort .CreatedUnix)}}
</span>
</div>
</div>
{{end}}
</div>
</div>
{{end}}
<h4 class="ui top attached header">
{{ctx.Locale.Tr "secrets.management"}}
<div class="ui right">
<button class="ui primary tiny button show-modal"
data-modal="#add-secret-modal"
data-modal-form.action="{{.Link}}"
data-modal-header="{{ctx.Locale.Tr "secrets.add_secret"}}"
data-modal-secret-name.value=""
data-modal-secret-name.read-only="false"
data-modal-secret-data=""
data-modal-secret-description=""
>
{{ctx.Locale.Tr "secrets.add_secret"}}
</button>
</div>
</h4>
<div class="ui attached segment">
{{if .Secrets}}
<div class="flex-list">
{{range .Secrets}}
<div class="flex-item tw-items-center">
<div class="flex-item-leading">
{{svg "octicon-key" 32}}
</div>
<div class="flex-item-main">
<div class="flex-item-title">
{{.Name}}
</div>
<div class="flex-item-body">
{{if .Description}}{{.Description}}{{else}}-{{end}}
</div>
<div class="flex-item-body">
******
</div>
</div>
<div class="flex-item-trailing">
<span class="color-text-light-2">
{{ctx.Locale.Tr "settings.added_on" (DateUtils.AbsoluteShort .CreatedUnix)}}
</span>
<button class="btn interact-bg show-modal tw-p-2"
data-modal="#add-secret-modal"
data-modal-form.action="{{$.Link}}"
data-modal-header="{{ctx.Locale.Tr "secrets.edit_secret"}}"
data-tooltip-content="{{ctx.Locale.Tr "secrets.edit_secret"}}"
data-modal-secret-name.value="{{.Name}}"
data-modal-secret-name.read-only="true"
data-modal-secret-data=""
data-modal-secret-description="{{if .Description}}{{.Description}}{{end}}"
>
{{svg "octicon-pencil"}}
</button>
<button class="btn interact-bg link-action tw-p-2"
data-url="{{$.Link}}/delete?id={{.ID}}"
data-modal-confirm="{{ctx.Locale.Tr "secrets.deletion.description"}}"
data-tooltip-content="{{ctx.Locale.Tr "secrets.deletion"}}"
>
{{svg "octicon-trash"}}
</button>
{{if or (and $.IsRepoContext $.RepoOwnerIsOrg) (and $.IsOrgContext $.IsSystemAdmin) (and $.IsRepoContext $.IsSystemAdmin)}}
<div class="ui small dropdown button tw-p-2" style="min-width:auto;" data-tooltip-content="{{ctx.Locale.Tr "secrets.promote"}}">
{{svg "octicon-arrow-up"}}
<div class="menu">
{{if and $.IsRepoContext $.RepoOwnerIsOrg}}
<button class="item link-action"
data-url="{{$.Link}}/promote?id={{.ID}}&target=org"
data-modal-confirm="{{ctx.Locale.Tr "secrets.promote.confirm_org" .Name}}"
>{{svg "octicon-organization" 14}} {{ctx.Locale.Tr "secrets.promote.to_org"}}</button>
{{end}}
{{if $.IsSystemAdmin}}
<button class="item link-action"
data-url="{{$.Link}}/promote?id={{.ID}}&target=global"
data-modal-confirm="{{ctx.Locale.Tr "secrets.promote.confirm_global" .Name}}"
>{{svg "octicon-globe" 14}} {{ctx.Locale.Tr "secrets.promote.to_global"}}</button>
{{end}}
</div>
</div>
{{end}}
</div>
</div>
{{end}}
</div>
{{else}}
{{ctx.Locale.Tr "secrets.none"}}
{{end}}
</div>
{{/* Add secret dialog */}}
<div class="ui small modal" id="add-secret-modal">
<div class="header"></div>
<form class="ui form form-fetch-action" method="post">
<div class="content">
<div class="field">
{{ctx.Locale.Tr "secrets.description"}}
</div>
<div class="field">
<label for="secret-name">{{ctx.Locale.Tr "name"}}</label>
<input autofocus required
id="secret-name"
name="name"
value="{{.name}}"
pattern="^(?!GITEA_|GITHUB_)[a-zA-Z_][a-zA-Z0-9_]*$"
placeholder="{{ctx.Locale.Tr "secrets.creation.name_placeholder"}}"
>
</div>
<div class="field">
<label for="secret-data">{{ctx.Locale.Tr "value"}}</label>
<textarea
id="secret-data"
name="data"
maxlength="{{.DataMaxLength}}"
placeholder="{{ctx.Locale.Tr "secrets.creation.value_placeholder"}}"
></textarea>
<p class="help tw-hidden" id="secret-data-optional-hint">{{ctx.Locale.Tr "secrets.update.value_optional"}}</p>
</div>
<div class="field">
<label for="secret-description">{{ctx.Locale.Tr "secrets.creation.description"}}</label>
<textarea
id="secret-description"
name="description"
rows="2"
maxlength="{{.DescriptionMaxLength}}"
placeholder="{{ctx.Locale.Tr "secrets.creation.description_placeholder"}}"
></textarea>
</div>
</div>
{{template "base/modal_actions_confirm" (dict "ModalButtonTypes" "confirm")}}
</form>
</div>
<script>
// Handle required attribute for secret data based on create vs edit mode
document.getElementById('add-secret-modal')?.addEventListener('shown.bs.modal', function() {
const nameInput = document.getElementById('secret-name');
const dataInput = document.getElementById('secret-data');
const optionalHint = document.getElementById('secret-data-optional-hint');
if (nameInput && dataInput && optionalHint) {
const isEditing = nameInput.readOnly;
if (isEditing) {
dataInput.removeAttribute('required');
optionalHint.classList.remove('tw-hidden');
} else {
dataInput.setAttribute('required', 'required');
optionalHint.classList.add('tw-hidden');
}
}
});
</script>