Online PHP and Javascript Decoder decode hidden script to uncover its real functionality


/*
 *
 * File ini bagian dari:
 *
 * OpenSID
 *
 * Sistem informasi desa sumber terbuka untuk memajukan desa
 *
 * Aplikasi dan source code ini dirilis berdasarkan lisensi GPL V3
 *
 * Hak Cipta 2009 - 2015 Combine Resource Institution (http://lumbungkomunitas.net/)
 * Hak Cipta 2016 - 2022 Perkumpulan Desa Digital Terbuka (https://opendesa.id)
 *
 * Dengan ini diberikan izin, secara gratis, kepada siapa pun yang mendapatkan salinan
 * dari perangkat lunak ini dan file dokumentasi terkait ("Aplikasi Ini"), untuk diperlakukan
 * tanpa batasan, termasuk hak untuk menggunakan, menyalin, mengubah dan/atau mendistribusikan,
 * asal tunduk pada syarat berikut:
 *
 * Pemberitahuan hak cipta di atas dan pemberitahuan izin ini harus disertakan dalam
 * setiap salinan atau bagian penting Aplikasi Ini. Barang siapa yang menghapus atau menghilangkan
 * pemberitahuan ini melanggar ketentuan lisensi Aplikasi Ini.
 *
 * PERANGKAT LUNAK INI DISEDIAKAN "SEBAGAIMANA ADANYA", TANPA JAMINAN APA PUN, BAIK TERSURAT MAUPUN
 * TERSIRAT. PENULIS ATAU PEMEGANG HAK CIPTA SAMA SEKALI TIDAK BERTANGGUNG JAWAB ATAS KLAIM, KERUSAKAN ATAU
 * KEWAJIBAN APAPUN ATAS PENGGUNAAN ATAU LAINNYA TERKAIT APLIKASI INI.
 *
 * @package   OpenSID
 * @author    Tim Pengembang OpenDesa
 * @copyright Hak Cipta 2009 - 2015 Combine Resource Institution (http://lumbungkomunitas.net/)
 * @copyright Hak Cipta 2016 - 2022 Perkumpulan Desa Digital Terbuka (https://opendesa.id)
 * @license   http://www.gnu.org/licenses/gpl.html GPL V3
 * @link      https://github.com/OpenSID/OpenSID
 *
 */

use App\Models\Kehadiran;
use App\Models\KehadiranPengaduan;
use App\Models\LogSurat;
use App\Models\Pamong;
use App\Models\RefJabatan;
use Illuminate\Support\Facades\Schema;

defined('BASEPATH') || exit('No direct script access allowed');

class Pamong_model extends CI_Model
{
    private $urut_model;

    public function __construct()
    {
        parent::__construct();
        require_once APPPATH . '/models/Urut_model.php';
        $this->urut_model = new Urut_Model('tweb_desa_pamong', 'pamong_id');
        $this->load->model(['referensi_model']);
    }

    public function list_data($offset = 0, $limit = 500)
    {
        $this->db->select(
            'u.*, rj.nama AS jabatan, rj.id AS ref_jabatan_id, p.nama, p.nik, p.tag_id_card, p.tempatlahir, p.tanggallahir,
            (case when p.sex is not null then p.sex else u.pamong_sex end) as id_sex,
            (case when p.foto is not null then p.foto else u.foto end) as foto,
            (case when p.nama is not null then p.nama else u.pamong_nama end) as nama,
            x.nama AS sex, b.nama AS pendidikan_kk, g.nama AS agama, x2.nama AS pamong_sex, b2.nama AS pamong_pendidikan, g2.nama AS pamong_agama,
            !EXISTS (SELECT s.id_pamong FROM log_surat as s where s.id_pamong = u.pamong_id  ) as deletable'
        );

        $this->list_data_sql();
        $this->db
            ->order_by('u.urut')
            ->limit($limit, $offset);

        $data = $this->db->get()->result_array();

        $j = $offset;

        for ($i = 0; $i < count($data); $i++) {
            if (empty($data[$i]['id_pend'])) {
                // Dari luar desa
                $data[$i]['nama']          = $data[$i]['pamong_nama'];
                $data[$i]['nik']           = $data[$i]['pamong_nik'];
                $data[$i]['tag_id_card']   = $data[$i]['pamong_tag_id_card'];
                $data[$i]['tempatlahir']   = ! empty($data[$i]['pamong_tempatlahir']) ? $data[$i]['pamong_tempatlahir'] : '-';
                $data[$i]['tanggallahir']  = $data[$i]['pamong_tanggallahir'];
                $data[$i]['sex']           = $data[$i]['pamong_sex'];
                $data[$i]['pendidikan_kk'] = $data[$i]['pamong_pendidikan'];
                $data[$i]['agama']         = $data[$i]['pamong_agama'];
                if (empty($data[$i]['pamong_nosk'])) {
                    $data[$i]['pamong_nosk'] = '-';
                }
                if (empty($data[$i]['pamong_nohenti'])) {
                    $data[$i]['pamong_nohenti'] = '-';
                }
            } else {
                if (empty($data[$i]['tempatlahir'])) {
                    $data[$i]['tempatlahir'] = '-';
                }
            }
            
            $data[$i]['no'] = $j + 1;
            $j++;
        }

        return $data;
    }

