GenerateRemoteCrontabCommand.php 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <?php
  2. namespace StatsBundle\Command;
  3. use Symfony\Bundle\FrameworkBundle\Command\ContainerAwareCommand;
  4. use Symfony\Component\Console\Input\InputOption;
  5. use Symfony\Component\Console\Input\InputInterface;
  6. use Symfony\Component\Console\Output\OutputInterface;
  7. class GenerateRemoteCrontabCommand extends ContainerAwareCommand
  8. {
  9. protected function configure()
  10. {
  11. $this
  12. ->setName('stats:crontab:remote')
  13. ->setDescription('Generate Remote Stats Crontab File')
  14. ->setHelp('El comando genera/actualiza el archivo crontab de manera remota para realizar consultas a dispositivos')
  15. ->setDefinition(array(
  16. new InputOption('file-crontab', false, InputOption::VALUE_OPTIONAL, "File Crontab", "/etc/cron.d/fd3_stats"),
  17. new InputOption('path-app', false, InputOption::VALUE_OPTIONAL, "Path App", "/opt/stats"),
  18. new InputOption('url', false, InputOption::VALUE_OPTIONAL, "Crontab webservice url"),
  19. new InputOption('amqp', false, InputOption::VALUE_OPTIONAL, "Execute the commands via amqp", true),
  20. new InputOption('routing_key', false, InputOption::VALUE_OPTIONAL, "AMQP Routing key"),
  21. ))
  22. ;
  23. }
  24. /**
  25. * @param InputInterface $input
  26. * @param OutputInterface $output
  27. */
  28. protected function execute(InputInterface $input, OutputInterface $output)
  29. {
  30. $this->output = $output;
  31. $fileCrontab = $input->getOption('file-crontab');
  32. $pathApp = $input->getOption('path-app');
  33. $url = $input->getOption('url');
  34. if (is_null($url)) {
  35. if ($this->getContainer()->hasParameter('url_crontab')) {
  36. $url = $this->getContainer()->getParameter('url_crontab');
  37. } else {
  38. $output->writeln('<error>ERROR:</error> Debe definir una url para generar el crontab.');
  39. $output->writeln($this->getSynopsis());
  40. return;
  41. }
  42. }
  43. $times = array();
  44. $now = date("d-m-Y H:i:s");
  45. $content = "SHELL=/bin/bash".PHP_EOL."BASH_ENV=/container.env".PHP_EOL;
  46. $content .= PHP_EOL . "# NO EDITAR este archivo, se autogenera con el comando stats:crontab:remote. Generado {$now}." . PHP_EOL;
  47. $doctrine = $this->getContainer()->get('doctrine.orm.entity_manager');
  48. if (is_null($pathApp)) {
  49. $pathApp = $this->getContainer()->getParameter('app_path');
  50. }
  51. $pathConsole = "{$pathApp}/bin/console";
  52. $serverDevices = $doctrine->getRepository('\StatsBundle\Entity\DeviceServer')->findAll();
  53. $oltMarks = array('FiberHome','FiberLink','Huawei','ZTE','Calix');
  54. $oltLibraries = array('OIDSFiberHomeV1','OIDSHuaweiV1','OIDSFiberLinkV1','OIDSZTEV1','OIDSCalixV1');
  55. $amqp = $input->getOption('amqp');
  56. $amqpRemote = 'stats:amqp';
  57. $content .= "*/5 * * * * {$pathConsole} stats:crontab:remote >> /var/log/cron.log 2>&1" . PHP_EOL;
  58. $content .= "*/20 * * * * {$pathConsole} stats:devices >> /var/log/cron.log 2>&1" . PHP_EOL;
  59. foreach ($serverDevices as $server) {
  60. $content .= PHP_EOL . PHP_EOL . "# SERVER {$server->getName()} / {$server->getUrl()}" . PHP_EOL;
  61. // APARTADO OLT
  62. $oltDevices = $doctrine->getRepository('\StatsBundle\Entity\Device')->findBy(array('deviceType' => 'FTTHBundle\Entity\OLT', 'deviceServer' => $server));
  63. $serverId = $server->getId();
  64. $saveHistoric = $server->getSaveHistoric();
  65. ($saveHistoric)? $saveHistoric = 1 : $saveHistoric = 0;
  66. foreach ($oltDevices as $device) {
  67. $commands = array();
  68. $data = $device->jsonExtraData();
  69. $deviceId = $device->getDeviceId();
  70. if(isset($data['timeDiscovery']) && $data['timeDiscovery'] > 0) {
  71. $timeDiscovery = (int) $data['timeDiscovery'];
  72. $params = "--args=--action:Discovery --args=--entity:FTTHBundle\\\\\Entity\\\\\OLT --args=--id:{$deviceId}";
  73. $content .= PHP_EOL . PHP_EOL . "# Autodiscovery {$deviceId} is OK " . PHP_EOL;
  74. $content .= "*/{$timeDiscovery} * * * * {$pathConsole} amqp:remote --route=ftth workflow:run:action {$params} >> /var/log/cron.log 2>&1" . PHP_EOL;
  75. } else {
  76. $content .= PHP_EOL . PHP_EOL . "# Autodiscovery {$deviceId} skiped, timeDiscovery is 0 or null or undefined" . PHP_EOL;
  77. }
  78. if ($data['executeSnmp'] == 0){
  79. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, executeSnmp is 0" . PHP_EOL;
  80. continue;
  81. }
  82. if (!in_array($data['mark'], $oltMarks)){
  83. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, mark is not one of " . implode(", ", $oltMarks). PHP_EOL;
  84. continue;
  85. }
  86. if (!in_array($data['library'], $oltLibraries)){
  87. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, library is not one of " . implode(", ", $oltLibraries). PHP_EOL;
  88. continue;
  89. }
  90. $oltName = $data['name'];
  91. $mark = strtolower($data['mark']);
  92. $library = $data['library'];
  93. $snmpCommunity = $data['snmpCommunity'];
  94. $deviceIp = $device->getIp();
  95. $timeScan = $data['timeScan'];
  96. $timeOltScan = $data['timeOltScan'];
  97. $params = "--olt-ip={$deviceIp} --olt-community={$snmpCommunity} --olt-snmp-library={$library} --olt-device-id={$deviceId} --olt-server-id={$serverId} --save-historic={$saveHistoric}";
  98. if ($amqp)
  99. $params = "--args=--olt-ip:{$deviceIp} --args=--olt-community:{$snmpCommunity} --args=--olt-snmp-library:{$library} --args=--olt-device-id:{$deviceId} --args=--olt-server-id:{$serverId} --args=--save-historic:{$saveHistoric}";
  100. $commands[] = "*/{$timeScan} * * * * {$pathConsole} {$amqpRemote} {$mark}:onu:scan {$params} >> /var/log/cron.log 2>&1";
  101. $commands[] = "*/{$timeOltScan} * * * * {$pathConsole} {$amqpRemote} {$mark}:olt:scan {$params} >> /var/log/cron.log 2>&1";
  102. $content .= PHP_EOL . "# OLT {$oltName} ({$deviceIp})" . PHP_EOL;
  103. $content .= implode(PHP_EOL, $commands);
  104. $content .= PHP_EOL . PHP_EOL;
  105. }
  106. // APARTADO NAS
  107. $nasDevices = $doctrine->getRepository('\StatsBundle\Entity\Device')->findBy(array('deviceType' => 'RadiusBundle\Entity\NAS', 'deviceServer' => $server));
  108. foreach ($nasDevices as $device) {
  109. $commands = array();
  110. $data = $device->jsonExtraData();
  111. $deviceId = $device->getDeviceId();
  112. if ($data['executeSnmp'] == 0){
  113. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, executeSnmp is 0" . PHP_EOL;
  114. continue;
  115. }
  116. if (is_null($data['snmpCommunity']) || empty($data['snmpCommunity'])){
  117. $content .= PHP_EOL . PHP_EOL . "# Device(NAS) {$deviceId} skiped, snmpCommunity is null or empty" . PHP_EOL;
  118. continue;
  119. }
  120. if (!in_array($data['library'], array('OIDSBase'))){
  121. $content .= PHP_EOL . PHP_EOL . "# Device(NAS) {$deviceId} skiped, library not exist" . PHP_EOL;
  122. continue;
  123. }
  124. if (!$saveHistoric){
  125. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, because saveHistoric is 0, set Server options in Stats". PHP_EOL;
  126. continue;
  127. }
  128. $library = $data['library'];
  129. $snmpCommunity = $data['snmpCommunity'];
  130. $description = $data['description'];
  131. $deviceIp = $device->getIp();
  132. $params = "--nas-ip={$deviceIp} --nas-community={$snmpCommunity} --nas-snmp-library={$library} --nas-device-id={$deviceId} --nas-server-id={$serverId} --save-historic=1";
  133. if ($amqp)
  134. $params = "--args=--nas-ip:{$deviceIp} --args=--nas-community:{$snmpCommunity} --args=--nas-snmp-library:{$library} --args=--nas-device-id:{$deviceId} --args=--nas-server-id:{$serverId} --args=--save-historic:1";
  135. $commands[] = "*/10 * * * * {$pathConsole} {$amqpRemote} nas:onu:octets {$params} >> /var/log/cron.log 2>&1";
  136. $content .= PHP_EOL . "# NAS {$description} ({$deviceIp})" . PHP_EOL;
  137. $content .= implode(PHP_EOL, $commands);
  138. $content .= PHP_EOL . PHP_EOL;
  139. }
  140. }
  141. $content .= PHP_EOL."#END ".PHP_EOL.PHP_EOL;
  142. file_put_contents($fileCrontab, $content);
  143. sleep(5);
  144. print_r(shell_exec("/usr/bin/crontab /etc/cron.d/fd3_stats"));
  145. //print_r(shell_exec("/usr/local/bin/supervisorctl -uiksop -pqueRini6 restart cron"));
  146. }
  147. }