conectar_moodle.php 1.2 KB

12345678910111213141516171819202122232425262728
  1. <?php
  2. require_once "{$_SERVER['DOCUMENT_ROOT']}/dependencies.php";
  3. use Respect\Validation\Validator as v;
  4. /* methods(['POST' => v::keySet(
  5. v::key('moodle-host', v::stringType()->notEmpty()),
  6. )]); */
  7. // method must be POST
  8. if (!isset($_SESSION['user'])) {
  9. serverError(title: 'Error de conexión', message: 'No se ha iniciado sesión');
  10. exit();
  11. }
  12. try {
  13. // $db->query("INSERT INTO moodle_host (etiqueta, host, puerto, postgres_user, postgres_dbname, postgres_password, periodos_gema) VALUES (:etiqueta, :host, :puerto, :postgres_user, :postgres_dbname, PGP_SYM_ENCRYPT(:postgres_password, '{$_ENV['KEY_ENCRYPT']}'), :periodos_gema)", $params);
  14. $string_connection = $db->querySingle(
  15. "SELECT CONCAT('pgsql:host=', host, ';port=', puerto, ';dbname=', postgres_dbname, ';user=', postgres_user, ';password=', PGP_SYM_DECRYPT(postgres_password, '{$_ENV['KEY_ENCRYPT']}')) AS connection_string FROM moodle_host WHERE host = :host",
  16. ['host' => $_POST['moodle-host']]
  17. )['connection_string'];
  18. $_SESSION['moodle_db'] = $string_connection;
  19. header('Location: /');
  20. } catch (\PDOException $th) {
  21. serverError(title: 'Error de conexión', message: $string_connection);
  22. exit();
  23. }