File "SchoolDataService.php"
Full Path: /home/trinadezambia/public_html/admin_panel/app/Services/SchoolDataService.php
File size: 31 KB
MIME-type: text/x-php
Charset: utf-8
<?php
namespace App\Services;
use App\Models\School;
use App\Models\SchoolSetting;
use App\Models\SessionYear;
use App\Models\User;
use App\Models\PayrollSetting;
use Artisan as GlobalArtisan;
use Carbon\Carbon;
use Illuminate\Support\Facades\Artisan;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Config;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\File;
use Spatie\Permission\Models\Permission;
use Spatie\Permission\Models\Role;
use Illuminate\Support\Facades\Session;
use Illuminate\Support\Facades\Log;
class SchoolDataService
{
public function preSettingsSetup($schoolData)
{
DB::setDefaultConnection('school');
Config::set('database.connections.school.database', $schoolData->database_name);
DB::purge('school');
DB::connection('school')->reconnect();
DB::setDefaultConnection('school');
$school = School::find($schoolData->id);
if (!$school) {
$school = new School();
}
$school->id = $schoolData->id;
$school->name = $schoolData->name;
$school->address = $schoolData->address;
$school->support_phone = $schoolData->support_phone;
$school->support_email = $schoolData->support_email;
$school->tagline = $schoolData->tagline;
$school->logo = $schoolData->logo;
$school->status = $schoolData->type == "demo" ? 1 : $schoolData->status;
$school->domain = $schoolData->domain;
$school->database_name = $schoolData->database_name;
$school->code = $schoolData->code;
$school->created_at = $schoolData->created_at;
$school->updated_at = $schoolData->updated_at;
$school->save();
$mainUser = DB::connection('mysql')->table('users')->where('id', $schoolData->admin_id)->first();
$user = User::on('school')->find($mainUser->id);
$userRow[] = [
'id' => $mainUser->id,
'first_name' => $mainUser->first_name,
'last_name' => $mainUser->last_name,
'mobile' => $mainUser->mobile,
'email' => $mainUser->email,
'password' => $mainUser->password,
'school_id' => $mainUser->school_id,
'two_factor_enabled' => 0,
'status' => $mainUser->status,
'email_verified_at' => $schoolData->type == "demo" ? Carbon::now() : null,
'created_at' => $mainUser->created_at,
'updated_at' => $mainUser->updated_at,
];
DB::connection('school')
->table('users')
->upsert(
$userRow, // data array
['id'], // unique key to check
[
'first_name',
'last_name',
'mobile',
'email',
'password',
'school_id',
'two_factor_enabled',
'status',
'email_verified_at',
'updated_at'
] // columns to update if exists
);
// if (!$user) {
// $user = User::on('school')->create($userRow);
// }
// DB::connection('school')->table('users')->insert($userRow);
$school = School::find($schoolData->id);
$school->admin_id = $schoolData->admin_id;
$school->save();
// Create Role
$this->createPreSetupRole($schoolData);
// Create Session Year
$sessionYear = SessionYear::updateOrCreate(
[
'name' => Carbon::now()->format('Y'),
'school_id' => $schoolData->id
],
[
'default' => 1,
'start_date' => Carbon::now()->startOfYear()->format('Y-m-d'),
'end_date' => Carbon::now()->endOfYear()->format('Y-m-d'),
]
);
// Add School Setting Data
$schoolSettingData = array(
[
'name' => 'school_name',
'data' => $schoolData->name,
'type' => 'string',
'school_id' => $schoolData->id,
],
[
'name' => 'school_email',
'data' => $schoolData->support_email,
'type' => 'string',
'school_id' => $schoolData->id
],
[
'name' => 'school_phone',
'data' => $schoolData->support_phone,
'type' => 'number',
'school_id' => $schoolData->id
],
[
'name' => 'school_tagline',
'data' => $schoolData->tagline,
'type' => 'string',
'school_id' => $schoolData->id
],
[
'name' => 'school_address',
'data' => $schoolData->address,
'type' => 'string',
'school_id' => $schoolData->id
],
[
'name' => 'session_year',
'data' => $sessionYear->id,
'type' => 'number',
'school_id' => $schoolData->id,
],
[
'name' => 'horizontal_logo',
'data' => '',
'type' => 'file',
'school_id' => $schoolData->id,
],
[
'name' => 'vertical_logo',
'data' => '',
'type' => 'file',
'school_id' => $schoolData->id,
],
[
'name' => 'timetable_start_time',
'data' => '09:00:00',
'type' => 'time',
'school_id' => $schoolData->id,
],
[
'name' => 'timetable_end_time',
'data' => '18:00:00',
'type' => 'time',
'school_id' => $schoolData->id,
],
[
'name' => 'timetable_duration',
'data' => '01:00:00',
'type' => 'time',
'school_id' => $schoolData->id,
],
[
'name' => 'auto_renewal_plan',
'data' => '1',
'type' => 'integer',
'school_id' => $schoolData->id,
],
[
'name' => 'currency_code',
'data' => 'INR',
'type' => 'string',
'school_id' => $schoolData->id,
],
[
'name' => 'currency_symbol',
'data' => '₹',
'type' => 'string',
'school_id' => $schoolData->id,
],
[
'name' => 'date_format',
'data' => 'd-m-Y',
'type' => 'string',
'school_id' => $schoolData->id,
],
[
'name' => 'time_format',
'data' => 'h:i A',
'type' => 'string',
'school_id' => $schoolData->id,
],
[
'name' => 'domain',
'data' => $schoolData->domain ?? '',
'type' => 'string',
'school_id' => $schoolData->id,
],
[
'name' => 'email-template-staff',
'data' => '<p>Dear {full_name},</p> <p>Welcome to {school_name}!</p> <p>We are excited to have you join our team. Below are your registration details to access the {school_name}:</p> <hr> <p><strong>Your Registration Details:</strong></p> <ul> <li><strong>Registration URL:</strong> {url}</li> <li><strong>Code:</strong> {code}</li> <li><strong>Email:</strong> {email}</li> <li><strong>Password:</strong> {password}</li> </ul> <hr> <p><strong>Steps to Complete Your Registration:</strong></p> <ol> <li>Click on the registration URL provided above.</li> <li>Enter your email and password.</li> <li>Follow the on-screen instructions to set up your profile.</li> </ol> <p><strong>Important:</strong></p> <ul> <li>For security reasons, please change your password upon your first login.</li> <li>If you have any questions or need assistance during the registration process, please contact our support team at {support_email} or call {support_contact}.</li> </ul> <p><strong>App Download Links:</strong></p> <ul> <li><strong>Android:</strong> {android_app}</li> <li><strong>iOS:</strong> {ios_app}</li> </ul> <p>We look forward to a successful academic year with you on our team. Thank you for your commitment to excellence in education.</p> <p>Best regards,</p> <p>{school_name}<br>{support_email}<br>{support_contact}<br>{url}</p>',
'type' => 'text',
'school_id' => $schoolData->id
],
[
'name' => 'email-template-parent',
'data' => '<p>Dear {parent_name},</p> <p>We are delighted to welcome {child_name} to {school_name}!</p> <p>As part of our registration process, we have created accounts for both you and your child in our {school_name}. Below are the registration details you will need to access the system, along with links to download our mobile app for your convenience.</p> <hr> <p><strong>Student Credential Details:</strong></p> <ul> <li><strong>Name:</strong> {child_name}</li> <li><strong>Admission No.: </strong>{admission_no}</li> <li><strong>Code:</strong> {code}</li> <li><strong>GR No.:</strong> {grno}</li> <li><strong>Password:</strong> {child_password}</li> </ul> <hr> <p><strong>Parent Credential Details:</strong></p> <ul> <li><strong>Name:</strong> {parent_name}</li> <li><strong>Code:</strong> {code}</li> <li><strong>Email:</strong> {email}</li> <li><strong>Password:</strong> {password}</li> </ul> <hr> <p><strong>App Download Links:</strong></p> <ul> <li><strong>Android:</strong> {android_app}</li> <li><strong>iOS:</strong> {ios_app}</li> </ul> <hr> <p><strong>Steps to Complete the Registration:</strong></p> <ol> <li>Download the school management app using the links above for easier access on your mobile devices.</li> <li>Enter the email and password for either the student or parent account.</li> <li>Follow the on-screen instructions to complete the profile setup.</li> </ol> <p><strong>Important:</strong></p> <ul> <li>For security reasons, please ensure that both the student and parent passwords are changed upon first login.</li> <li>If you encounter any issues during the registration process, please do not hesitate to contact our support team at {support_email} or call {support_contact}.</li> </ul> <p>We look forward to an enriching educational experience for {child_name} at {school_name}. Thank you for entrusting us with your child's education.</p> <p>Best regards,</p> <p>{school_name}<br>{support_email}</p>',
'type' => 'text',
'school_id' => $schoolData->id
],
[
'name' => 'email-template-application-reject',
'data' => '<p>Dear {child_name},</p> <p>We regret to inform you that your application for admission to {school_name} has been rejected. After a thorough review, it was found that your application did not meet certain criteria required for enrollment. Please note that this decision was made based on valid reasons, Unfortunately, all available seats for the requested grade have already been filled.</p> <p>We encourage you to reach out to the admissions office if you have any questions or require further clarification.</p> <p>Thank you for your interest in our school.</p> <p>Sincerely,<br>{school_name}</p> <p>Admissions Team</p>',
'type' => 'text',
'school_id' => $schoolData->id
],
);
SchoolSetting::upsert($schoolSettingData, ["name", "school_id"], ["data", "type"]);
}
public function createPreSetupRole($school)
{
DB::setDefaultConnection('school');
Config::set('database.connections.school.database', $school->database_name);
DB::purge('school');
DB::connection('school')->reconnect();
DB::setDefaultConnection('school');
$this->createPermissions();
$this->createSchoolAdminRole($school);
$schoolAdminUser = User::on('school')->where('id', $school->admin_id)->first();
$user = $schoolAdminUser->setConnection('school');
$user->assignRole('School Admin');
$this->defaultRoles($school);
// Create teacher role
$this->createTeacherRole($school);
$this->createDriverRole($school);
$this->createHelperRole($school);
}
public function defaultRoles($school)
{
Role::updateOrCreate(['name' => 'Guardian', 'school_id' => $school->id, 'custom_role' => 0, 'editable' => 0]);
Role::updateOrCreate(['name' => 'Student', 'school_id' => $school->id, 'custom_role' => 0, 'editable' => 0]);
}
public function createDatabaseMigration($schoolData)
{
$database_name = $schoolData->database_name;
$query = "SELECT SCHEMA_NAME FROM INFORMATION_SCHEMA.SCHEMATA WHERE SCHEMA_NAME = ?";
$db = DB::select($query, [$database_name]);
if (empty($db)) {
DB::statement("CREATE DATABASE {$database_name}");
}
// Artisan::call('migrate:school');
Config::set('database.connections.school.database', $schoolData->database_name);
DB::purge('school');
DB::connection('school')->reconnect();
DB::setDefaultConnection('school');
Artisan::call('migrate', [
'--database' => 'school',
'--path' => 'database/migrations/schools',
'--force' => true,
]);
}
public function createPermissions()
{
$permissions = [
...self::permission('role'),
...self::permission('medium'),
...self::permission('section'),
...self::permission('class'),
...self::permission('class-section'),
...self::permission('subject'),
...self::permission('teacher'),
...self::permission('guardian'),
...self::permission('session-year'),
...self::permission('student'),
...self::permission('timetable'),
...self::permission('attendance'),
...self::permission('holiday'),
...self::permission('announcement'),
...self::permission('slider'),
...self::permission('promote-student'),
...self::permission('language'),
...self::permission('lesson'),
...self::permission('topic'),
...self::permission('schools'),
...self::permission('form-fields'),
...self::permission('grade'),
...self::permission('package'),
...self::permission('addons'),
...self::permission('guidance'),
...self::permission('assign-elective-subject'),
...self::permission('assignment'),
['name' => 'assignment-submission'],
...self::permission('exam'),
...self::permission('exam-timetable'),
['name' => 'exam-upload-marks'],
['name' => 'exam-result'],
['name' => 'exam-result-edit'],
['name' => 'system-setting-manage'],
['name' => 'fcm-setting-create'],
['name' => 'email-setting-create'],
['name' => 'privacy-policy'],
['name' => 'contact-us'],
['name' => 'about-us'],
['name' => 'terms-condition'],
['name' => 'class-teacher'],
['name' => 'student-reset-password'],
['name' => 'reset-password-list'],
['name' => 'student-change-password'],
['name' => 'fees-classes'],
['name' => 'fees-paid'],
['name' => 'fees-config'],
['name' => 'school-setting-manage'],
['name' => 'app-settings'],
['name' => 'subscription-view'],
...self::permission('online-exam'),
...self::permission('online-exam-questions'),
['name' => 'online-exam-result-list'],
...self::permission('fees-type'),
...self::permission('fees-class'),
...self::permission('role'),
...self::permission('staff'),
...self::permission('expense-category'),
...self::permission('expense'),
...self::permission('semester'),
...self::permission('payroll'),
...self::permission('stream'),
...self::permission('shift'),
...self::permission('leave'),
['name' => 'approve-leave'],
...self::permission('faqs'),
['name' => 'fcm-setting-manage'],
...self::permission('fees'),
...self::permission('transfer-student'),
...self::permission('gallery'),
...self::permission('notification'),
['name' => 'payment-settings'],
['name' => 'subscription-settings'],
['name' => 'subscription-change-bills'],
['name' => 'school-terms-condition'],
['name' => 'id-card-settings'],
['name' => 'subscription-bill-payment'],
['name' => 'web-settings'],
...self::permission('certificate'),
...self::permission('payroll-settings'),
['name' => 'school-web-settings'],
...self::permission('class-group'),
['name' => 'email-template'],
['name' => 'database-backup'],
['name' => 'view-exam-marks'],
['name' => 'contact-inquiry-list'],
// Reports
['name' => 'reports-student'],
['name' => 'reports-teacher'],
['name' => 'reports-exam'],
['name' => 'reports-expense'],
...self::permission('student-diary'),
...self::permission('route'),
...self::permission('pickup-points'),
...self::permission('transportation-fees'),
...self::permission('driver-helper'),
...self::permission('vehicles'),
...self::permission('RouteVehicle'),
...self::permission('transportationexpense'),
['name' => 'transportationRequests-create'],
['name' => 'transportationRequests-list'],
['name' => 'transportationRequests-edit'],
['name' => 'transportationRequests-receipt'],
['name' => 'staff-attendance-list'],
['name' => 'staff-attendance-edit'],
...self::permission('syllabus'),
];
$permissions = array_map(static function ($data) {
$data['guard_name'] = 'web';
return $data;
}, $permissions);
Permission::upsert($permissions, ['name'], ['name']);
$permissionNames = array_column($permissions, 'name');
Permission::whereNotIn('name', $permissionNames)->delete();
}
public static function permission($prefix, array $customPermissions = [])
{
$list = [["name" => $prefix . '-list']];
$create = [["name" => $prefix . '-create']];
$edit = [["name" => $prefix . '-edit']];
$delete = [["name" => $prefix . '-delete']];
$finalArray = array_merge($list, $create, $edit, $delete);
foreach ($customPermissions as $customPermission) {
$finalArray[] = ["name" => $prefix . "-" . $customPermission];
}
return $finalArray;
}
public function createSchoolAdminRole($school)
{
$role = Role::withoutGlobalScope('school')->updateOrCreate(['name' => 'School Admin', 'custom_role' => 0, 'editable' => 0, 'school_id' => $school->id]);
$SchoolAdminHasAccessTo = [
'medium-list',
'medium-create',
'medium-edit',
'medium-delete',
'section-list',
'section-create',
'section-edit',
'section-delete',
'class-list',
'class-create',
'class-edit',
'class-delete',
'class-section-list',
'class-section-create',
'class-section-edit',
'class-section-delete',
'subject-list',
'subject-create',
'subject-edit',
'subject-delete',
'teacher-list',
'teacher-create',
'teacher-edit',
'teacher-delete',
'guardian-list',
'guardian-create',
'guardian-edit',
'guardian-delete',
'session-year-list',
'session-year-create',
'session-year-edit',
'session-year-delete',
'student-list',
'student-create',
'student-edit',
'student-delete',
'timetable-list',
'timetable-create',
'timetable-edit',
'timetable-delete',
'attendance-list',
'staff-attendance-list',
'staff-attendance-edit',
'holiday-list',
'holiday-create',
'holiday-edit',
'holiday-delete',
'announcement-list',
'announcement-create',
'announcement-edit',
'announcement-delete',
'slider-list',
'slider-create',
'slider-edit',
'slider-delete',
'exam-create',
'exam-list',
'exam-edit',
'exam-delete',
'exam-timetable-create',
'exam-timetable-list',
'exam-timetable-delete',
'exam-result',
'exam-result-edit',
'assignment-submission',
'student-reset-password',
'reset-password-list',
'student-change-password',
'promote-student-list',
'promote-student-create',
'promote-student-edit',
'promote-student-delete',
'transfer-student-list',
'transfer-student-create',
'transfer-student-edit',
'transfer-student-delete',
'fees-paid',
'fees-config',
'form-fields-list',
'form-fields-create',
'form-fields-edit',
'form-fields-delete',
'grade-create',
'grade-list',
'grade-edit',
'grade-delete',
'school-setting-manage',
'fees-type-list',
'fees-type-create',
'fees-type-edit',
'fees-type-delete',
'fees-class-list',
'fees-class-create',
'fees-class-edit',
'fees-class-delete',
'online-exam-create',
'online-exam-list',
'online-exam-edit',
'online-exam-delete',
'online-exam-questions-create',
'online-exam-questions-list',
'online-exam-questions-edit',
'online-exam-questions-delete',
'online-exam-result-list',
'role-list',
'role-create',
'role-edit',
'role-delete',
'staff-list',
'staff-create',
'staff-edit',
'staff-delete',
'expense-category-list',
'expense-category-create',
'expense-category-edit',
'expense-category-delete',
'expense-list',
'expense-create',
'expense-edit',
'expense-delete',
'fees-list',
'fees-create',
'fees-edit',
'fees-delete',
'semester-list',
'semester-create',
'semester-edit',
'semester-delete',
'payroll-list',
'payroll-create',
'payroll-edit',
'payroll-delete',
'stream-list',
'stream-create',
'stream-edit',
'stream-delete',
'shift-list',
'shift-create',
'shift-edit',
'shift-delete',
'approve-leave',
'id-card-settings',
'gallery-list',
'gallery-create',
'gallery-edit',
'gallery-delete',
'notification-list',
'notification-create',
'notification-delete',
'certificate-list',
'certificate-create',
'certificate-edit',
'certificate-delete',
'payroll-settings-list',
'payroll-settings-create',
'payroll-settings-edit',
'payroll-settings-delete',
'school-web-settings',
'faqs-list',
'faqs-create',
'faqs-edit',
'faqs-delete',
'class-group-list',
'class-group-create',
'class-group-edit',
'class-group-delete',
'email-template',
'database-backup',
'view-exam-marks',
'assign-elective-subject-list',
'assign-elective-subject-create',
'assign-elective-subject-edit',
'assign-elective-subject-delete',
'reports-student',
'reports-teacher',
'reports-exam',
'reports-expense',
'contact-inquiry-list',
'student-diary-list',
'student-diary-create',
'student-diary-edit',
'student-diary-delete',
'route-list',
'route-create',
'route-edit',
'route-delete',
'pickup-points-list',
'pickup-points-create',
'pickup-points-edit',
'pickup-points-delete',
'transportation-fees-list',
'transportation-fees-create',
'transportation-fees-edit',
'transportation-fees-delete',
'driver-helper-list',
'driver-helper-create',
'driver-helper-edit',
'driver-helper-delete',
'vehicles-list',
'vehicles-create',
'vehicles-edit',
'vehicles-delete',
'RouteVehicle-list',
'RouteVehicle-create',
'RouteVehicle-edit',
'RouteVehicle-delete',
'transportationexpense-list',
'transportationexpense-create',
'transportationexpense-edit',
'transportationexpense-delete',
'transportationRequests-create',
'transportationRequests-list',
'transportationRequests-edit',
'transportationRequests-receipt',
'syllabus-list',
'syllabus-create',
'syllabus-edit',
'syllabus-delete',
];
$role->syncPermissions($SchoolAdminHasAccessTo);
}
public function createTeacherRole($school)
{
//Add Teacher Role
$teacher_role = Role::updateOrCreate(['name' => 'Teacher', 'school_id' => $school->id, 'custom_role' => 0, 'editable' => 1]);
$TeacherHasAccessTo = [
'student-list',
'timetable-list',
'holiday-list',
'announcement-list',
'announcement-create',
'announcement-edit',
'announcement-delete',
'assignment-create',
'assignment-list',
'assignment-edit',
'assignment-delete',
'assignment-submission',
'lesson-list',
'lesson-create',
'lesson-edit',
'lesson-delete',
'topic-list',
'topic-create',
'topic-edit',
'topic-delete',
'class-section-list',
'online-exam-create',
'online-exam-list',
'online-exam-edit',
'online-exam-delete',
'online-exam-questions-create',
'online-exam-questions-list',
'online-exam-questions-edit',
'online-exam-questions-delete',
'online-exam-result-list',
'leave-list',
'leave-create',
'leave-edit',
'leave-delete',
'attendance-list',
'student-diary-list',
'student-diary-create',
'student-diary-edit',
'student-diary-delete',
];
$teacher_role->syncPermissions($TeacherHasAccessTo);
}
public function createDriverRole($school)
{
//Add Driver Role
$driver_role = Role::updateOrCreate(['name' => 'Driver', 'school_id' => $school->id, 'custom_role' => 0, 'editable' => 0]);
$DriverHasAccessTo = [
'leave-list',
'leave-create',
'leave-edit',
'leave-delete',
];
$driver_role->syncPermissions($DriverHasAccessTo);
}
public function createHelperRole($school)
{
//Add Helper Role
$helper_role = Role::updateOrCreate(['name' => 'Helper', 'school_id' => $school->id, 'custom_role' => 0, 'editable' => 0]);
$HelperHasAccessTo = [
'leave-list',
'leave-create',
'leave-edit',
'leave-delete',
];
$helper_role->syncPermissions($HelperHasAccessTo);
}
public function createPayrollSettingsSeeder($school)
{
$payrollSetting = PayrollSetting::updateOrCreate(
[
'name' => 'Transportation Deduction',
'type' => 'deduction',
'school_id' => $school->id,
],
[
'amount' => 0,
'percentage' => null,
]
);
}
public static function switchToMainDatabase()
{
DB::setDefaultConnection('mysql');
Session::forget('school_database_name');
Session::flush();
Session::put('school_database_name', null);
}
public static function switchToSchoolDatabase($school_id)
{
$school_database = School::where('id', $school_id)->pluck('database_name')->first();
DB::setDefaultConnection('school');
Config::set('database.connections.school.database', $school_database);
DB::purge('school');
DB::connection('school')->reconnect();
DB::setDefaultConnection('school');
Session::put('school_database_name', $school_database);
}
}