HEX
Server: Apache
System: Linux p3plzcpnl506847.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: slfopp7cb1df (5698090)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/slfopp7cb1df/www/shaneconrad.me/inventory/app/Http/Controllers/Notifications_Template.php
<?php

namespace App\Http\Controllers;

use App\Models\Setting;
use App\Models\User;
use App\Models\SMSMessage;
use App\Models\EmailMessage;
use Illuminate\Support\Facades\Artisan;
use Illuminate\Http\Request;
use HTMLPurifier;
use HTMLPurifier_Config;

class Notifications_Template extends Controller
{


    //-------------- get_sms_template ---------------\\

    public function get_sms_template(Request $request)
    {

        $this->authorizeForUser($request->user('api'), 'notification_template', Setting::class);

        //---get sms body for Sale

        $get_type_sale = SMSMessage::where('name', 'sale')->where('deleted_at', '=', null)->first();
        
        if($get_type_sale){
            $sms_body_sale = $get_type_sale->text;
        }else{
            $sms_body_sale = '';
        }

        //---get sms body for quotation

        $get_type_quotation = SMSMessage::where('name', 'quotation')->where('deleted_at', '=', null)->first();
    
        if($get_type_quotation){
            $sms_body_quotation = $get_type_quotation->text;
        }else{
            $sms_body_quotation = '';
        }

        //---get sms body for payment_received

        $get_type_payment_received = SMSMessage::where('name', 'payment_received')->where('deleted_at', '=', null)->first();

        if($get_type_payment_received){
            $sms_body_payment_received = $get_type_payment_received->text;
        }else{
            $sms_body_payment_received = '';
        }

        //---get sms body for purchase

        $get_type_purchase = SMSMessage::where('name', 'purchase')->where('deleted_at', '=', null)->first();

        if($get_type_purchase){
            $sms_body_purchase = $get_type_purchase->text;
        }else{
            $sms_body_purchase = '';
        }

        //---get sms body for payment_sent

        $get_type_payment_sent = SMSMessage::where('name', 'payment_sent')->where('deleted_at', '=', null)->first();

        if($get_type_payment_sent){
            $sms_body_payment_sent = $get_type_payment_sent->text;
        }else{
            $sms_body_payment_sent = '';
        }

          
        return response()->json([
            'sms_body_sale' => $sms_body_sale,
            'sms_body_quotation' => $sms_body_quotation,
            'sms_body_payment_received' => $sms_body_payment_received,
            'sms_body_purchase' => $sms_body_purchase,
            'sms_body_payment_sent' => $sms_body_payment_sent,
        ], 200);
       
       
    }


   
     //-------------- update_sms_body ---------------\\

     public function update_sms_body(Request $request)
     {
 
        $this->authorizeForUser($request->user('api'), 'notification_template', Setting::class);

        $smsMessage = SMSMessage::firstOrNew(['name' => $request['sms_body_type']]);
        $smsMessage->name = $request['sms_body_type'];
        $smsMessage->text = $request['sms_body'];
        $smsMessage->save();

        return response()->json(['success' => true]);

 
     }


     //-------------- get_emails_template ---------------\\

    public function get_emails_template(Request $request)
    {

        $this->authorizeForUser($request->user('api'), 'notification_template', Setting::class);

        //---get sms body for Sale

        $email_sale = EmailMessage::where('name', 'sale')->where('deleted_at', '=', null)->first();
        
        if($email_sale){
            $sale['subject'] = $email_sale->subject;
            $sale['body'] = $email_sale->body;
        }else{
            $sale['subject'] = '';
            $sale['body'] = '';
        }


        //---get sms body for quotation

        $email_quotation = EmailMessage::where('name', 'quotation')->where('deleted_at', '=', null)->first();
        
            
        if($email_quotation){
            $quotation['subject'] = $email_quotation->subject;
            $quotation['body'] = $email_quotation->body;
        }else{
            $quotation['subject'] = '';
            $quotation['body'] = '';
        }
 
        //---get sms body for payment_received

        $email_payment_received = EmailMessage::where('name', 'payment_received')->where('deleted_at', '=', null)->first();
        
            
        if($email_payment_received){
            $payment_received['subject'] = $email_payment_received->subject;
            $payment_received['body'] = $email_payment_received->body;
        }else{
            $payment_received['subject'] = '';
            $payment_received['body'] = '';
        }

        //---get sms body for purchase

        $email_purchase = EmailMessage::where('name', 'purchase')->where('deleted_at', '=', null)->first();

            
        if($email_purchase){
            $purchase['subject'] = $email_purchase->subject;
            $purchase['body'] = $email_purchase->body;
        }else{
            $purchase['subject'] = '';
            $purchase['body'] = '';
        }
 
        //---get sms body for payment_sent

        $email_payment_sent = EmailMessage::where('name', 'payment_sent')->where('deleted_at', '=', null)->first();

            
        if($email_payment_sent){
            $payment_sent['subject'] = $email_payment_sent->subject;
            $payment_sent['body'] = $email_payment_sent->body;
        }else{
            $payment_sent['subject'] = '';
            $payment_sent['body'] = '';
        }

        return response()->json([
            'sale' => $sale,
            'quotation' => $quotation,
            'payment_received' => $payment_received,
            'purchase' => $purchase,
            'payment_sent' => $payment_sent,
        ], 200);
       
    }


    //-------------- update_custom_email ---------------\\

    public function update_custom_email(Request $request)
    {
        $this->authorizeForUser($request->user('api'), 'notification_template', Setting::class);
        
        $requestData = $request->json();
        $email_type = $requestData->get('email_type');

        $config = HTMLPurifier_Config::createDefault();
        $config->set('Core.Encoding', 'UTF-8');
        $config->set('HTML.Allowed', 'div[style],h1,h2,h3,h4,h5,h6,p[style],b,strong,i,em,u,ul,ol,li,br,hr,pre,blockquote,span[style]');
        $config->set('CSS.AllowedProperties', 'font-size, color, background-color, text-align');
        $purifier = new HTMLPurifier($config);

        $custom_email_body = $purifier->purify($requestData->get('custom_email_body'));

        $custom_email_subject = $purifier->purify($requestData->get('custom_email_subject'));


        $emailMessage = EmailMessage::firstOrNew(['name' => $email_type]);
        $emailMessage->name = $email_type;
        $emailMessage->subject = $custom_email_subject;
        $emailMessage->body = $custom_email_body;
        $emailMessage->save();

        return response()->json(['success' => true]);

       

    }


   
}