/** * Atualiza na base os dados de um PID revisado. * * @param \Illuminate\Http\Request $request * @param int $id * @return \Illuminate\Http\Response */ public function update(Request $request) { $this->validate($request, ['nome' => 'required|min:5', 'email' => 'required|email', 'url' => 'url', 'tipo_id' => 'exists:pidTipos,idTipo', 'endereco.logradouro' => 'required|min:3|max:150', 'endereco.bairro' => 'required|min:3|max:150', 'endereco.uf' => 'required', 'endereco.cidade_id' => 'required|exists:cidades,idCidade', 'endereco.latitude' => 'numeric', 'endereco.longitude' => 'numeric', 'endereco.localidade_id' => 'exists:localidades,idLocalidade', 'endereco.localizacao_id' => 'exists:localizacoes,idLocalizacao']); $pid = Pid::findOrFail($request['idPid']); $email = $request['session_email']; $pass = $request['session_pass']; $review = DB::table('pid_revisao')->where('email', $email)->where('pass', $pass)->where('valido', 1)->where('submetido', 1)->select('pid_id', 'idRevisao')->get(); if (empty($review)) { return ['error' => 'Acesso Inválido']; } else { if ($review[0]->pid_id != $request['idPid']) { return ['error' => 'Acesso Inválido']; } } DB::beginTransaction(); try { $pid->endereco()->update($request['endereco']); $pid->update($request->all()); $pid->touch(); $telefones = []; foreach ($request['telefones'] as $telefone) { if ($telefone['idTelefone'] == null) { $tel = $pid->telefones()->create($telefone); $telefones[] = $tel->idTelefone; } else { $tel = Telefone::find($telefone['idTelefone']); $tel->update($telefone); $telefones[] = $tel->idTelefone; } } $pid->telefones()->sync($telefones); $instituicoes = []; foreach ($request['instituicoes'] as $instituicao) { $instituicoes[] = $instituicao['idInstituicao']; } $pid->instituicoes()->sync($instituicoes); $iniciativas = []; foreach ($request['iniciativas'] as $iniciativa) { $iniciativas[] = $iniciativa['idIniciativa']; } $pid->iniciativas()->sync($iniciativas); $pid->servicos()->sync($request['servicos']); DB::table('pid_revisao')->where('idRevisao', '=', $review[0]->idRevisao)->update(['valido' => 0, 'updated_at' => Carbon::now()]); DB::commit(); } catch (\Exception $e) { DB::rollback(); abort(400); } finally { unlink(storage_path() . '/revisao/pid_' . $pid->idPid . '.json'); return $this->show($pid->idPid); } }
/** * Display the specified resource. * @param int $id * @return \Illuminate\Http\Response */ public function show($id = null) { if ($id) { $pid = Pid::findOrFail($id); $instituicoes = []; foreach ($pid->instituicoes as $instituicao) { $cidade = DB::table('cidades')->select('nomeCidade', 'uf_id')->where('idCidade', '=', $instituicao->endereco->cidade_id)->first(); $uf = DB::table('uf')->select('uf')->where('idUf', '=', $cidade->uf_id)->first(); $instituicoes[] = array('idInstituicao' => $instituicao->idInstituicao, 'nome' => $instituicao->nome, 'nomeCidade' => $cidade->nomeCidade, 'uf' => $uf->uf, 'tipoVinculo' => $instituicao->pivot->tipoVinculo); } $iniciativas = []; foreach ($pid->iniciativas as $iniciativa) { $cidade = DB::table('cidades')->select('nomeCidade', 'uf_id')->where('idCidade', '=', $iniciativa->endereco->cidade_id)->first(); $uf = DB::table('uf')->select('uf')->where('idUf', '=', $cidade->uf_id)->first(); $iniciativas[] = array('idIniciativa' => $iniciativa->idIniciativa, 'nome' => $iniciativa->nome, 'nomeCidade' => $cidade->nomeCidade, 'uf' => $uf->uf); } $cidade = DB::table('cidades')->select('nomeCidade', 'uf_id')->where('idCidade', '=', $pid->endereco->cidade_id)->first(); $uf = DB::table('uf')->select('uf')->where('idUf', '=', $cidade->uf_id)->first(); return ['idPid' => $pid->idPid, 'nome' => $pid->nome, 'email' => $pid->email, 'url' => $pid->url, 'tipo_id' => $pid->tipo_id, 'endereco' => ['cep' => $pid->endereco->cep, 'logradouro' => $pid->endereco->logradouro, 'numero' => $pid->endereco->numero, 'complemento' => $pid->endereco->complemento, 'bairro' => $pid->endereco->bairro, 'uf' => $uf->uf, 'cidade_id' => $cidade->nomeCidade, 'latitude' => $pid->endereco->latitude, 'longitude' => $pid->endereco->longitude, 'localidade_id' => $pid->endereco->localidade_id, 'localizacao_id' => $pid->endereco->localizacao_id], 'telefones' => $pid->telefones, 'instituicoes' => $instituicoes, 'iniciativas' => $iniciativas, 'fotos' => $pid->fotos]; } }
/** * Retorna uma imagem * @param $id * @param $nome * @return mixed */ public function getFotos($id, $nome) { $pid = Pid::findOrFail($id); $foto = $pid->fotos()->where('nome', '=', $nome)->first(); $img = Image::make($foto->arquivo); $img->resize(171, null, function ($constraint) { $constraint->aspectRatio(); }); return $img->response(); }
/** * @param Request $request * @return mixed */ public function sendLink(Request $request) { $this->validate($request, ['idPid' => 'required', 'email' => 'required|email']); $emRevisao = DB::table('pid_revisao')->where('pid_id', $request['idPid'])->where('valido', 1)->count(); if ($emRevisao > 0) { return 10; } $pid = Pid::findOrFail($request['idPid']); $email = $request['email']; $pass = str_random(8); DB::table('pid_revisao')->insert(['pid_id' => $pid->idPid, 'email' => $email, 'pass' => $pass, 'created_at' => Carbon::now(), 'updated_at' => Carbon::now()]); return Mail::send('emails.pidRevisao', ["idPid" => $pid->idPid, "nome" => $pid->nome, 'email' => $request['email'], 'pass' => $pass], function ($m) use($request) { $m->to($request['email'])->subject('SisMid: Revisão de PID'); }); }