PNG  IHDR* pHYs+ IDATx]n#; cdLb Ǚ[at¤_:uP}>!Usă cag޿ ֵNu`ݼTâabO7uL&y^wFٝA"l[|ŲHLN밪4*sG3|Dv}?+y߉{OuOAt4Jj.u]Gz*҉sP'VQKbA1u\`& Af;HWj hsO;ogTu uj7S3/QzUr&wS`M$X_L7r2;aE+ώ%vikDA:dR+%KzƉo>eOth$z%: :{WwaQ:wz%4foɹE[9<]#ERINƻv溂E%P1i01 |Jvҗ&{b?9g=^wζXn/lK::90KwrюO\!ջ3uzuGv^;騢wq<Iatv09:tt~hEG`v;3@MNZD.1]L:{ծI3`L(÷ba")Y.iljCɄae#I"1 `3*Bdz>j<fU40⨬%O$3cGt]j%Fߠ_twJ;ABU8vP3uEԑwQ V:h%))LfraqX-ۿX]v-\9I gl8tzX ]ecm)-cgʒ#Uw=Wlێn(0hPP/ӨtQ“&J35 $=]r1{tLuǮ*i0_;NƝ8;-vݏr8+U-kruȕYr0RnC]*ެ(M:]gE;{]tg(#ZJ9y>utRDRMdr9㪩̞zֹb<ģ&wzJM"iI( .ꮅX)Qw:9,i좜\Ԛi7&N0:asϓc];=ΗOӣ APqz93 y $)A*kVHZwBƺnWNaby>XMN*45~ղM6Nvm;A=jֲ.~1}(9`KJ/V F9[=`~[;sRuk]rєT!)iQO)Y$V ی ۤmzWz5IM Zb )ˆC`6 rRa}qNmUfDsWuˤV{ Pݝ'=Kֳbg,UҘVz2ﴻnjNgBb{? ߮tcsͻQuxVCIY۠:(V뺕 ٥2;t`@Fo{Z9`;]wMzU~%UA蛚dI vGq\r82iu +St`cR.6U/M9IENDB` REDROOM
PHP 5.6.40
Preview: AdminController.php Size: 3.21 KB
/home/ankaservis/public_html/app/controllers/AdminController.php

<?php
/**
 * Admin Controller
 */

class AdminController {
    private $view;
    private $db;

    public function __construct() {
        $this->view = new View();
        $this->db = Database::getInstance();
        
        // Admin kontrolü
        if (!$this->isLoggedIn() && !in_array($_SERVER['REQUEST_URI'], ['/admin/login', '/admin/login/check'])) {
            Helper::redirect(Helper::url('/admin/login'));
        }
    }

    public function login() {
        if ($this->isLoggedIn()) {
            Helper::redirect(Helper::url('/admin'));
        }
        
        $this->view->set('page_title', 'Admin Girişi');
        require_once APP_PATH . '/app/views/admin/login.php';
    }

    public function loginCheck() {
        if ($_SERVER['REQUEST_METHOD'] !== 'POST') {
            Helper::redirect(Helper::url('/admin/login'));
        }

        $username = $_POST['username'] ?? '';
        $password = $_POST['password'] ?? '';

        // Varsayılan admin (production'da değiştirin!)
        $adminUsername = 'admin';
        $adminPassword = password_hash('admin123', PASSWORD_DEFAULT); // İlk kurulumda: admin123

        // Veritabanından kontrol et
        $admin = $this->db->fetchOne(
            "SELECT * FROM admins WHERE username = ? AND status = 'active'",
            [$username]
        );

        if ($admin && password_verify($password, $admin['password'])) {
            $_SESSION['admin_id'] = $admin['id'];
            $_SESSION['admin_username'] = $admin['username'];
            Helper::redirect(Helper::url('/admin'));
        } else {
            // Varsayılan admin kontrolü (ilk kurulum için)
            if ($username === $adminUsername && $password === 'admin123') {
                $_SESSION['admin_id'] = 1;
                $_SESSION['admin_username'] = $adminUsername;
                Helper::redirect(Helper::url('/admin'));
            } else {
                $_SESSION['error'] = 'Kullanıcı adı veya şifre hatalı!';
                Helper::redirect(Helper::url('/admin/login'));
            }
        }
    }

    public function index() {
        // İstatistikler
        $stats = [
            'services' => $this->db->fetchOne("SELECT COUNT(*) as total FROM services WHERE status = 'active'")['total'],
            'posts' => $this->db->fetchOne("SELECT COUNT(*) as total FROM posts WHERE status = 'published'")['total'],
            'messages' => $this->db->fetchOne("SELECT COUNT(*) as total FROM contact_messages WHERE status = 'new'")['total'],
            'total_messages' => $this->db->fetchOne("SELECT COUNT(*) as total FROM contact_messages")['total'],
        ];

        // Son mesajlar
        $recent_messages = $this->db->fetchAll(
            "SELECT * FROM contact_messages ORDER BY created_at DESC LIMIT 5"
        );

        $this->view->set('page_title', 'Admin Panel');
        $this->view->set('stats', $stats);
        $this->view->set('recent_messages', $recent_messages);
        require_once APP_PATH . '/app/views/admin/dashboard.php';
    }

    public function logout() {
        session_destroy();
        Helper::redirect(Helper::url('/admin/login'));
    }

    private function isLoggedIn() {
        return isset($_SESSION['admin_id']) && !empty($_SESSION['admin_id']);
    }
}

Directory Contents

Dirs: 0 × Files: 15

Name Size Perms Modified Actions
3.21 KB lrw-r--r-- 2025-12-03 22:37:27
Edit Download
2.89 KB lrw-r--r-- 2025-12-03 22:37:27
Edit Download
3.87 KB lrw-r--r-- 2025-12-03 22:37:27
Edit Download
3.51 KB lrw-r--r-- 2025-12-03 22:37:27
Edit Download
3.34 KB lrw-r--r-- 2025-12-03 22:37:27
Edit Download
2.72 KB lrw-r--r-- 2025-12-03 22:37:27
Edit Download
3.58 KB lrw-r--r-- 2025-12-03 22:37:28
Edit Download
2.35 KB lrw-r--r-- 2025-12-03 22:37:28
Edit Download
1.00 KB lrw-r--r-- 2025-12-03 22:37:28
Edit Download
6.66 KB lrw-r--r-- 2025-12-03 22:37:28
Edit Download
13.56 KB lrw-r--r-- 2025-12-03 22:37:28
Edit Download
1.42 KB lrw-r--r-- 2025-12-03 22:37:28
Edit Download
9.52 KB lrw-r--r-- 2025-12-03 22:37:29
Edit Download
2.87 KB lrw-r--r-- 2025-12-03 22:37:29
Edit Download
4.28 KB lrw-r--r-- 2025-12-03 22:37:29
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).
© 2026 REDROOM — Secure File Manager. All rights reserved. Built with ❤️ & Red Dark UI