MOON
Server: Apache
System: Linux 101-53-147-124.cprapid.com 4.18.0-553.121.1.el8_10.x86_64 #1 SMP Thu Apr 30 09:06:34 EDT 2026 x86_64
User: clientsoftwares (1005)
PHP: 8.2.30
Disabled: show_source, system, shell_exec, passthru, exec, popen, proc_open
Upload Files
File: /home/clientsoftwares/www/multi-school.clientsoftwares.com/application/models/Transport_model.php
<?php
if (!defined('BASEPATH')) {
    exit('No direct script access allowed');
}

class Transport_model extends MY_Model
{

    public function __construct()
    {
        parent::__construct();
    }

    public function route_save($data)
    {
        $arraRoute = array(
            'name' => $data['route_name'],
            'start_place' => $data['start_place'],
            'stop_place' => $data['stop_place'],
            'remarks' => $data['remarks'],
            'branch_id' => $this->application_model->get_branch_id(),
        );
        if (!isset($data['route_id'])) {
            $this->db->insert('transport_route', $arraRoute);
        } else {
            $this->db->where('id', $data['route_id']);
            $this->db->update('transport_route', $arraRoute);
        }
        if ($this->db->affected_rows() > 0) {
            return true;
        } else {
            return false;
        }
    }

    public function vehicle_save($data)
    {
        $arraVehicle = array(
            'vehicle_no' => $data['vehicle_no'],
            'capacity' => $data['capacity'],
            'insurance_renewal' => $data['insurance_renewal'],
            'driver_name' => $data['driver_name'],
            'driver_phone' => $data['driver_phone'],
            'driver_license' => $data['driver_license'],
            'branch_id' => $this->application_model->get_branch_id(),
        );
        if (!isset($data['vehicle_id'])) {
            $this->db->insert('transport_vehicle', $arraVehicle);
        } else {
            $this->db->where('id', $data['vehicle_id']);
            $this->db->update('transport_vehicle', $arraVehicle);
        }
        if ($this->db->affected_rows() > 0) {
            return true;
        } else {
            return false;
        }
    }

    public function stoppage_save($data)
    {
        $arraStoppage = array(
            'stop_position' => $data['stop_position'],
            'stop_time' => date("H:i", strtotime($data['stop_time'])),
            'route_fare' => $data['route_fare'],
            'branch_id' => $this->application_model->get_branch_id(),
        );
        if (!isset($data['stoppage_id'])) {
            $this->db->insert('transport_stoppage', $arraStoppage);
        } else {
            $this->db->where('id', $data['stoppage_id']);
            $this->db->update('transport_stoppage', $arraStoppage);
        }
        if ($this->db->affected_rows() > 0) {
            return true;
        } else {
            return false;
        }
    }

    // allocation report with student name
    public function allocation_report($classID, $sectionID, $branchID)
    {
        $this->db->select('ta.*,r.name as route_name,v.vehicle_no,sp.stop_position,sp.stop_time,sp.route_fare,s.first_name,s.last_name,s.register_no,e.id as enroll_id');
        $this->db->from('transport_assign as ta');
        $this->db->join('transport_route as r', 'r.id = ta.route_id', 'left');
        $this->db->join('transport_vehicle as v', 'v.id = ta.vehicle_id', 'left');
        $this->db->join('transport_stoppage as sp', 'sp.id = ta.stoppage_id', 'left');
        $this->db->join('student as s', 's.route_id = ta.route_id AND s.vehicle_id = ta.vehicle_id', 'left');
        $this->db->join('enroll as e', 'e.student_id = s.id', 'left');
        $this->db->where('ta.branch_id', $branchID);
        $this->db->where('e.class_id', $classID);
        $this->db->where('e.section_id', $sectionID);
        return $this->db->get()->result_array();
    }

    // get route,vehicle,stoppage assign list
    public function getAssignList($branch_id = '')
    {
        $this->db->select('ta.route_id,ta.stoppage_id,ta.branch_id,r.name,r.start_place,r.stop_place,sp.stop_position,sp.stop_time,sp.route_fare');
        $this->db->from('transport_assign as ta');
        $this->db->join('transport_route as r', 'r.id = ta.route_id', 'left');
        $this->db->join('transport_stoppage as sp', 'sp.id = ta.stoppage_id', 'left');
        $this->db->group_by(array('ta.route_id', 'ta.stoppage_id', 'ta.branch_id'));
        if (!empty($branch_id)) {
            $this->db->where('ta.branch_id', $branch_id);
        }
        return $this->db->get()->result_array();
    }

    public function getAssignEdit($id='')
    {
        if (!is_superadmin_loggedin()) {
            $this->db->where('branch_id', get_loggedin_branch_id());
        }
        $this->db->where('route_id', $id);
        $this->db->limit(1);
        return $this->db->get('transport_assign')->row_array();
    }

    // get vehicle list by route_id
    public function get_vehicle_list($route_id)
    {
        $this->db->select('ta.vehicle_id,v.vehicle_no');
        $this->db->from('transport_assign as ta');
        $this->db->join('transport_vehicle as v', 'v.id = ta.vehicle_id', 'left');
        $this->db->where('ta.route_id', $route_id);
        $vehicles = $this->db->get()->result();
        $name_list = '';
        foreach ($vehicles as $row) {
            $name_list .= '- ' . $row->vehicle_no . '<br>';
        }
        return $name_list;
    }

    // get route information by route id and vehicle id
    public function get_student_route($route_id, $vehicle_id)
    {
        $this->db->select('ta.route_id,ta.stoppage_id,ta.vehicle_id,r.name as route_name,r.start_place,r.stop_place,sp.stop_position,sp.stop_time,sp.route_fare,v.vehicle_no,v.driver_name,v.driver_phone');
        $this->db->from('transport_assign as ta');
        $this->db->join('transport_route as r', 'r.id = ta.route_id', 'left');
        $this->db->join('transport_vehicle as v', 'v.id = ta.vehicle_id', 'left');
        $this->db->join('transport_stoppage as sp', 'sp.id = ta.stoppage_id', 'left');
        $this->db->where('ta.route_id', $route_id);
        $this->db->where('ta.vehicle_id', $vehicle_id);
        return $this->db->get()->row();
    }
}