<?php

/*===============================================*\
|| ############################################# ||
|| # JAKWEB.CH / Version 1.1                   # ||
|| # ----------------------------------------- # ||
|| # Copyright 2020 JAKWEB All Rights Reserved # ||
|| ############################################# ||
\*===============================================*/

// Check if the file is accessed only via index.php if not stop the script from running
if (!defined('JAK_ADMIN_PREVENT_ACCESS')) die('You cannot access this file directly.');

// Check if the user has access to this file
if (!jak_get_access("proactive", $jakuser->getVar("permissions"), JAK_MAIN_OP)) jak_redirect(BASE_URL);

// All the tables we need for this plugin
$errors = array();
$jaktable = 'bot_question';
$jaktable1 = 'departments';
$jaktable2 = 'chatwidget';

// Now start with the plugin use a switch to access all pages
switch ($page1) {

  case 'delete':
     
    // Check if user exists and can be deleted
    if (is_numeric($page2) && jak_row_exist($page2, $opcacheid, $jaktable)) {
            
      // Now check how many languages are installed and do the dirty work
      $result = $jakdb->delete($jaktable, ["AND" => ["id" => $page2, "opid" => $opcacheid]]);
    
      if (!$result) {
          $_SESSION["infomsg"] = $jkl['i'];
          jak_redirect($_SESSION['LCRedirect']);
      } else {
        
        // Now let us delete the user cache file
        $cachestufffile = APP_PATH.JAK_CACHE_DIRECTORY.'/opcache'.$opcacheid.'.php';
        if (file_exists($cachestufffile)) {
          unlink($cachestufffile);
        }

        // Write the log file each time someone tries to login before
              JAK_base::jakWhatslog('', $opcacheid, JAK_USERID, 0, 78, $page2, (isset($_COOKIE['WIOgeoData']) ? $_COOKIE['WIOgeoData'] : ''), $jakuser->getVar("username"), $_SERVER['REQUEST_URI'], $ipa, $valid_agent);
        
          $_SESSION["successmsg"] = $jkl['g14'];
          jak_redirect($_SESSION['LCRedirect']);
      }
        
    } else {
         $_SESSION["errormsg"] = $jkl['i3'];
        jak_redirect($_SESSION['LCRedirect']);
    }
    
  break;
  case 'edit':
  
    // Check if the user exists
    if (is_numeric($page2) && jak_row_exist($page2, $opcacheid, $jaktable)) {
    
      if ($_SERVER['REQUEST_METHOD'] == 'POST') {
        $jkp = $_POST;
    
        if (empty($jkp['question'])) {
            $errors['e'] = $jkl['e26'];
        }
        
        if (empty($jkp['answer']) && $jkp["jak_abid"] == 0) {
            $errors['e1'] = $jkl['e1'];
        }
        
        if (count($errors) == 0) {

          // widget id's
        if (!isset($jkp['jak_widgetid'])) {
          $widg = 0;
        } else {
          $widg = join(',', $jkp['jak_widgetid']);
        }

          $result = $jakdb->update($jaktable, ["widgetids" => $widg,
            "depid" => $jkp['jak_depid'],
          "lang" => $jkp['jak_lang'],
          "question" => strtolower($jkp['question']),
          "answer" => $jkp['answer'],
          "updated" => $jakdb->raw("NOW()")], ["AND" => ["id" => $page2, "opid" => $opcacheid]]);
    
        if (!$result) {
            $_SESSION["infomsg"] = $jkl['i'];
            jak_redirect($_SESSION['LCRedirect']);
        } else {
          
          // Now let us delete the user cache file
          $cachestufffile = APP_PATH.JAK_CACHE_DIRECTORY.'/opcache'.$opcacheid.'.php';
          if (file_exists($cachestufffile)) {
            unlink($cachestufffile);
          }

          // Write the log file each time someone tries to login before
                JAK_base::jakWhatslog('', $opcacheid, JAK_USERID, 0, 76, $page2, (isset($_COOKIE['WIOgeoData']) ? $_COOKIE['WIOgeoData'] : ''), $jakuser->getVar("username"), $_SERVER['REQUEST_URI'], $ipa, $valid_agent);
          
            $_SESSION["successmsg"] = $jkl['g14'];
            jak_redirect($_SESSION['LCRedirect']);
        }
    
      // Output the errors
      } else {
      
          $errors = $errors;
      }
      
      }

      // Get all widgets
      $JAK_WIDGETS = $jakdb->select($jaktable2, ["id", "title"], ["opid" => $opcacheid, "ORDER" => ["title" => "ASC"]]);
    
      // Get all departments
      $JAK_DEPARTMENTS = $jakdb->select($jaktable1, ["id", "title"], ["opid" => $opcacheid, "ORDER" => ["dorder" => "ASC"]]);

      // Call the settings function
      $lang_files = jak_get_lang_files();
    
      $JAK_FORM_DATA = jak_get_data($page2, $opcacheid, $jaktable);
      
      // Title and Description
      $SECTION_TITLE = $jkl["m24"];
      $SECTION_DESC = "";
      
      $template = 'editbot.php';
    
    } else {
        
         $_SESSION["errormsg"] = $jkl['i3'];
        jak_redirect(JAK_rewrite::jakParseurl('bot'));
    }
    
  break;
  default:
    
    if ($_SERVER['REQUEST_METHOD'] == 'POST' && isset($_POST['insert_bot'])) {
        $jkp = $_POST;
        
        if (empty($jkp['question'])) {
                $errors['e'] = $jkl['e26'];
            }
            
            if (empty($jkp['answer']) && $jkp["jak_abid"] == 0) {
                $errors['e1'] = $jkl['e1'];
            }
            
            if (count($errors) == 0) {

              // widget id's
            if (!isset($jkp['jak_widgetid'])) {
              $widg = 0;
            } else {
              $widg = join(',', $jkp['jak_widgetid']);
            }

              $jakdb->insert($jaktable, ["opid" => $opcacheid,
                "widgetids" => $widg,
                "depid" => $jkp['jak_depid'],
            "lang" => $jkp['jak_lang'],
            "question" => strtolower($jkp['question']),
            "answer" => $jkp['answer'],
            "updated" => $jakdb->raw("NOW()"),
            "created" => $jakdb->raw("NOW()")]);

          $lastid = $jakdb->id();
        
            if (!$lastid) {
                $_SESSION["infomsg"] = $jkl['i'];
              jak_redirect($_SESSION['LCRedirect']);
            } else {
              
              // Now let us delete the user cache file
            $cachestufffile = APP_PATH.JAK_CACHE_DIRECTORY.'/opcache'.$opcacheid.'.php';
            if (file_exists($cachestufffile)) {
              unlink($cachestufffile);
            }

            // Write the log file each time someone tries to login before
                  JAK_base::jakWhatslog('', $opcacheid, JAK_USERID, 0, 77, $lastid, (isset($_COOKIE['WIOgeoData']) ? $_COOKIE['WIOgeoData'] : ''), $jakuser->getVar("username"), $_SERVER['REQUEST_URI'], $ipa, $valid_agent);
              
                $_SESSION["successmsg"] = $jkl['g14'];
              jak_redirect($_SESSION['LCRedirect']);
            }
        
        // Output the errors
        } else {
        
            $errors = $errors;
        }
        
   
     }

    // Get all widgets
    $JAK_WIDGETS = $jakdb->select($jaktable2, ["id", "title"], ["opid" => $opcacheid, "ORDER" => ["title" => "ASC"]]);
     
    // Get all departments
    $JAK_DEPARTMENTS = $jakdb->select($jaktable1, ["id", "title"], ["opid" => $opcacheid, "ORDER" => ["dorder" => "ASC"]]);
     
    // Get all bot messages for the chat
    $BOT_ALL = $jakdb->select($jaktable, ["id", "question", "answer"], ["opid" => $opcacheid, "ORDER" => ["id" => "DESC"]]);

    // Call the settings function
    $lang_files = jak_get_lang_files();
     
    // Title and Description
    $SECTION_TITLE = $jkl["m23"];
    $SECTION_DESC = "";
    
    // Include the javascript file for results
    $js_file_footer = 'js_pages.php';
     
    // Call the template
    $template = 'bot.php';
}
?>