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
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.
217 lines
7.0 KiB
Handlebars
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>
|