GenerateRemoteCrontabCommand.php 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  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 = '';
  57. $routing_key = '';
  58. if ($amqp) {
  59. $amqpRemote = 'amqp:remote';
  60. // Verifico la routing key si se pasa como parametro o variable de entorno
  61. // default routing_key = stats
  62. $routing_key = $input->getOption('routing_key');
  63. if (!$routing_key) {
  64. $routing_key = getenv('AMQP_KEY') !== false ? getenv('AMQP_KEY') : 'stats';
  65. }
  66. $routing_key = "--route={$routing_key}";
  67. }
  68. $content .= "*/5 * * * * {$pathConsole} stats:crontab:remote >> /var/log/cron.log 2>&1" . PHP_EOL;
  69. $content .= "*/20 * * * * {$pathConsole} stats:devices >> /var/log/cron.log 2>&1" . PHP_EOL;
  70. foreach ($serverDevices as $server) {
  71. $content .= PHP_EOL . PHP_EOL . "# SERVER {$server->getName()} / {$server->getUrl()}" . PHP_EOL;
  72. // APARTADO OLT
  73. $oltDevices = $doctrine->getRepository('\StatsBundle\Entity\Device')->findBy(array('deviceType' => 'FTTHBundle\Entity\OLT', 'deviceServer' => $server));
  74. $serverId = $server->getId();
  75. $saveHistoric = $server->getSaveHistoric();
  76. ($saveHistoric)? $saveHistoric = 1 : $saveHistoric = 0;
  77. foreach ($oltDevices as $device) {
  78. $commands = array();
  79. $data = $device->jsonExtraData();
  80. $deviceId = $device->getDeviceId();
  81. if(isset($data['timeDiscovery']) && $data['timeDiscovery'] > 0) {
  82. $timeDiscovery = (int) $data['timeDiscovery'];
  83. $params = "--args=--action:Discovery --args=--entity:FTTHBundle\\\\\Entity\\\\\OLT --args=--id:{$deviceId}";
  84. $content .= PHP_EOL . PHP_EOL . "# Autodiscovery {$deviceId} is OK " . PHP_EOL;
  85. $content .= "*/{$timeDiscovery} * * * * {$pathConsole} amqp:remote --route=ftth workflow:run:action {$params} >> /var/log/cron.log 2>&1" . PHP_EOL;
  86. } else {
  87. $content .= PHP_EOL . PHP_EOL . "# Autodiscovery {$deviceId} skiped, timeDiscovery is 0 or null or undefined" . PHP_EOL;
  88. }
  89. if ($data['executeSnmp'] == 0){
  90. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, executeSnmp is 0" . PHP_EOL;
  91. continue;
  92. }
  93. if (!in_array($data['mark'], $oltMarks)){
  94. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, mark is not one of " . implode(", ", $oltMarks). PHP_EOL;
  95. continue;
  96. }
  97. if (!in_array($data['library'], $oltLibraries)){
  98. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, library is not one of " . implode(", ", $oltLibraries). PHP_EOL;
  99. continue;
  100. }
  101. $oltName = $data['name'];
  102. $mark = strtolower($data['mark']);
  103. $library = $data['library'];
  104. $snmpCommunity = $data['snmpCommunity'];
  105. $deviceIp = $device->getIp();
  106. $timeScan = $data['timeScan'];
  107. $timeOltScan = $data['timeOltScan'];
  108. $params = "--olt-ip={$deviceIp} --olt-community={$snmpCommunity} --olt-snmp-library={$library} --olt-device-id={$deviceId} --olt-server-id={$serverId} --save-historic={$saveHistoric}";
  109. if ($amqp)
  110. $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}";
  111. $commands[] = "*/{$timeScan} * * * * {$pathConsole} {$amqpRemote} {$routing_key} {$mark}:onu:scan {$params} >> /var/log/cron.log 2>&1";
  112. $commands[] = "*/{$timeOltScan} * * * * {$pathConsole} {$amqpRemote} {$routing_key} {$mark}:olt:scan {$params} >> /var/log/cron.log 2>&1";
  113. $content .= PHP_EOL . "# OLT {$oltName} ({$deviceIp})" . PHP_EOL;
  114. $content .= implode(PHP_EOL, $commands);
  115. $content .= PHP_EOL . PHP_EOL;
  116. }
  117. // APARTADO NAS
  118. $nasDevices = $doctrine->getRepository('\StatsBundle\Entity\Device')->findBy(array('deviceType' => 'RadiusBundle\Entity\NAS', 'deviceServer' => $server));
  119. foreach ($nasDevices as $device) {
  120. $commands = array();
  121. $data = $device->jsonExtraData();
  122. $deviceId = $device->getDeviceId();
  123. if (is_null($data['snmpCommunity']) || empty($data['snmpCommunity'])){
  124. $content .= PHP_EOL . PHP_EOL . "# Device(NAS) {$deviceId} skiped, snmpCommunity is null or empty" . PHP_EOL;
  125. continue;
  126. }
  127. if (!in_array($data['library'], array('OIDSBase'))){
  128. $content .= PHP_EOL . PHP_EOL . "# Device(NAS) {$deviceId} skiped, library not exist" . PHP_EOL;
  129. continue;
  130. }
  131. if (!$saveHistoric){
  132. $content .= PHP_EOL . PHP_EOL . "# Device {$deviceId} skiped, because saveHistoric is 0, set Server options in Stats". PHP_EOL;
  133. continue;
  134. }
  135. $library = $data['library'];
  136. $snmpCommunity = $data['snmpCommunity'];
  137. $description = $data['description'];
  138. $deviceIp = $device->getIp();
  139. $params = "--nas-ip={$deviceIp} --nas-community={$snmpCommunity} --nas-snmp-library={$library} --nas-device-id={$deviceId} --nas-server-id={$serverId} --save-historic=1";
  140. if ($amqp)
  141. $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";
  142. $commands[] = "*/10 * * * * {$pathConsole} {$amqpRemote} {$routing_key} nas:onu:octets {$params} >> /var/log/cron.log 2>&1";
  143. $content .= PHP_EOL . "# NAS {$description} ({$deviceIp})" . PHP_EOL;
  144. $content .= implode(PHP_EOL, $commands);
  145. $content .= PHP_EOL . PHP_EOL;
  146. }
  147. }
  148. $content .= PHP_EOL."#END ".PHP_EOL.PHP_EOL;
  149. file_put_contents($fileCrontab, $content);
  150. sleep(5);
  151. print_r(shell_exec("/usr/bin/crontab /etc/cron.d/fd3_stats"));
  152. //print_r(shell_exec("/usr/local/bin/supervisorctl -uiksop -pqueRini6 restart cron"));
  153. }
  154. }