ソースを参照

[Web] add generic-oidc provider

FreddleSpl0it 2 年 前
コミット
d2e656107f
1 ファイル変更14 行追加3 行削除
  1. 14 3
      data/web/js/site/admin.js

+ 14 - 3
data/web/js/site/admin.js

@@ -750,9 +750,9 @@ jQuery(function($){
     add_table_row($('#f2b_regex_table'), "f2b_regex");
   });
   // IAM test connection
-  $('#iam_test_connection').click(async function(e){
+  $('.iam_test_connection').click(async function(e){
     e.preventDefault();
-    var data = { attr: $('form[data-id="iam_sso"]').serializeObject() };
+    var data = { attr: $('form[data-id="' + $(this).data('id') + '"]').serializeObject() };
     var res = await fetch("/api/v1/edit/identity-provider-test", { 
       headers: {
         "Content-Type": "application/json",
@@ -768,7 +768,7 @@ jQuery(function($){
     return mailcow_alert_box(lang_danger.iam_test_connection, 'danger');
   });
 
-  $('#iam_rolemap_add').click(async function(e){
+  $('.iam_rolemap_add').click(async function(e){
     e.preventDefault();
 
     var parent = $(this).parent().parent();
@@ -791,4 +791,15 @@ jQuery(function($){
     e.preventDefault();
     $(this).parent().remove();
   });
+  // selecting identity provider
+  $('#iam_provider').on('change', function(){
+    // toggle password fields
+    if (this.value === 'keycloak'){
+      $('#keycloak_settings').removeClass('d-none');
+      $('#generic_oidc_settings').addClass('d-none');
+    } else if (this.value === 'generic-oidc') {
+      $('#keycloak_settings').addClass('d-none');
+      $('#generic_oidc_settings').removeClass('d-none');
+    }
+  });
 });