upload
This commit is contained in:
30
app/Http/Controllers/AlunosController.php
Normal file
30
app/Http/Controllers/AlunosController.php
Normal file
@@ -0,0 +1,30 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\alunos;
|
||||
use App\Models\turmas;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
|
||||
class AlunosController extends Controller
|
||||
{
|
||||
public function index()
|
||||
{
|
||||
$escolaId = Auth::user()->id_escola;
|
||||
if ($escolaId == 0) {
|
||||
$alunos = alunos::all();
|
||||
} else {
|
||||
$alunos = [];
|
||||
$turmas = turmas::where('id_escola', $escolaId)->get();
|
||||
foreach ($turmas as $turma) {
|
||||
$alunosget = alunos::where('id_turma', $turma->id)->get();
|
||||
|
||||
foreach ($alunosget as $alunosg) {
|
||||
$alunos[] = $alunosg;
|
||||
}
|
||||
}
|
||||
}
|
||||
return view('escolas.alunos', compact('alunos'));
|
||||
}
|
||||
}
|
||||
61
app/Http/Controllers/EnvioWhatsap.php
Normal file
61
app/Http/Controllers/EnvioWhatsap.php
Normal file
@@ -0,0 +1,61 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\turmas;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Http;
|
||||
|
||||
class EnvioWhatsap extends Controller
|
||||
{
|
||||
public function envio(Request $request)
|
||||
{
|
||||
$request->validate([
|
||||
'id_turma' => 'required|exists:turmas,id',
|
||||
'tipo_envio' => 'required|in:texto,imagem',
|
||||
'mensagem' => 'nullable|string',
|
||||
'imagem' => 'required_if:tipo_envio,imagem|image|mimes:jpeg,png,webp|max:2048',
|
||||
]);
|
||||
|
||||
$turma = turmas::findOrFail($request->id_turma);
|
||||
|
||||
// Corrigir formatação para WhatsApp
|
||||
$mensagem = $request->mensagem ?? '';
|
||||
$mensagem = str_replace(['**', '__', '~~'], ['*', '_', '~'], $mensagem);
|
||||
|
||||
$payload = [
|
||||
'chatId' => $turma->id_whatsapp,
|
||||
'mensagem' => $mensagem,
|
||||
];
|
||||
|
||||
// ✅ Se for envio com imagem
|
||||
if ($request->tipo_envio === 'imagem' && $request->hasFile('imagem')) {
|
||||
|
||||
$file = $request->file('imagem');
|
||||
|
||||
$base64 = base64_encode(
|
||||
file_get_contents($file->getRealPath())
|
||||
);
|
||||
|
||||
$mime = $file->getMimeType(); // image/png, image/jpeg, etc
|
||||
|
||||
// 🔥 AQUI está o prefixo obrigatório
|
||||
$base64Completo = "data:$mime;base64,$base64";
|
||||
|
||||
$payload['imagem'] = $base64Completo;
|
||||
}
|
||||
|
||||
// ✅ Enviar para API
|
||||
$response = Http::withHeaders([
|
||||
'X-API-KEY' => 'UoCkSF4ApgADhpvDkkE5XO1fD761yOZX',
|
||||
'Content-Type' => 'application/json',
|
||||
])->post('https://n8n.cae.app.br/webhook/envioWpp', $payload);
|
||||
|
||||
// ✅ Retorno amigável
|
||||
if ($response->successful()) {
|
||||
return back()->with('success', 'Mensagem enviada com sucesso!');
|
||||
}
|
||||
|
||||
return back()->with('error', 'Erro ao enviar: ' . $response->body());
|
||||
}
|
||||
}
|
||||
37
app/Http/Controllers/EscolasController.php
Normal file
37
app/Http/Controllers/EscolasController.php
Normal file
@@ -0,0 +1,37 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\escolas;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
|
||||
class EscolasController extends Controller
|
||||
{
|
||||
public function index()
|
||||
{
|
||||
|
||||
if (Auth::user()->id_escola == 0) {
|
||||
$escolas = escolas::all();
|
||||
} else {
|
||||
$escolas = escolas::where('id', Auth::user()->id_escola)->get();
|
||||
}
|
||||
|
||||
return view('escolas.index', compact('escolas'));
|
||||
}
|
||||
|
||||
public function createOrUpdate(Request $request)
|
||||
{
|
||||
try {
|
||||
escolas::updateOrCreate([
|
||||
'cnpj' => $request->cnpj,
|
||||
],[
|
||||
'nome' => $request->razaosocial,
|
||||
'endereco' => json_decode($request->address, true),
|
||||
]);
|
||||
return redirect()->route('escolas')->with('success', 'Escola Criada|Atualizada com sucesso');
|
||||
} catch (\Throwable $th) {
|
||||
dd($th);
|
||||
}
|
||||
}
|
||||
}
|
||||
10
app/Http/Controllers/HistoricoEscolarController.php
Normal file
10
app/Http/Controllers/HistoricoEscolarController.php
Normal file
@@ -0,0 +1,10 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
|
||||
class HistoricoEscolarController extends Controller
|
||||
{
|
||||
//
|
||||
}
|
||||
52
app/Http/Controllers/TurmasController.php
Normal file
52
app/Http/Controllers/TurmasController.php
Normal file
@@ -0,0 +1,52 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use App\Models\turmas;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
|
||||
class TurmasController extends Controller
|
||||
{
|
||||
public function index()
|
||||
{
|
||||
|
||||
if (Auth::user()->id_escola == 0) {
|
||||
$turmas = turmas::all();
|
||||
} else {
|
||||
$turmas = turmas::where('id_escola', Auth::user()->id_escola)->get();
|
||||
}
|
||||
|
||||
return view('escolas.turmas', compact('turmas'));
|
||||
}
|
||||
|
||||
public function createOrUpdate(Request $request)
|
||||
{
|
||||
$turma = turmas::where('nome', '=', $request->turma_nome)->count();
|
||||
if ($turma == 0) {
|
||||
try {
|
||||
$turma = new turmas();
|
||||
$turma->id_escola = $request->id_escola;
|
||||
$turma->nome = $request->turma_nome;
|
||||
$turma->descricao = $request->turma_descricao;
|
||||
$turma->id_whatsapp = $request->id_whatsapp;
|
||||
$turma->save();
|
||||
return redirect()->route('turmas')->with('success', 'Turma Criada|Atualizada com sucesso.');
|
||||
} catch (\Throwable $th) {
|
||||
dd($th);
|
||||
}
|
||||
} else {
|
||||
try {
|
||||
turmas::where('nome', $request->turma_nome)->update([
|
||||
'nome' => $request->turma_nome,
|
||||
'descricao' => $request->turma_descricao,
|
||||
'id_escola' => $request->id_escola,
|
||||
'id_whatsapp' => $request->id_whatsapp,
|
||||
]);
|
||||
return redirect()->route('turmas')->with('success', 'Turma Criada|Atualizada com sucesso.');
|
||||
} catch (\Throwable $th) {
|
||||
//throw $th;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user