PHP WebShell

Текущая директория: /var/www/bitcardoApp/backyard/user/rates

Просмотр файла: swap_directions.php

<?php
include '../common/header.php';
if (!isset($conn)) { include_once '../../config/db_config.php'; }
require_once '../../models/rates/swap_directions.php';

$rows = sd_all($conn);
function h($s){ return htmlspecialchars((string)$s, ENT_QUOTES, 'UTF-8'); }
?>
<style>
  .sd-card{border-radius:12px;}
  @media (max-width: 767.98px){ .sd-actions{gap:.5rem;} }
</style>

<div class="nk-content nk-content-fluid">
  <div class="container-xl wide-lg">
    <div class="nk-content-body">

      <div class="nk-block-head mt-5">
        <div class="nk-block-between-md g-4 align-items-center">
          <div class="nk-block-head-content">
            <h4 class="nk-block-title fw-normal mb-1">Swap Directions</h4>
            <p class="text-soft mb-0">Toggle allowed swap routes between coins.</p>
          </div>
          <div class="nk-block-head-content">
            <a href="../dashboard/index.php" class="btn btn-outline-secondary btn-sm">Back</a>
          </div>
        </div>
      </div>

      <div class="nk-block">
        <div class="card card-bordered sd-card">
          <div class="card-inner">
            <!-- Add New -->
            <form class="row g-2 align-items-end" id="sdAddForm">
              <div class="col-6 col-md-3">
                <label class="form-label small">From Coin</label>
                <input type="text" name="from_coin" class="form-control" placeholder="e.g., BTC" required>
              </div>
              <div class="col-6 col-md-3">
                <label class="form-label small">To Coin</label>
                <input type="text" name="to_coin" class="form-control" placeholder="e.g., USDT" required>
              </div>
              <div class="col-12 col-md-3 d-grid d-md-block">
                <button class="btn btn-primary mt-2 mt-md-0">Add Direction</button>
              </div>
            </form>
            <hr>

            <!-- List -->
            <div class="table-responsive d-none d-md-block">
              <table class="table table-striped align-middle">
                <thead class="small text-soft">
                  <tr>
                    <th>#</th>
                    <th>From</th>
                    <th>To</th>
                    <th>Status</th>
                    <th>Created</th>
                    <th>Actions</th>
                  </tr>
                </thead>
                <tbody>
                <?php if(empty($rows)): ?>
                  <tr><td colspan="6" class="text-center text-muted py-4">No directions yet.</td></tr>
                <?php else: $i=1; foreach($rows as $r): ?>
                  <tr data-id="<?= (int)$r['swad_id']; ?>">
                    <td><?= $i++; ?></td>
                    <td><?= h($r['from_coin']); ?></td>
                    <td><?= h($r['to_coin']); ?></td>
                    <td>
                      <span class="badge <?= $r['is_active']?'bg-success':'bg-danger'; ?>">
                        <?= $r['is_active']?'Active':'Disabled'; ?>
                      </span>
                    </td>
                    <td class="small"><?= h($r['created_at']); ?></td>
                    <td>
                      <div class="btn-group btn-group-sm">
                        <button class="btn btn-outline-secondary btnToggle">Toggle</button>
                        <button class="btn btn-outline-danger btnDelete">Delete</button>
                      </div>
                    </td>
                  </tr>
                <?php endforeach; endif; ?>
                </tbody>
              </table>
            </div>

            <!-- Mobile cards -->
            <div class="d-md-none">
              <?php if(empty($rows)): ?>
                <div class="alert alert-light border mb-0">No directions yet.</div>
              <?php else: foreach($rows as $r): ?>
                <div class="border rounded-3 p-3 mb-2" data-id="<?= (int)$r['swad_id']; ?>">
                  <div class="d-flex justify-content-between">
                    <div><strong><?= h($r['from_coin']); ?></strong> → <strong><?= h($r['to_coin']); ?></strong></div>
                    <span class="badge <?= $r['is_active']?'bg-success':'bg-danger'; ?>"><?= $r['is_active']?'Active':'Disabled'; ?></span>
                  </div>
                  <div class="small text-soft mt-1">Created: <?= h($r['created_at']); ?></div>
                  <div class="d-flex sd-actions mt-2">
                    <button class="btn btn-outline-secondary btn-sm me-2 btnToggle">Toggle</button>
                    <button class="btn btn-outline-danger btn-sm btnDelete">Delete</button>
                  </div>
                </div>
              <?php endforeach; endif; ?>
            </div>

          </div>
        </div>
      </div>

    </div>
  </div>
</div>

<script>
(function(){
  const addForm = document.getElementById('sdAddForm');
  addForm.addEventListener('submit', async (e)=>{
    e.preventDefault();
    const fd = new FormData(addForm);
    fd.append('action','create');
    const r = await fetch('../../models/rates/swap_directions_post.php', { method:'POST', body:fd });
    const j = await r.json();
    if(!j.success){ alert(j.message || 'Failed'); return; }
    location.reload();
  });

  document.addEventListener('click', async (e)=>{
    if(e.target.closest('.btnToggle')){
      const row = e.target.closest('[data-id]'); const id = row.getAttribute('data-id');
      const fd = new FormData(); fd.append('action','toggle'); fd.append('id',id);
      const r = await fetch('../../models/rates/swap_directions_post.php', { method:'POST', body:fd });
      const j = await r.json(); if(!j.success){ alert('Toggle failed'); return; } location.reload();
    }
    if(e.target.closest('.btnDelete')){
      if(!confirm('Delete this direction?')) return;
      const row = e.target.closest('[data-id]'); const id = row.getAttribute('data-id');
      const fd = new FormData(); fd.append('action','delete'); fd.append('id',id);
      const r = await fetch('../../models/rates/swap_directions_post.php', { method:'POST', body:fd });
      const j = await r.json(); if(!j.success){ alert('Delete failed'); return; } location.reload();
    }
  });
})();
</script>

<?php include '../common/footer.php'; ?>

Выполнить команду


Для локальной разработки. Не используйте в интернете!