public function getComputadorPreCole(Request $request, $te_so, $te_node_adress, $rede, $so, $ip_computador) { //recebe dados via POST, deCripata dados, e attribui a variaveis $computer_system = OldCacicHelper::deCrypt($request, $request->request->get('ComputerSystem'), true); $network_adapter = OldCacicHelper::deCrypt($request, $request->request->get('NetworkAdapterConfiguration'), true); $operating_system = OldCacicHelper::deCrypt($request, $request->request->get('OperatingSystem'), true); $te_versao_cacic = $request->request->get('te_versao_cacic'); $te_versao_gercols = $request->request->get('te_versao_gercols'); $data = new \DateTime('NOW'); //armazena data Atual //vefifica se existe SO coletado se não, insere novo SO $computador = $this->findOneBy(array('teNodeAddress' => $te_node_adress, 'idSo' => $so->getIdSo())); //inserção de dado se for um novo computador if (empty($computador)) { $computador = new Computador(); $computador->setTeNodeAddress($te_node_adress); $computador->setIdSo($so); $computador->setIdRede($rede); $computador->setDtHrInclusao($data); $computador->setTePalavraChave($request->get('PHP_AUTH_PW')); $computador->setAtivo(true); $this->getEntityManager()->persist($computador); } // Atualiza subrede se houve mudança de subrede para o computador #if ($computador->getIdRede() != $rede) { #error_log("Atualizando subrede paara o computador ".$computador->getTeIpComputador()." Antiga: ".$computador->getIdRede()->getNmRede()." | Nova: ".$rede->getNmRede()); # $computador->setIdRede($rede); #} $computador->setDtHrUltAcesso($data); $computador->setTeVersaoCacic($te_versao_cacic); $computador->setTeVersaoGercols($te_versao_gercols); $computador->setTeUltimoLogin(TagValueHelper::getValueFromTags('UserName', $computer_system)); $computador->setTeIpComputador($ip_computador); $computador->setNmComputador(TagValueHelper::getValueFromTags('Caption', $computer_system)); $computador->setAtivo(true); $this->getEntityManager()->persist($computador); $acoes = $this->getEntityManager()->getRepository('CacicCommonBundle:Acao')->findAll(); //inserção ações de coleta a nova maquina foreach ($acoes as $acao) { $acao_so = $this->getEntityManager()->getRepository('CacicCommonBundle:AcaoSo')->findBy(array('rede' => $rede, 'so' => $so, 'acao' => $acao)); if (empty($acao_so)) { $acao_so = new AcaoSo(); $acao_so->setRede($rede); $acao_so->setSo($so); $acao_so->setAcao($acao); $this->getEntityManager()->persist($acao_so); } } //persistir dados $this->getEntityManager()->flush(); return $computador; }
/** * * Tela de importação de arquivo CSV com registros de Computadores */ public function importarcsvAction(Request $request) { $form = $this->createFormBuilder()->add('arquivocsv', 'file', array('label' => 'Arquivo', 'attr' => array('accept' => '.csv')))->getForm(); if ($request->isMethod('POST')) { $form->bindRequest($request); if ($form['arquivocsv']->getData() instanceof \Symfony\Component\HttpFoundation\File\UploadedFile) { // Executa a importação do arquivo - grava no diretório web/upload/migracao $dirMigracao = realpath(dirname(__FILE__) . '/../../../../web/upload/migracao/'); $fileName = 'Comp_U' . $this->getUser()->getIdUsuario() . 'T' . time() . '.csv'; $form['arquivocsv']->getData()->move($dirMigracao, $fileName); $em = $this->getDoctrine()->getManager(); // Abre o arquivo salvo e começa a rotina de importação dos dados do CSV $csv = file($dirMigracao . '/' . $fileName); foreach ($csv as $k => $v) { // Valida a linha $v = explode(';', trim(str_replace(array('"', '\\N'), '', $v))); if (count($v) != 13) { continue; } $so = $this->getDoctrine()->getRepository('CacicCommonBundle:So')->find((int) $v[1]); $rede = $this->getDoctrine()->getRepository('CacicCommonBundle:Rede')->findOneByTeIpRede($v[2]); $comp = new Computador(); if ($so) { $comp->setIdSo($so); } if ($rede) { $comp->setIdRede($rede); } $comp->setTeNodeAddress($v[0]); $comp->setTePalavraChave($v[3]); $comp->setTeIpComputador($v[4]); $comp->setDtHrInclusao($v[5] ? new \Datetime($v[5]) : null); $comp->setDtHrUltAcesso($v[6] ? new \Datetime($v[6]) : null); $comp->setTeVersaoCacic($v[7]); $comp->setTeVersaoGercols($v[8]); $comp->setDtHrColetaForcadaEstacao($v[9] ? new \Datetime($v[9]) : null); $comp->setTeNomesCurtosModulos($v[10]); $comp->setIdConta($v[11]); $comp->setNmComputador($v[12]); $em->persist($comp); } $em->flush(); // Persiste os dados dos Computadores $this->get('session')->getFlashBag()->add('success', 'Importação realizada com sucesso!'); } else { $this->get('session')->getFlashBag()->add('error', 'Arquivo CSV inválido!'); } return $this->redirect($this->generateUrl('cacic_migracao_computador')); } return $this->render('CacicCommonBundle:Computador:importarcsv.html.twig', array('form' => $form->createView())); }