| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798 | <?phplogger();$hash = $js_minifier->getDataHash();$JSPath = '/tmp/' . $hash . '.js';if(!file_exists($JSPath)) {  $js_minifier->minify($JSPath);  cleanupJS($hash);}$alertbox_log_parser = alertbox_log_parser($_SESSION);$alerts = [];if (is_array($alertbox_log_parser)) {  foreach ($alertbox_log_parser as $log) {    $message = htmlspecialchars($log['msg'], ENT_QUOTES);    $message = strtr($message, ["\n" => '', "\r" => '', "\t" => '<br>']);    $alerts[trim($log['type'], '"')][] = trim($message, '"');  }  $alert = array_filter(array_unique($alerts));  foreach($alert as $alert_type => $alert_msg) {    // html breaks from mysql alerts, replace ` with '    $alerts[$alert_type] = implode('<hr class="alert-hr">', str_replace("`", "'", $alert_msg));  }  unset($_SESSION['return']);}// map tfa details for twig$pending_tfa_authmechs = [];if (array_key_exists('pending_tfa_methods', $_SESSION)) {  foreach($_SESSION['pending_tfa_methods'] as $authdata){    $pending_tfa_authmechs[$authdata['authmech']] = false;  }  if (isset($pending_tfa_authmechs['webauthn'])) {    $pending_tfa_authmechs['webauthn'] = true;  }  if (!isset($pending_tfa_authmechs['webauthn'])       && isset($pending_tfa_authmechs['yubi_otp'])) {    $pending_tfa_authmechs['yubi_otp'] = true;  }  if (!isset($pending_tfa_authmechs['webauthn'])       && !isset($pending_tfa_authmechs['yubi_otp'])      && isset($pending_tfa_authmechs['totp'])) {    $pending_tfa_authmechs['totp'] = true;  }  if (isset($pending_tfa_authmechs['u2f'])) {    $pending_tfa_authmechs['u2f'] = true;  }}// globals$globalVariables = [  'mailcow_info' => array(    'version_tag' => $GLOBALS['MAILCOW_GIT_VERSION'],    'last_version_tag' => $GLOBALS['MAILCOW_LAST_GIT_VERSION'],    'git_owner' => $GLOBALS['MAILCOW_GIT_OWNER'],    'git_repo' => $GLOBALS['MAILCOW_GIT_REPO'],    'git_project_url' => $GLOBALS['MAILCOW_GIT_URL'],    'git_commit' => $GLOBALS['MAILCOW_GIT_COMMIT'],    'git_commit_date' => $GLOBALS['MAILCOW_GIT_COMMIT_DATE'],    'mailcow_branch' => $GLOBALS['MAILCOW_BRANCH'],    'updated_at' => $GLOBALS['MAILCOW_UPDATEDAT']  ),  'js_path' => '/cache/'.basename($JSPath),  'pending_tfa_methods' => @$_SESSION['pending_tfa_methods'],  'pending_tfa_authmechs' => $pending_tfa_authmechs,  'pending_mailcow_cc_username' => @$_SESSION['pending_mailcow_cc_username'],  'lang_footer' => json_encode($lang['footer']),  'lang_acl' => json_encode($lang['acl']),  'lang_tfa' => json_encode($lang['tfa']),  'lang_fido2' => json_encode($lang['fido2']),  'lang_success' => json_encode($lang['success']),  'lang_danger' => json_encode($lang['danger']),  'docker_timeout' => $DOCKER_TIMEOUT,  'session_lifetime' => (int)$SESSION_LIFETIME,  'csrf_token' => $_SESSION['CSRF']['TOKEN'],  'pagination_size' => $PAGINATION_SIZE,  'log_pagination_size' => $LOG_PAGINATION_SIZE,  'alerts' => $alerts,  'totp_secret' => $tfa->createSecret(),];foreach ($globalVariables as $globalVariableName => $globalVariableValue) {  $twig->addGlobal($globalVariableName, $globalVariableValue);}if (is_array($template_data)) {  echo $twig->render($template, $template_data);}if (isset($_SESSION['mailcow_cc_api'])) {  session_regenerate_id(true);  session_unset();  session_destroy();  session_write_close();  header("Location: /");}$stmt = null;$pdo = null;
 |