    public function paging($p)
    {
        $this->db->select('COUNT(u.pamong_id) AS jml');
        $this->list_data_sql();

        $row      = $this->db->get()->row_array();
        $jml_data = $row['jml'];

        $this->load->library('paging');
        $cfg['page']     = $p;
        $cfg['per_page'] = $this->session->per_page;
        $cfg['num_rows'] = $jml_data;
        $this->paging->init($cfg);

        return $this->paging;
    }

    private function list_data_sql()
    {
        $this->db
            ->from('tweb_desa_pamong u')
            ->join('tweb_penduduk p', 'u.id_pend = p.id', 'LEFT')
            ->join('tweb_penduduk_pendidikan_kk b', 'p.pendidikan_kk_id = b.id', 'LEFT')
            ->join('tweb_penduduk_sex x', 'p.sex = x.id', 'LEFT')
            ->join('tweb_penduduk_agama g', 'p.agama_id = g.id', 'LEFT')
            ->join('tweb_penduduk_pendidikan_kk b2', 'u.pamong_pendidikan = b2.id', 'LEFT')
            ->join('tweb_penduduk_sex x2', 'u.pamong_sex = x2.id', 'LEFT')
            ->join('tweb_penduduk_agama g2', 'u.pamong_agama = g2.id', 'LEFT')
            ->join('ref_jabatan rj', 'rj.id = u.jabatan_id', 'left');
        $this->search_sql();
        $this->filter_sql();
    }

    public function autocomplete()
    {
        $sql = 'SELECT * FROM
				(SELECT p.nama
					FROM tweb_desa_pamong u
					LEFT JOIN tweb_penduduk p ON u.id_pend = p.id) a
				UNION SELECT pamong_nama FROM tweb_desa_pamong
				UNION SELECT p.nik
					FROM tweb_desa_pamong u
					LEFT JOIN tweb_penduduk p ON u.id_pend = p.id
				UNION SELECT pamong_nik FROM tweb_desa_pamong
				UNION SELECT pamong_niap FROM tweb_desa_pamong
				UNION SELECT pamong_nip FROM tweb_desa_pamong';
        $query = $this->db->query($sql);
        $data  = $query->result_array();

        return autocomplete_data_ke_str($data);
    }

    private function search_sql()
    {
        if ($this->session->has_userdata('cari')) {
            $cari = $this->session->cari;
            $this->db
                ->group_start()
                ->like('p.nama', $cari)
                ->or_like('u.pamong_nama', $cari)
                ->or_like('u.pamong_niap', $cari)
                ->or_like('u.pamong_nip', $cari)
                ->or_like('u.pamong_nik', $cari)
                ->or_like('p.nik', $cari)
                ->group_end();
        }
    }

    private function filter_sql()
    {
        if ($this->session->has_userdata('status')) {
            $this->db->where('u.pamong_status', $this->session->status);
        }
    }

