setArgument('action', 'popup.ldap.test.send') ->getUrl(); $formgrid = (new CFormGrid()) ->addItem([ (new CLabel(_('Login'), 'test_username'))->setAsteriskMark(), new CFormField( (new CTextBox('test_username', $data['test_username'])) ->setWidth(ZBX_TEXTAREA_SMALL_WIDTH) ->disableAutocomplete() ->setAriaRequired() ) ]) ->addItem([ (new CLabel(_('User password'), 'test_password'))->setAsteriskMark(), new CFormField( (new CPassBox('test_password')) ->setWidth(ZBX_TEXTAREA_SMALL_WIDTH) ->disableAutocomplete() ->setAriaRequired() ) ]); if ($data['ldap_config']['provision_status'] == JIT_PROVISIONING_ENABLED) { $formgrid ->addItem([ new CLabel(_('User role')), (new CFormField((new CSpan(_('No value')))->addClass(ZBX_STYLE_DISABLED)))->setId('provisioning_role') ]) ->addItem([ new CLabel(_('User groups')), (new CFormField((new CSpan(_('No value')))->addClass(ZBX_STYLE_DISABLED)))->setId('provisioning_groups') ]) ->addItem([ new CLabel(_('Media type')), (new CFormField((new CSpan(_('No value')))->addClass(ZBX_STYLE_DISABLED)))->setId('provisioning_medias') ]); } $form = (new CForm('post', $form_action)) ->addItem((new CVar(CCsrfTokenHelper::CSRF_TOKEN_NAME, CCsrfTokenHelper::get('ldap')))->removeId()) ->addItem($formgrid) ->addItem((new CScriptTag('ldap_test_edit_popup.init();'))->setOnDocumentReady()); // Enable form submitting on Enter. $form->addItem((new CSubmitButton())->addClass(ZBX_STYLE_FORM_SUBMIT_HIDDEN)); foreach ($data['ldap_config'] as $field => $value) { $form->addVar($field, $value); } $output = [ 'header' => _('Test authentication'), 'body' => $form->toString(), 'buttons' => [ [ 'title' => _('Test'), 'keepOpen' => true, 'isSubmit' => true, 'action' => 'ldap_test_edit_popup.submit();' ] ], 'script_inline' => $this->readJsFile('popup.ldap.test.edit.js.php') ]; if ($data['user']['debug_mode'] == GROUP_DEBUG_MODE_ENABLED) { CProfiler::getInstance()->stop(); $output['debug'] = CProfiler::getInstance()->make()->toString(); } echo json_encode($output);