diff --git a/data/web/edit.php b/data/web/edit.php
index ff1ccc44..185e7934 100644
--- a/data/web/edit.php
+++ b/data/web/edit.php
@@ -38,24 +38,36 @@ if (isset($_SESSION['mailcow_cc_role'])) {
       $template = 'edit/admin.twig';
       $template_data = ['admin' => $admin];
     }
-    elseif (isset($_GET['domain']) &&
-      is_valid_domain_name($_GET["domain"]) &&
-      !empty($_GET["domain"])) {
-        $domain = $_GET["domain"];
-        $result = mailbox('get', 'domain_details', $domain);
-        $quota_notification_bcc = quota_notification_bcc('get', $domain);
-        $rl = ratelimit('get', 'domain', $domain);
-        $rlyhosts = relayhost('get');
-        $template = 'edit/domain.twig';
-        $template_data = [
-          'acl' => $_SESSION['acl'],
-          'domain' => $domain,
-          'quota_notification_bcc' => $quota_notification_bcc,
-          'rl' => $rl,
-          'rlyhosts' => $rlyhosts,
-          'dkim' => dkim('details', $domain),
-          'domain_details' => $result,
-        ];
+    elseif (isset($_GET['domain'])) {
+      if ($_GET['domain'] == "defaults") {
+          // edit domain default settings
+          //$result = mailbox('get', 'domain_defaults');
+          //$rl = ratelimit('get', 'domain_defaults');
+          $result = true;
+          $template = 'edit/domain-defaults.twig';
+          $template_data = [
+          //  'rl' => $rl,
+          ];
+      }
+      elseif (is_valid_domain_name($_GET["domain"]) &&
+        !empty($_GET["domain"])) {
+          // edit domain
+          $domain = $_GET["domain"];
+          $result = mailbox('get', 'domain_details', $domain);
+          $quota_notification_bcc = quota_notification_bcc('get', $domain);
+          $rl = ratelimit('get', 'domain', $domain);
+          $rlyhosts = relayhost('get');
+          $template = 'edit/domain.twig';
+          $template_data = [
+            'acl' => $_SESSION['acl'],
+            'domain' => $domain,
+            'quota_notification_bcc' => $quota_notification_bcc,
+            'rl' => $rl,
+            'rlyhosts' => $rlyhosts,
+            'dkim' => dkim('details', $domain),
+            'domain_details' => $result,
+          ];
+      }
     }
     elseif (isset($_GET['oauth2client']) &&
       is_numeric($_GET["oauth2client"]) &&
@@ -79,29 +91,42 @@ if (isset($_SESSION['mailcow_cc_role'])) {
           'dkim' => dkim('details', $alias_domain),
         ];
     }
-    elseif (isset($_GET['mailbox']) && filter_var(html_entity_decode(rawurldecode($_GET["mailbox"])), FILTER_VALIDATE_EMAIL) && !empty($_GET["mailbox"])) {
-      $mailbox = html_entity_decode(rawurldecode($_GET["mailbox"]));
-      $result = mailbox('get', 'mailbox_details', $mailbox);
-      $rl = ratelimit('get', 'mailbox', $mailbox);
-      $pushover_data = pushover('get', $mailbox);
-      $quarantine_notification = mailbox('get', 'quarantine_notification', $mailbox);
-      $quarantine_category = mailbox('get', 'quarantine_category', $mailbox);
-      $get_tls_policy = mailbox('get', 'tls_policy', $mailbox);
-      $rlyhosts = relayhost('get');
-      $template = 'edit/mailbox.twig';
-      $template_data = [
-        'acl' => $_SESSION['acl'],
-        'mailbox' => $mailbox,
-        'rl' => $rl,
-        'pushover_data' => $pushover_data,
-        'quarantine_notification' => $quarantine_notification,
-        'quarantine_category' => $quarantine_category,
-        'get_tls_policy' => $get_tls_policy,
-        'rlyhosts' => $rlyhosts,
-        'sender_acl_handles' => mailbox('get', 'sender_acl_handles', $mailbox),
-        'user_acls' => acl('get', 'user', $mailbox),
-        'mailbox_details' => $result
-      ];
+    elseif (isset($_GET['mailbox'])){
+      if ($_GET['mailbox'] == "defaults"){
+        // edit mailbox default settings
+        // $result = mailbox('get', 'mailbox_defaults');
+        // $rl = ratelimit('get', 'mailbox_defaults');
+        $result = true;
+        $template = 'edit/mailbox-defaults.twig';
+        $template_data = [
+        //  'rl' => $rl,
+        ];
+      }
+      elseif(filter_var(html_entity_decode(rawurldecode($_GET["mailbox"])), FILTER_VALIDATE_EMAIL) && !empty($_GET["mailbox"])) {
+        // edit mailbox
+        $mailbox = html_entity_decode(rawurldecode($_GET["mailbox"]));
+        $result = mailbox('get', 'mailbox_details', $mailbox);
+        $rl = ratelimit('get', 'mailbox', $mailbox);
+        $pushover_data = pushover('get', $mailbox);
+        $quarantine_notification = mailbox('get', 'quarantine_notification', $mailbox);
+        $quarantine_category = mailbox('get', 'quarantine_category', $mailbox);
+        $get_tls_policy = mailbox('get', 'tls_policy', $mailbox);
+        $rlyhosts = relayhost('get');
+        $template = 'edit/mailbox.twig';
+        $template_data = [
+          'acl' => $_SESSION['acl'],
+          'mailbox' => $mailbox,
+          'rl' => $rl,
+          'pushover_data' => $pushover_data,
+          'quarantine_notification' => $quarantine_notification,
+          'quarantine_category' => $quarantine_category,
+          'get_tls_policy' => $get_tls_policy,
+          'rlyhosts' => $rlyhosts,
+          'sender_acl_handles' => mailbox('get', 'sender_acl_handles', $mailbox),
+          'user_acls' => acl('get', 'user', $mailbox),
+          'mailbox_details' => $result
+        ];
+      }
     }
     elseif (isset($_GET['relayhost']) && is_numeric($_GET["relayhost"]) && !empty($_GET["relayhost"])) {
         $relayhost = intval($_GET["relayhost"]);
diff --git a/data/web/templates/edit/domain-defaults.twig b/data/web/templates/edit/domain-defaults.twig
new file mode 100644
index 00000000..84b150da
--- /dev/null
+++ b/data/web/templates/edit/domain-defaults.twig
@@ -0,0 +1,156 @@
+{% extends 'edit.twig' %}
+
+{% block inner_content %}
+{% if result %}
+<ul class="nav nav-tabs" role="tablist">
+  <li role="presentation" class="nav-item"><button class="nav-link active" data-bs-toggle="tab" data-bs-target="#dedit">{{ lang.edit.domain }}</button></li>
+  <li role="presentation" class="nav-item"><button class="nav-link" data-bs-toggle="tab" data-bs-target="#dratelimit">{{ lang.edit.ratelimit }}</button></li>
+  <li role="presentation" class="nav-item"><button class="nav-link" data-bs-toggle="tab" data-bs-target="#dspamfilter">{{ lang.edit.spam_filter }}</button></li>
+  <li role="presentation" class="nav-item"><button class="nav-link" data-bs-toggle="tab" data-bs-target="#dqwbcc">{{ lang.edit.quota_warning_bcc }}</button></li>
+</ul>
+<hr>
+<div class="tab-content">
+  <div id="dedit" class="tab-pane fade show active" role="tabpanel" aria-labelledby="domain-edit">
+    <form data-id="editdomain" class="form-horizontal" role="form" method="post">
+      <input type="hidden" value="0" name="active">
+      <input type="hidden" value="0" name="backupmx">
+      <input type="hidden" value="0" name="gal">
+      <input type="hidden" value="0" name="relay_all_recipients">
+      <input type="hidden" value="0" name="relay_unknown_only">
+      {% if mailcow_cc_role == 'admin' %}
+      <div class="row mb-2">
+        <label class="control-label col-sm-2" for="aliases">{{ lang.edit.max_aliases }}</label>
+        <div class="col-sm-10">
+          <input type="number" class="form-control" name="aliases" value="{{ result.max_num_aliases_for_domain }}">
+        </div>
+      </div>
+      <div class="row mb-2">
+        <label class="control-label col-sm-2" for="mailboxes">{{ lang.edit.max_mailboxes }}</label>
+        <div class="col-sm-10">
+          <input type="number" class="form-control" name="mailboxes" value="{{ result.max_num_mboxes_for_domain }}">
+        </div>
+      </div>
+      <div class="row mb-2">
+        <label class="control-label col-sm-2" for="defquota">{{ lang.edit.mailbox_quota_def }}</label>
+        <div class="col-sm-10">
+          <input type="number" class="form-control" name="defquota" value="{{ (result.def_quota_for_mbox / 1048576) }}">
+        </div>
+      </div>
+      <div class="row mb-2">
+        <label class="control-label col-sm-2" for="maxquota">{{ lang.edit.max_quota }}</label>
+        <div class="col-sm-10">
+          <input type="number" class="form-control" name="maxquota" value="{{ (result.max_quota_for_mbox / 1048576) }}">
+        </div>
+      </div>
+      <div class="row mb-4">
+        <label class="control-label col-sm-2" for="quota">{{ lang.edit.domain_quota }}</label>
+        <div class="col-sm-10">
+          <input type="number" class="form-control" name="quota" value="{{ (result.max_quota_for_domain / 1048576) }}">
+        </div>
+      </div>
+      {% endif %}
+      <hr>
+      <div class="row mb-2">
+        <div class="offset-sm-2 col-sm-10">
+          <div class="checkbox">
+            <label><input type="checkbox" value="1" name="active"{% if result.active == '1' %} checked{% endif %}{% if mailcow_cc_role != 'admin' %} disabled{% endif %}> {{ lang.edit.active }}</label>
+          </div>
+        </div>
+      </div>
+      <div class="row">
+        <div class="offset-sm-2 col-sm-10">
+          <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="edit_selected" data-id="editdomain" data-item="{{ domain }}" data-api-url='edit/domain' data-api-attr='{}' href="#">{{ lang.admin.save }}</button>
+        </div>
+      </div>
+    </form>
+  </div>
+  <div id="dratelimit" class="tab-pane fade" role="tabpanel" aria-labelledby="domain-ratelimit">
+    <form data-id="domratelimit" class="form-inline well" method="post">
+      <div class="row">
+        <div class="col-12">
+          <label class="control-label mb-2">{{ lang.edit.ratelimit }}</label>
+          <input name="rl_value" type="number" value="{{ rl.value }}" autocomplete="off" class="form-control mb-4" placeholder="{{ lang.ratelimit.disabled }}">
+          <select name="rl_frame" class="form-control">
+            {% include 'mailbox/rl-frame.twig' %}
+          </select>
+          <button data-acl="{{ acl.ratelimit }}" class="btn btn-xs-lg d-block d-sm-inline btn-secondary" data-action="edit_selected" data-id="domratelimit" data-item="{{ domain }}" data-api-url='edit/rl-domain' data-api-attr='{}' href="#">{{ lang.admin.save }}</button>
+        </div>
+      </div>
+    </form>
+  </div>
+  <div id="dspamfilter" class="tab-pane fade" role="tabpanel" aria-labelledby="domain-spamfilter">
+    <div class="row">
+      <div class="col-sm-6">
+        <h4>{{ lang.user.spamfilter_wl }}</h4>
+        <p>{{ lang.user.spamfilter_wl_desc|raw }}</p>
+        <form class="form-inline mb-4" data-id="add_wl_policy_domain">
+          <div class="input-group" data-acl="{{ acl.spam_policy }}">
+            <input type="text" class="form-control" name="object_from" placeholder="*@example.org" required>
+            <span class="input-group-btn">
+                      <button class="btn btn-secondary" data-action="add_item" data-id="add_wl_policy_domain" data-api-url='add/domain-policy' data-api-attr='{"domain":"{{ domain }}","object_list":"wl"}' href="#">{{ lang.user.spamfilter_table_add }}</button>
+                    </span>
+          </div>
+        </form>
+        <table id="wl_policy_domain_table" class="table table-striped dt-responsive w-100"></table>
+        <div class="mass-actions-user">
+          <div class="btn-group" data-acl="{{ acl.spam_policy }}">
+            <a class="btn btn-xs-half d-block d-sm-inline btn-sm btn-secondary" id="toggle_multi_select_all" data-id="policy_wl_domain" href="#"><i class="bi bi-check-all"></i> {{ lang.mailbox.toggle_all }}</a>
+            <a class="btn btn-xs-half d-block d-sm-inline btn-sm btn-danger" data-action="delete_selected" data-id="policy_wl_domain" data-api-url='delete/domain-policy' href="#">{{ lang.mailbox.remove }}</a>
+          </div>
+        </div>
+      </div>
+      <div class="col-sm-6">
+        <h4>{{ lang.user.spamfilter_bl }}</h4>
+        <p>{{ lang.user.spamfilter_bl_desc|raw }}</p>
+        <form class="form-inline mb-4" data-id="add_bl_policy_domain">
+          <div class="input-group" data-acl="{{ acl.spam_policy }}">
+            <input type="text" class="form-control" name="object_from" placeholder="*@example.org" required>
+            <span class="input-group-btn">
+                      <button class="btn btn-secondary" data-action="add_item" data-id="add_bl_policy_domain" data-api-url='add/domain-policy' data-api-attr='{"domain":"{{ domain }}","object_list":"bl"}' href="#">{{ lang.user.spamfilter_table_add }}</button>
+                    </span>
+          </div>
+        </form>
+        <table id="bl_policy_domain_table" class="table table-striped dt-responsive w-100"></table>
+        <div class="mass-actions-user">
+          <div class="btn-group" data-acl="{{ acl.spam_policy }}">
+            <a class="btn btn-xs-half d-block d-sm-inline btn-sm btn-secondary" id="toggle_multi_select_all" data-id="policy_bl_domain" href="#"><i class="bi bi-check-all"></i> {{ lang.mailbox.toggle_all }}</a>
+            <a class="btn btn-xs-half d-block d-sm-inline btn-sm btn-danger" data-action="delete_selected" data-id="policy_bl_domain" data-api-url='delete/domain-policy' href="#">{{ lang.mailbox.remove }}</a></li>
+          </div>
+        </div>
+      </div>
+    </div>
+  </div>
+  <div id="dqwbcc" class="tab-pane fade" role="tabpanel" aria-labelledby="domain-qwbcc">
+    <div class="row">
+      <div class="col-sm-12">
+        <h4>{{ lang.edit.quota_warning_bcc }}</h4>
+        <p>{{ lang.edit.quota_warning_bcc_info|raw }}</p>
+        <form class="form-horizontal" data-id="quota_bcc">
+          <input type="hidden" value="0" name="active">
+          <div class="row mb-2">
+            <label class="control-label col-sm-2" for="script_data">{{ lang.edit.target_address|raw }}:</label>
+            <div class="col-sm-10">
+              <textarea spellcheck="false" autocorrect="off" autocapitalize="none" class="form-control" rows="10" id="bcc_rcpt" name="bcc_rcpt">{{ quota_notification_bcc.bcc_rcpts|join("\n") }}</textarea>
+            </div>
+          </div>
+          <div class="row mb-4">
+            <div class="offset-sm-2 col-sm-10">
+              <div class="checkbox">
+                <label><input type="checkbox" value="1" name="active"{% if quota_notification_bcc.active == '1' %} checked{% endif %}> {{ lang.edit.active }}</label>
+              </div>
+            </div>
+          </div>
+          <div class="row">
+            <div class="offset-sm-2 col-sm-10">
+              <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="edit_selected" data-id="quota_bcc" data-item="quota_bcc" data-api-url='edit/quota_notification_bcc' data-api-attr='{"domain":"{{ domain }}"}' href="#">{{ lang.edit.save }}</button>
+            </div>
+          </div>
+        </form>
+      </div>
+    </div>
+  </div>
+</div>
+{% else %}
+  {{ parent() }}
+{% endif %}
+{% endblock %}
diff --git a/data/web/templates/edit/mailbox-defaults.twig b/data/web/templates/edit/mailbox-defaults.twig
new file mode 100644
index 00000000..9487c856
--- /dev/null
+++ b/data/web/templates/edit/mailbox-defaults.twig
@@ -0,0 +1,195 @@
+{% extends 'edit.twig' %}
+
+{% block inner_content %}
+{% if result %}
+<ul class="nav nav-tabs" role="tablist">
+  <li role="presentation" class="nav-item"><button class="nav-link active" data-bs-toggle="tab" data-bs-target="#medit">{{ lang.edit.mailbox }}</button></li>
+  <li role="presentation" class="nav-item"><button class="nav-link" data-bs-toggle="tab" data-bs-target="#macl">{{ lang.edit.acl }}</button></li>
+  <li role="presentation" class="nav-item"><button class="nav-link" data-bs-toggle="tab" data-bs-target="#mrl">{{ lang.edit.ratelimit }}</button></li>
+</ul>
+<hr>
+<div class="tab-content">
+  <div id="medit" class="tab-pane fade show active" role="tabpanel" aria-labelledby="mailbox-edit">
+    <form class="form-horizontal" data-id="editmailbox" role="form" method="post">
+      <input type="hidden" value="default" name="sender_acl">
+      <input type="hidden" value="0" name="force_pw_update">
+      <input type="hidden" value="0" name="sogo_access">
+      <input type="hidden" value="0" name="protocol_access">
+      <div class="row mb-2">
+        <label class="control-label col-sm-2" for="quota">
+          {{ lang.edit.quota_mb }}
+        </label>
+        <div class="col-sm-10">
+          <input type="number" name="quota" style="width:100%" min="0" max="{{ (result.max_new_quota / 1048576) }}" value="{{ (result.quota / 1048576) }}" class="form-control">
+          <small class="text-muted">0 = ∞</small>
+        </div>
+      </div>
+      <div class="row mb-2">
+        <label class="control-label col-sm-2">{{ lang.user.quarantine_notification }}</label>
+        <div class="col-sm-10">
+          <div class="btn-group" data-acl="{{ acl.quarantine_notification }}">
+            <button type="button" class="btn btn-sm btn-xs-quart d-block d-sm-inline btn-secondary{% if quarantine_notification == 'never' %} active{% endif %}"
+            data-action="edit_selected"
+            data-item="{{ mailbox }}"
+            data-id="quarantine_notification"
+            data-api-url='edit/quarantine_notification'
+            data-api-attr='{"quarantine_notification":"never"}'>{{ lang.user.never }}</button>
+            <button type="button" class="btn btn-sm btn-xs-quart d-block d-sm-inline btn-secondary{% if quarantine_notification == 'hourly' %} active{% endif %}"
+            data-action="edit_selected"
+            data-item="{{ mailbox }}"
+            data-id="quarantine_notification"
+            data-api-url='edit/quarantine_notification'
+            data-api-attr='{"quarantine_notification":"hourly"}'>{{ lang.user.hourly }}</button>
+            <button type="button" class="btn btn-sm btn-xs-quart d-block d-sm-inline btn-secondary{% if quarantine_notification == 'daily' %} active{% endif %}"
+            data-action="edit_selected"
+            data-item="{{ mailbox }}"
+            data-id="quarantine_notification"
+            data-api-url='edit/quarantine_notification'
+            data-api-attr='{"quarantine_notification":"daily"}'>{{ lang.user.daily }}</button>
+            <button type="button" class="btn btn-sm btn-xs-quart d-block d-sm-inline btn-secondary{% if quarantine_notification == 'weekly' %} active{% endif %}"
+            data-action="edit_selected"
+            data-item="{{ mailbox }}"
+            data-id="quarantine_notification"
+            data-api-url='edit/quarantine_notification'
+            data-api-attr='{"quarantine_notification":"weekly"}'>{{ lang.user.weekly }}</button>
+          </div>
+          <p class="text-muted"><small>{{ lang.user.quarantine_notification_info }}</small></p>
+        </div>
+      </div>
+      <div class="row mb-2">
+        <label class="control-label col-sm-2">{{ lang.user.quarantine_category }}</label>
+        <div class="col-sm-10">
+          <div class="btn-group" data-acl="{{ acl.quarantine_category }}">
+            <button type="button" class="btn btn-sm btn-xs-third d-block d-sm-inline btn-secondary{% if quarantine_category == 'reject' %} active{% endif %}"
+            data-action="edit_selected"
+            data-item="{{ mailbox }}"
+            data-id="quarantine_category"
+            data-api-url='edit/quarantine_category'
+            data-api-attr='{"quarantine_category":"reject"}'>{{ lang.user.q_reject }}</button>
+            <button type="button" class="btn btn-sm btn-xs-third d-block d-sm-inline btn-secondary{% if quarantine_category == 'add_header' %} active{% endif %}"
+            data-action="edit_selected"
+            data-item="{{ mailbox }}"
+            data-id="quarantine_category"
+            data-api-url='edit/quarantine_category'
+            data-api-attr='{"quarantine_category":"add_header"}'>{{ lang.user.q_add_header }}</button>
+            <button type="button" class="btn btn-sm btn-xs-third d-block d-sm-inline btn-secondary{% if quarantine_category == 'all' %} active{% endif %}"
+            data-action="edit_selected"
+            data-item="{{ mailbox }}"
+            data-id="quarantine_category"
+            data-api-url='edit/quarantine_category'
+            data-api-attr='{"quarantine_category":"all"}'>{{ lang.user.q_all }}</button>
+          </div>
+          <p class="text-muted"><small>{{ lang.user.quarantine_category_info }}</small></p>
+        </div>
+      </div>
+      <div class="row mb-4">
+        <label class="control-label col-sm-2" for="sender_acl">{{ lang.user.tls_policy }}</label>
+        <div class="col-sm-10">
+          <div class="btn-group" data-acl="{{ acl.tls_policy }}">
+            <button type="button" class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary{% if get_tls_policy.tls_enforce_in == '1' %} active"{% endif %}"
+              data-action="edit_selected"
+              data-item="{{ mailbox }}"
+              data-id="tls_policy"
+              data-api-url='edit/tls_policy'
+              data-api-attr='{"tls_enforce_in": {% if get_tls_policy.tls_enforce_in == '1' %}0{% else %}1{% endif %} }'>{{ lang.user.tls_enforce_in }}</button>
+            <button type="button" class="btn btn-sm btn-xs-half d-block d-sm-inline btn-secondary{% if get_tls_policy.tls_enforce_out == '1' %} active"{% endif %}"
+              data-action="edit_selected"
+              data-item="{{ mailbox }}"
+              data-id="tls_policy"
+              data-api-url='edit/tls_policy'
+              data-api-attr='{"tls_enforce_out": {% if get_tls_policy.tls_enforce_out == '1' %}0{% else %}1{% endif %} }'>{{ lang.user.tls_enforce_out }}</button>
+          </div>
+        </div>
+      </div>
+      <div class="row">
+        <label class="control-label col-sm-2" for="protocol_access">{{ lang.edit.allowed_protocols }}</label>
+        <div class="col-sm-10">
+          <select data-acl="{{ acl.protocol_access }}" name="protocol_access" multiple class="form-control">
+            <option value="imap"{% if result.attributes.imap_access == '1' %} selected{% endif %}>IMAP</option>
+            <option value="pop3"{% if result.attributes.pop3_access == '1' %} selected{% endif %}>POP3</option>
+            <option value="smtp"{% if result.attributes.smtp_access == '1' %} selected{% endif %}>SMTP</option>
+            <option value="sieve"{% if result.attributes.sieve_access == '1' %} selected{% endif %}>Sieve</option>
+          </select>
+        </div>
+      </div>
+      <div hidden data-acl="{{ acl.smtp_ip_access }}" class="row">
+        <label class="control-label col-sm-2" for="allow_from_smtp">{{ lang.edit.allow_from_smtp }}</label>
+        <div class="col-sm-10">
+          <input type="text" class="form-control" name="allow_from_smtp" value="{{ allow_from_smtp }}" placeholder="1.1.1.1, 10.2.0.0/24, ...">
+          <small class="text-muted">{{ lang.edit.allow_from_smtp_info }}</small>
+        </div>
+      </div>
+      <hr>
+      <div class="row my-2">
+        <div class="offset-sm-2 col-sm-10">
+          <select name="active" class="form-control">
+            <option value="1"{% if result.active == '1' %} selected{% endif %}>{{ lang.edit.active }}</option>
+            <option value="2"{% if result.active == '2' %} selected{% endif %}>{{ lang.edit.disable_login }}</option>
+            <option value="0"{% if result.active == '0' %} selected{% endif %}>{{ lang.edit.inactive }}</option>
+          </select>
+        </div>
+      </div>
+      <div class="row">
+        <div class="offset-sm-2 col-sm-10">
+          <div class="checkbox">
+            <label><input type="checkbox" value="1" name="force_pw_update"{% if result.attributes.force_pw_update == '1' %} checked{% endif %}> {{ lang.edit.force_pw_update }}</label>
+            <small class="text-muted">{{ lang.edit.force_pw_update_info|format(ui_texts.main_name) }}</small>
+          </div>
+        </div>
+      </div>
+      {% if not skip_sogo %}
+      <div data-acl="{{ acl.sogo_access }}" class="row">
+        <div class="offset-sm-2 col-sm-10">
+          <div class="checkbox">
+            <label><input type="checkbox" value="1" name="sogo_access"{% if result.attributes.sogo_access == '1' %} checked{% endif %}> {{ lang.edit.sogo_access }}</label>
+            <small class="text-muted">{{ lang.edit.sogo_access_info }}</small>
+          </div>
+        </div>
+      </div>
+      {% endif %}
+      <div class="row my-2">
+        <div class="offset-sm-2 col-sm-10">
+          <button class="btn btn-xs-lg d-block d-sm-inline btn-success" data-action="edit_selected" data-id="editmailbox" data-item="{{ result.username }}" data-api-url='edit/mailbox' data-api-attr='{}' href="#">{{ lang.edit.save }}</button>
+        </div>
+      </div>
+    </form>
+  </div>
+  <div id="macl" class="tab-pane fade" role="tabpanel" aria-labelledby="mailbox-acl">
+    <form data-id="useracl" class="form-inline well" method="post">
+      <div class="row">
+        <div class="col-sm-1">
+          <p class="text-muted">ACL</p>
+        </div>
+        <div class="col-sm-10">
+          <select id="user_acl" name="user_acl" size="10" multiple>
+            {% for acl, val in user_acls %}
+              <option value="{{ acl }}"{% if val == 1 %} selected{% endif %}>{{ lang.acl[acl] }}</option>
+            {% endfor %}
+          </select>
+          <button class="btn btn-xs-lg d-block d-sm-inline btn-secondary" data-action="edit_selected" data-id="useracl" data-item="{{ mailbox }}" data-api-url='edit/user-acl' data-api-attr='{}' href="#">{{ lang.edit.save }}</button>
+        </div>
+      </div>
+    </form>
+  </div>
+  <div id="mrl" class="tab-pane fade" role="tabpanel" aria-labelledby="mailbox-rl">
+    <form data-id="mboxratelimit" class="form-inline well" method="post">
+      <div class="row">
+        <div class="col-sm-1">
+          <p class="text-muted">{{ lang.acl.ratelimit }}</p>
+        </div>
+        <div class="col-sm-10">
+          <input name="rl_value" type="number" autocomplete="off" value="{{ rl.value }}" class="form-control mb-4" placeholder="{{ lang.ratelimit.disabled }}">
+          <select name="rl_frame" class="form-control">
+            {% include 'mailbox/rl-frame.twig' %}
+          </select>
+          <button class="btn btn-xs-lg d-block d-sm-inline btn-secondary" data-action="edit_selected" data-id="mboxratelimit" data-item="{{ mailbox }}" data-api-url='edit/rl-mbox' data-api-attr='{}' href="#">{{ lang.edit.save }}</button>
+          <p class="text-muted mt-3">{{ lang.edit.mbox_rl_info }}</p>
+        </div>
+      </div>
+    </form>
+  </div>
+</div>
+{% else %}
+  {{ parent() }}
+{% endif %}
+{% endblock %}
diff --git a/data/web/templates/mailbox.twig b/data/web/templates/mailbox.twig
index 382a206c..26215ef2 100644
--- a/data/web/templates/mailbox.twig
+++ b/data/web/templates/mailbox.twig
@@ -7,7 +7,7 @@
     <a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#">{{ lang.mailbox.domains }}</a>
     <ul class="dropdown-menu">
       <li><button class="dropdown-item" aria-selected="false" aria-controls="tab-mailboxes" role="tab" data-bs-toggle="tab" data-bs-target="#tab-domains">{{ lang.mailbox.domains }}</button></li>
-      <li><button class="dropdown-item" aria-selected="false" aria-controls="tab-mailbox-defaults" role="tab" data-bs-toggle="tab" data-bs-target="#tab-mailbox-defaults">Default settings</button></li>
+      <li><a href="/edit/domain/defaults" class="dropdown-item" aria-selected="false" aria-controls="tab-domain-defaults" role="tab">{{ lang.mailbox.mailbox_defaults }}</a></li>
     </ul>
     </li>
     {# <li class="nav-item" role="presentation"><button class="nav-link active" aria-selected="false" aria-controls="tab-domains" role="tab" data-bs-toggle="tab" data-bs-target="#tab-domains">{{ lang.mailbox.domains }}</button></li> #}
@@ -16,7 +16,7 @@
     <a class="nav-link dropdown-toggle" data-bs-toggle="dropdown" href="#">{{ lang.mailbox.mailboxes }}</a>
     <ul class="dropdown-menu">
       <li><button class="dropdown-item" aria-selected="false" aria-controls="tab-mailboxes" role="tab" data-bs-toggle="tab" data-bs-target="#tab-mailboxes">{{ lang.mailbox.mailboxes }}</button></li>
-      <li><button class="dropdown-item" aria-selected="false" aria-controls="tab-mailbox-defaults" role="tab" data-bs-toggle="tab" data-bs-target="#tab-mailbox-defaults">{{ lang.mailbox.mailbox_defaults }}</button></li>
+      <li><a href="/edit/mailbox/defaults" class="dropdown-item" aria-selected="false" aria-controls="tab-mailbox-defaults" role="tab">{{ lang.mailbox.mailbox_defaults }}</a></li>
     </ul>
     </li>
     <li class="nav-item" role="presentation"><button class="nav-link" aria-controls="tab-resources" role="tab" data-bs-toggle="tab" data-bs-target="#tab-resources">{{ lang.mailbox.resources }}</button></li>