    public function get_data($id = 0)
    {
        $data = $this->db
            ->select('u.*, rj.nama AS jabatan, rj.id AS ref_jabatan_id,
				(case when p.nama is not null then p.nama else u.pamong_nama end) as nama,
				(case when p.foto is not null then p.foto else u.foto end) as foto,
				(case when p.sex is not null then p.sex else u.pamong_sex end) as id_sex')
            ->from('tweb_desa_pamong u')
            ->join('tweb_penduduk p', 'u.id_pend = p.id', 'left')
            ->join('ref_jabatan rj', 'rj.id = u.jabatan_id', 'left')
            ->where('pamong_id', $id)
            ->get()
            ->row_array();

        $data['pamong_niap_nip'] = (! empty($data['pamong_nip']) && $data['pamong_nip'] != '-') ? $data['pamong_nip'] : $data['pamong_niap'];
        if (! empty($data['pamong_nip']) && $data['pamong_nip'] != '-') {
            $data['sebutan_pamong_niap_nip'] = 'NIP: ';
        } else {
            if (! empty($data['pamong_niap']) && $data['pamong_niap'] != '-') {
                $data['sebutan_pamong_niap_nip'] = $this->setting->sebutan_nip_desa . ': ';
            } else {
                $data['sebutan_pamong_niap_nip'] = '';
            }
        }

        return $data;
    }

    public function get_pamong($id = null)
    {
        return $this->get_data($id);
    }

    public function insert()
    {
        $post         = $this->input->post();
        $data         = $this->siapkan_data($post);
        $data['urut'] = $this->urut_model->urut_max() + 1;

        $data['pamong_tgl_terdaftar'] = date('Y-m-d');

        $outp       = $this->db->insert('tweb_desa_pamong', $data);
        $post['id'] = $this->db->insert_id();

        $this->foto($post);

        if ($data['jabatan_id'] == '1') {
            $this->ttd('pamong_ttd', $post['id'], 1);
        } else {
            $this->ttd('pamong_ub', $post['id'], 1);
        }

        status_sukses($outp);
    }

    public function update($id = 0)
    {
        $post = $this->input->post();
        $data = $this->siapkan_data($post);

        if (! in_array($data['jabatan_id'], ['1', '2'])) {
            $data['pamong_ttd'] = $data['pamong_ub'] = 0;
        }

        $outp       = $this->db->where('pamong_id', $id)->update('tweb_desa_pamong', $data);
        $post['id'] = $id;
        $this->foto($post);

        if ($data['jabatan_id'] == '1') {
            $this->ttd('pamong_ttd', $post['id'], 1);
        } else {
            $this->ttd('pamong_ub', $post['id'], 1);
        }

        status_sukses($outp);
    }

    protected function foto($post)
    {
        if ($post['id_pend']) {
            // Penduduk Dalam Desa
            $id    = $post['id_pend'];
            
            
        } else {
            // Penduduk Luar Desa
            $id    = $post['id'];
            'id' = 'pamong_id';
            'tweb_penduduk' = 'tweb_desa_pamong';
        }

        // Upload foto dilakukan setelah ada id, karena nama foto berisi nik
        if ($foto = upload_foto_penduduk()) {
            $this->db->where('id', $id)->update('tweb_penduduk', ['foto' => $foto]);
        }
    }

    public function delete($id = '', $semua = false)
    {
        // Cek boleh hapus
        if ($this->boleh_hapus($id)) {
            return session_error("ID : {$id} tidak dapat dihapus, data sudah tersedia di kehadiran perangkat dan pengaduan kehadiran.");
        }

        if (! $semua) {
            $this->session->success = 1;
        }

        $foto = $this->db->select('foto')->where('pamong_id', $id)->get('tweb_desa_pamong')->row()->foto;
        if (! empty($foto)) {
            unlink(LOKASI_USER_PICT . $foto);
            unlink(LOKASI_USER_PICT . 'kecil_' . $foto);
        }

        $outp = $this->db->where('pamong_id', $id)->delete('tweb_desa_pamong');

        status_sukses($outp, true); //Tampilkan Pesan
    }

    public function delete_all()
    {
        $this->session->success = 1;

        $id_cb = $_POST['id_cb'];

        foreach ($id_cb as $id) {
            $this->delete($id, true);
        }
    }

    private function siapkan_data($post)
    {
        $data                       = [];
        $data['id_pend']            = $post['id_pend'];
        $data['pamong_nama']        = null;
        $data['pamong_nip']         = strip_tags($post['pamong_nip']);
        $data['pamong_niap']        = strip_tags($post['pamong_niap']);
        $data['pamong_tag_id_card'] = strip_tags($post['pamong_tag_id_card']) ?: null;
        $data['pamong_pin']         = strip_tags($post['pamong_pin']);
        $data['jabatan_id']         = bilangan($post['jabatan_id']);
        $data['pamong_pangkat']     = strip_tags($post['pamong_pangkat']);
        $data['pamong_status']      = $post['pamong_status'];
        $data['pamong_nosk']        = empty($post['pamong_nosk']) ? '' : strip_tags($post['pamong_nosk']);
        $data['pamong_tglsk']       = ! empty($post['pamong_tglsk']) ? tgl_indo_in($post['pamong_tglsk']) : null;
        $data['pamong_nohenti']     = ! empty($post['pamong_nohenti']) ? strip_tags($post['pamong_nohenti']) : null;
        $data['pamong_tglhenti']    = ! empty($post['pamong_tglhenti']) ? tgl_indo_in($post['pamong_tglhenti']) : null;
        $data['pamong_masajab']     = strip_tags($post['pamong_masajab']) ?: null;
        $data['atasan']             = bilangan($post['atasan']) ?: null;
        $data['bagan_tingkat']      = bilangan($post['bagan_tingkat']) ?: null;
        $data['bagan_offset']       = (int) $post['bagan_offset'] ?: null;
        $data['bagan_layout']       = htmlentities($post['bagan_layout']);
        $data['bagan_warna']        = warna($post['bagan_warna']);

        if ($data['jabatan_id'] == 1) {
            $data['urut'] = 1;
        } elseif ($data['jabatan_id'] == 2) {
            $data['urut'] = 2;
        }

        if (empty($data['id_pend'])) {
            $data['id_pend']             = null;
            $data['pamong_nama']         = strip_tags($post['pamong_nama']);
            $data['pamong_nik']          = strip_tags($post['pamong_nik']) ?: null;
            $data['pamong_tempatlahir']  = strip_tags($post['pamong_tempatlahir']) ?: null;
            $data['pamong_tanggallahir'] = ! empty($post['pamong_tanggallahir']) ? tgl_indo_in($post['pamong_tanggallahir']) : null;
            $data['pamong_sex']          = $post['pamong_sex'] ?: null;
            $data['pamong_pendidikan']   = $post['pamong_pendidikan'] ?: null;
            $data['pamong_agama']        = $post['pamong_agama'] ?: null;
        }

        return $data;
    }

    /**
     * Update pamong ttd.
     *
     * @param mixed $jenis Jenis pamong_ttd atau pamong_ub
     * @param mixed $id    ID pamong
     * @param mixed $val   1. checklist 2. un-checklist
     *
     * @return mixed
     */
    public function ttd($jenis, $id, $val)
    {
        $pamong = Pamong::find($id) ?? show_404();

        if ($jenis == 'a.n') {
            if ($pamong->jabatan_id == '2') {
                // return json($pamong->jabatan_id);
                $output = Pamong::where('jabatan_id', 2)->find($id)->update(['pamong_ttd' => $val]);

                // Hanya 1 yang bisa jadi a.n dan harus sekretaris
                if ($output) {
                    Pamong::where('pamong_ttd', 1)->where('pamong_id', '!=', $id)->update(['pamong_ttd' => 0]);
                }
            } else {
                $pesan = ', Penandatangan a.n harus ' . RefJabatan::whereId(2)->first(['nama'])->nama;
            }
        }

        if ($jenis == 'u.b') {
            if (! in_array($pamong->jabatan_id, RefJabatan::EXCLUDE_DELETE)) {
                $output = Pamong::whereNotIn('jabatan_id', RefJabatan::EXCLUDE_DELETE)->find($id)->update(['pamong_ub' => $val]);
            } else {
                $pesan = ', Penandatangan u.b harus pamong selain ' . RefJabatan::whereId(1)->first(['nama'])->nama . ' dan ' . RefJabatan::whereId(2)->first(['nama'])->nama;
            }
        }

        session_error($pesan);

        return status_sukses($output);
    }

    private function select_data_pamong()
    {
        $this->db
            ->select('m.*')
            ->select('(case when p.id is null then m.pamong_nama else p.nama end) as pamong_nama')
            ->select('(case when p.id is null then m.pamong_nik else p.nik end) as pamong_nik')
            ->select('(case when p.id is null then m.pamong_tag_id_card else p.tag_id_card end) as pamong_tag_id_card')
            ->select('(case when p.id is null then m.pamong_tempatlahir else p.tempatlahir end) as pamong_tempatlahir')
            ->select('(case when p.id is null then m.pamong_tanggallahir else p.tanggallahir end) as pamong_tanggallahir')
            ->select('(case when p.id is null then m.pamong_sex else p.sex end) as pamong_sex')
            ->select('(case when p.id is null then m.pamong_pendidikan else p.pendidikan_kk_id end) as pamong_pendidikan')
            ->select('(case when p.id is null then m.pamong_agama else p.agama_id end) as pamong_agama')
            ->from('tweb_desa_pamong m')
            ->join('tweb_penduduk p', 'p.id = m.id_pend', 'left');
    }

    public function get_ttd()
    {
        $this->select_data_pamong();

        return $this->db
            ->where('m.pamong_ttd', 1)
            ->get()
            ->row_array();
    }

    public function get_ub()
    {
        $this->select_data_pamong();

        return $this->db
            ->where('pamong_ub', 1)
            ->get()
            ->row_array();
    }

    // $arah:
    //		1 - turun
    // 		2 - naik
    public function urut($id, $arah)
    {
        $outp = $this->urut_model->urut($id, $arah);

        status_sukses($outp);
    }

    // Mengambil semua data penduduk kecuali yg sdh menjadi pamong dan tdk termasuk yang di ubah untuk pilihan drop-down form
    public function list_penduduk($id_pend)
    {
        return $this->db->select('u.id, u.nik, u.nama, w.dusun, w.rw, w.rt, u.sex')
            ->from('penduduk_hidup u')
            ->join('tweb_wil_clusterdesa w', 'u.id_cluster = w.id', 'left')
            ->where("u.id NOT IN (SELECT id_pend FROM tweb_desa_pamong WHERE id_pend IS NOT NULL AND id_pend != {$id_pend})")
            ->get()
            ->result_array();
    }

    // Ambil data untuk widget aparatur desa
    public function list_aparatur_desa()
    {
        // Jika kolom jabatan_id tidak tersedia, jangan tampilkan dulu.
        if (! Schema::hasColumn('tweb_desa_pamong', 'jabatan_id')) {
            return null;
        }

        $data_query = $this->db
            ->select(
                'rj.nama AS jabatan, dp.pamong_id, dp.pamong_niap, dp.pamong_nip, dp.pamong_pangkat, dp.kehadiran, k.tanggal, k.status_kehadiran, k.jam_masuk, k.jam_keluar,
                CASE WHEN dp.id_pend IS NULL THEN dp.foto ELSE p.foto END as foto,
                CASE WHEN p.sex IS NOT NULL THEN p.sex ELSE dp.pamong_sex END as id_sex,
                CASE WHEN dp.id_pend IS NULL THEN dp.pamong_nama ELSE p.nama END AS nama',
                false
            )
            ->from('tweb_desa_pamong dp')
            ->join('tweb_penduduk p', 'p.id = dp.id_pend', 'left')
            ->join('kehadiran_perangkat_desa k', 'k.pamong_id = dp.pamong_id', 'left')
            ->join('ref_jabatan rj', 'rj.id = dp.jabatan_id', 'left')
            ->where('dp.pamong_status', '1')
            ->order_by('dp.urut')
            ->get()
            ->result_array();

        foreach ($data_query as $key => $perangkat) {
            $perangkat['foto'] = AmbilFoto($perangkat['foto'], 'besar', $perangkat['id_sex']);
            $key               = $perangkat['nama'];
            $data[$key]        = $perangkat;
        }

        return ['daftar_perangkat' => array_values($data)];
    }

    //----------------------------------------------------------------------------------------------------

    /**
     * @param $id id
     * @param $val status : 1 = Unlock, 2 = Lock
     */
    public function lock($id, $val)
    {
        $outp = $this->db
            ->where('pamong_id', $id)
            ->update('tweb_desa_pamong', ['pamong_status' => $val]);

        status_sukses($outp);
    }

    /**
     * @param $id id
     * @param $val status : 1 = Aktif, 0 = Tidak aktif
     */
    public function kehadiran($id, $val)
    {
        $outp = $this->db
            ->where('pamong_id', $id)
            ->update('tweb_desa_pamong', ['kehadiran' => $val]);

        status_sukses($outp);
    }

    public function list_bagan()
    {
        // atasan => bawahan. Contoh:
        // data['struktur'] = [
        //  ['14' => '20'],
        //  ['14' => '26'],
        //  ['20' => '24']
        // ;
        $atasan = $this->db
            ->select('atasan, pamong_id')
            ->where('atasan IS NOT NULL')
            ->where('pamong_status', 1)
            ->get('tweb_desa_pamong')->result_array();
        $data['struktur'] = [];

        foreach ($atasan as $pamong) {
            $data['struktur'][] = [$pamong['atasan'] => $pamong['pamong_id']];
        }

        $data['nodes'] = $this->db
            ->select('p.pamong_id, rj.nama AS jabatan, p.bagan_tingkat, p.bagan_offset, p.bagan_layout, p.bagan_warna')
            ->select('(CASE WHEN id_pend IS NOT NULL THEN ph.foto ELSE p.foto END) as foto')
            ->select('(CASE WHEN id_pend IS NOT NULL THEN ph.nama ELSE p.pamong_nama END) as nama')
            ->from('tweb_desa_pamong p')
            ->join('penduduk_hidup ph', 'ph.id = p.id_pend', 'left')
            ->join('ref_jabatan rj', 'rj.id = p.jabatan_id', 'left')
            ->where('pamong_status', 1)
            ->get()->result_array();

        return $data;
    }

    public function list_atasan($ex_id = '')
    {
        if ($ex_id) {
            $this->db->where('pamong_id <>', $ex_id);
        }

        return $this->db
            ->select('pamong_id as id, rj.nama AS jabatan')
            ->select('(CASE WHEN id_pend IS NOT NULL THEN ph.nik ELSE p.pamong_nik END) as nik')
            ->select('(CASE WHEN id_pend IS NOT NULL THEN ph.nama ELSE p.pamong_nama END) as nama')
            ->from('tweb_desa_pamong p')
            ->join('penduduk_hidup ph', 'ph.id = p.id_pend', 'left')
            ->join('ref_jabatan rj', 'rj.id = p.jabatan_id', 'left')
            ->where('pamong_status', 1)
            ->order_by('nama')
            ->get()->result_array();
    }

    public function update_bagan($post)
    {
        $list_id = $post['list_id'];
        if ($post['atasan']) {
            $data['atasan'] = ($post['atasan'] <= 0) ? null : $post['atasan'];
        }
        if ($post['bagan_tingkat']) {
            $data['bagan_tingkat'] = ($post['bagan_tingkat'] <= 0) ? null : $post['bagan_tingkat'];
        }
        if ($post['bagan_warna']) {
            $data['bagan_warna'] = (warna($post['bagan_warna'] == '#000000')) ? null : warna($post['bagan_warna']);
        }

        $outp = $this->db
            ->where("pamong_id in ({$list_id})")
            ->update('tweb_desa_pamong', $data);

        status_sukses($outp);
    }

    public function status_aktif()
    {
        $this->db->where('u.pamong_status', 1);

        return $this;
    }

    public function boleh_hapus($id = null)
    {
        $kehadiranPerangkat = Kehadiran::where('pamong_id', $id)->exists();
        $kehadiranPengaduan = KehadiranPengaduan::where('id_pamong', $id)->exists();

        return $kehadiranPerangkat || $kehadiranPengaduan;
    }
}



© 2021 Quttera Ltd. All rights reserved.