예제 #1
0
 /**
  * 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);
     }
 }
예제 #2
0
 /**
  * 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];
     }
 }
예제 #3
0
 /**
  * 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();
 }
예제 #4
0
 /**
  * @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');
     });
 }