mirror of
https://github.com/bitwarden/server.git
synced 2025-04-05 05:00:19 -05:00
[AC-1429] Add new secrets manager fields to organization edit page in admin portal (#3009)
* Added new secrets fields to organization edit page * Reordered fields based on feedback from Priya
This commit is contained in:
parent
e0b231a220
commit
333145209e
@ -287,6 +287,12 @@ public class OrganizationsController : Controller
|
|||||||
organization.UseTotp = model.UseTotp;
|
organization.UseTotp = model.UseTotp;
|
||||||
organization.UsersGetPremium = model.UsersGetPremium;
|
organization.UsersGetPremium = model.UsersGetPremium;
|
||||||
organization.UseSecretsManager = model.UseSecretsManager;
|
organization.UseSecretsManager = model.UseSecretsManager;
|
||||||
|
|
||||||
|
//secrets
|
||||||
|
organization.SmSeats = model.SmSeats;
|
||||||
|
organization.MaxAutoscaleSmSeats = model.MaxAutoscaleSmSeats;
|
||||||
|
organization.SmServiceAccounts = model.SmServiceAccounts;
|
||||||
|
organization.MaxAutoscaleSmServiceAccounts = model.MaxAutoscaleSmServiceAccounts;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_accessControlService.UserHasPermission(Permission.Org_Licensing_Edit))
|
if (_accessControlService.UserHasPermission(Permission.Org_Licensing_Edit))
|
||||||
|
@ -63,6 +63,10 @@ public class OrganizationEditModel : OrganizationViewModel
|
|||||||
Enabled = org.Enabled;
|
Enabled = org.Enabled;
|
||||||
LicenseKey = org.LicenseKey;
|
LicenseKey = org.LicenseKey;
|
||||||
ExpirationDate = org.ExpirationDate;
|
ExpirationDate = org.ExpirationDate;
|
||||||
|
SmSeats = org.SmSeats;
|
||||||
|
MaxAutoscaleSmSeats = org.MaxAutoscaleSmSeats;
|
||||||
|
SmServiceAccounts = org.SmServiceAccounts;
|
||||||
|
MaxAutoscaleSmServiceAccounts = org.MaxAutoscaleSmServiceAccounts;
|
||||||
}
|
}
|
||||||
|
|
||||||
public BillingInfo BillingInfo { get; set; }
|
public BillingInfo BillingInfo { get; set; }
|
||||||
@ -134,6 +138,14 @@ public class OrganizationEditModel : OrganizationViewModel
|
|||||||
[Display(Name = "Expiration Date")]
|
[Display(Name = "Expiration Date")]
|
||||||
public DateTime? ExpirationDate { get; set; }
|
public DateTime? ExpirationDate { get; set; }
|
||||||
public bool SalesAssistedTrialStarted { get; set; }
|
public bool SalesAssistedTrialStarted { get; set; }
|
||||||
|
[Display(Name = "Seats")]
|
||||||
|
public int? SmSeats { get; set; }
|
||||||
|
[Display(Name = "Max Autoscale Seats")]
|
||||||
|
public int? MaxAutoscaleSmSeats { get; set; }
|
||||||
|
[Display(Name = "Max Service Accounts")]
|
||||||
|
public int? SmServiceAccounts { get; set; }
|
||||||
|
[Display(Name = "Max Autoscale Service Accounts")]
|
||||||
|
public int? MaxAutoscaleSmServiceAccounts { get; set; }
|
||||||
|
|
||||||
public Organization CreateOrganization(Provider provider)
|
public Organization CreateOrganization(Provider provider)
|
||||||
{
|
{
|
||||||
@ -174,6 +186,10 @@ public class OrganizationEditModel : OrganizationViewModel
|
|||||||
existingOrganization.LicenseKey = LicenseKey;
|
existingOrganization.LicenseKey = LicenseKey;
|
||||||
existingOrganization.ExpirationDate = ExpirationDate;
|
existingOrganization.ExpirationDate = ExpirationDate;
|
||||||
existingOrganization.MaxAutoscaleSeats = MaxAutoscaleSeats;
|
existingOrganization.MaxAutoscaleSeats = MaxAutoscaleSeats;
|
||||||
|
existingOrganization.SmSeats = SmSeats;
|
||||||
|
existingOrganization.MaxAutoscaleSmSeats = MaxAutoscaleSmSeats;
|
||||||
|
existingOrganization.SmServiceAccounts = SmServiceAccounts;
|
||||||
|
existingOrganization.MaxAutoscaleSmServiceAccounts = MaxAutoscaleSmServiceAccounts;
|
||||||
return existingOrganization;
|
return existingOrganization;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -99,34 +99,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="row">
|
|
||||||
<div class="col-sm">
|
|
||||||
<div class="form-group">
|
|
||||||
<label asp-for="Seats"></label>
|
|
||||||
<input type="number" class="form-control" asp-for="Seats" min="1" readonly='@(!canEditPlan)'>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm">
|
|
||||||
<div class="form-group">
|
|
||||||
<label asp-for="MaxCollections"></label>
|
|
||||||
<input type="number" class="form-control" asp-for="MaxCollections" min="1" readonly='@(!canEditPlan)'>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="col-sm">
|
|
||||||
<div class="form-group">
|
|
||||||
<label asp-for="MaxStorageGb"></label>
|
|
||||||
<input type="number" class="form-control" asp-for="MaxStorageGb" min="1" readonly='@(!canEditPlan)'>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<div class="row">
|
|
||||||
<div class="col-4">
|
|
||||||
<div class="form-group">
|
|
||||||
<label asp-for="MaxAutoscaleSeats"></label>
|
|
||||||
<input type="number" class="form-control" asp-for="MaxAutoscaleSeats" min="1" readonly='@(!canEditPlan)'>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
<h2>Features</h2>
|
<h2>Features</h2>
|
||||||
<div class="row mb-3">
|
<div class="row mb-3">
|
||||||
<div class="col-4">
|
<div class="col-4">
|
||||||
@ -200,6 +172,75 @@
|
|||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@if (canViewPlan)
|
||||||
|
{
|
||||||
|
<h2>Password Manager Configuration</h2>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="Seats"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="Seats" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="MaxCollections"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="MaxCollections" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="MaxStorageGb"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="MaxStorageGb" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-4">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="MaxAutoscaleSeats"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="MaxAutoscaleSeats" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
|
||||||
|
@if (canViewPlan)
|
||||||
|
{
|
||||||
|
<div id="organization-secrets-configuration" hidden="@(!Model.UseSecretsManager)">
|
||||||
|
<h2>Secrets Manager Configuration</h2>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-sm">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="SmSeats"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="SmSeats" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="MaxAutoscaleSmSeats"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="MaxAutoscaleSmSeats" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="col-sm">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="SmServiceAccounts"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="SmServiceAccounts" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<div class="row">
|
||||||
|
<div class="col-4">
|
||||||
|
<div class="form-group">
|
||||||
|
<label asp-for="MaxAutoscaleSmServiceAccounts"></label>
|
||||||
|
<input type="number" class="form-control" asp-for="MaxAutoscaleSmServiceAccounts" min="1" readonly='@(!canEditPlan)'>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
}
|
||||||
|
|
||||||
@if(canViewLicensing)
|
@if(canViewLicensing)
|
||||||
{
|
{
|
||||||
<h2>Licensing</h2>
|
<h2>Licensing</h2>
|
||||||
|
@ -32,6 +32,18 @@
|
|||||||
'subscriptions/' + subId.value, '_blank');
|
'subscriptions/' + subId.value, '_blank');
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
document.getElementById('@(nameof(Model.UseSecretsManager))').addEventListener('change', (event) => {
|
||||||
|
document.getElementById('organization-secrets-configuration').hidden = !event.target.checked;
|
||||||
|
|
||||||
|
if (event.target.checked) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
document.getElementById('@(nameof(Model.SmSeats))').value = '';
|
||||||
|
document.getElementById('@(nameof(Model.MaxAutoscaleSmSeats))').value = '';
|
||||||
|
document.getElementById('@(nameof(Model.SmServiceAccounts))').value = '';
|
||||||
|
document.getElementById('@(nameof(Model.MaxAutoscaleSmServiceAccounts))').value = '';
|
||||||
|
});
|
||||||
})();
|
})();
|
||||||
|
|
||||||
function togglePlanSettings(planType) {
|
function togglePlanSettings(planType) {
|
||||||
@ -43,6 +55,10 @@
|
|||||||
document.getElementById('@(nameof(Model.Seats))').value = '10';
|
document.getElementById('@(nameof(Model.Seats))').value = '10';
|
||||||
document.getElementById('@(nameof(Model.MaxCollections))').value = '';
|
document.getElementById('@(nameof(Model.MaxCollections))').value = '';
|
||||||
document.getElementById('@(nameof(Model.MaxStorageGb))').value = '1';
|
document.getElementById('@(nameof(Model.MaxStorageGb))').value = '1';
|
||||||
|
// Secrets
|
||||||
|
if (document.getElementById('@(nameof(Model.UseSecretsManager))').checked) {
|
||||||
|
document.getElementById('@(nameof(Model.SmServiceAccounts))').value = '50';
|
||||||
|
}
|
||||||
// Features
|
// Features
|
||||||
document.getElementById('@(nameof(Model.UsePolicies))').checked = false;
|
document.getElementById('@(nameof(Model.UsePolicies))').checked = false;
|
||||||
document.getElementById('@(nameof(Model.UseSso))').checked = false;
|
document.getElementById('@(nameof(Model.UseSso))').checked = false;
|
||||||
@ -69,6 +85,10 @@
|
|||||||
document.getElementById('@(nameof(Model.Seats))').value = '10';
|
document.getElementById('@(nameof(Model.Seats))').value = '10';
|
||||||
document.getElementById('@(nameof(Model.MaxCollections))').value = '';
|
document.getElementById('@(nameof(Model.MaxCollections))').value = '';
|
||||||
document.getElementById('@(nameof(Model.MaxStorageGb))').value = '1';
|
document.getElementById('@(nameof(Model.MaxStorageGb))').value = '1';
|
||||||
|
// Secrets
|
||||||
|
if (document.getElementById('@(nameof(Model.UseSecretsManager))').checked) {
|
||||||
|
document.getElementById('@(nameof(Model.SmServiceAccounts))').value = '200';
|
||||||
|
}
|
||||||
// Features
|
// Features
|
||||||
document.getElementById('@(nameof(Model.UsePolicies))').checked = true;
|
document.getElementById('@(nameof(Model.UsePolicies))').checked = true;
|
||||||
document.getElementById('@(nameof(Model.UseSso))').checked = true;
|
document.getElementById('@(nameof(Model.UseSso))').checked = true;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user