NAP.php 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153
  1. <?php
  2. namespace FTTHBundle\Entity;
  3. use Base\AdminBundle\Traits\TenancyIdTrait;
  4. use Base\AdminBundle\Traits\TenancyIdTraitInterface;
  5. use Doctrine\ORM\Mapping as ORM;
  6. use ExtraDataBundle\Entity\Traits\ExtraDataWithParentTrait;
  7. use MapBundle\Entity\Interfaces\LocationInterface;
  8. use MapBundle\Entity\Traits\LocationTrait;
  9. use Symfony\Component\DependencyInjection\ContainerInterface;
  10. use Symfony\Component\Validator\Constraints as Assert;
  11. /**
  12. * @ORM\Table
  13. * @ORM\Entity
  14. */
  15. class NAP implements TenancyIdTraitInterface, LocationInterface
  16. {
  17. use ExtraDataWithParentTrait;
  18. use ONUTrait;
  19. use TenancyIdTrait;
  20. use LocationTrait;
  21. // Cantidad máxima de ONU por NAP
  22. const MAX_NUMBER_ONU = 64;
  23. /**
  24. * @var int
  25. *
  26. * @ORM\Column(name="id", type="integer")
  27. * @ORM\Id
  28. * @ORM\GeneratedValue(strategy="AUTO")
  29. */
  30. private $id;
  31. /**
  32. * @var string
  33. *
  34. * @ORM\Column(type="string", length=255)
  35. *
  36. * @Assert\NotNull
  37. */
  38. private $name;
  39. /**
  40. * @ORM\ManyToOne(targetEntity="NAP", fetch="EXTRA_LAZY")
  41. */
  42. protected $parent;
  43. /**
  44. * @ORM\OneToMany(targetEntity="ONU", mappedBy="nap", fetch="EXTRA_LAZY")
  45. */
  46. protected $onus;
  47. /**
  48. * @var ContainerInterface
  49. */
  50. private $container;
  51. /**
  52. * @return string
  53. */
  54. public function __toString()
  55. {
  56. return (string)$this->name;
  57. }
  58. /**
  59. * Get id
  60. *
  61. * @return int
  62. */
  63. public function getId()
  64. {
  65. return $this->id;
  66. }
  67. /**
  68. * @param string $name
  69. *
  70. * @return Node
  71. */
  72. public function setName($name)
  73. {
  74. $this->name = $name;
  75. return $this;
  76. }
  77. /**
  78. * @return string
  79. */
  80. public function getName()
  81. {
  82. return $this->name;
  83. }
  84. /**
  85. * @return NAP
  86. */
  87. public function getParent()
  88. {
  89. return $this->parent;
  90. }
  91. /**
  92. * @param NAP $parent
  93. *
  94. * @return $this
  95. */
  96. public function setParent($parent = null)
  97. {
  98. $this->parent = $parent;
  99. return $this;
  100. }
  101. /**
  102. * @return ContainerInterface
  103. */
  104. public function getContainer()
  105. {
  106. return $this->container;
  107. }
  108. /**
  109. * @param ContainerInterface $container
  110. */
  111. public function setContainer(ContainerInterface $container)
  112. {
  113. $this->container = $container;
  114. }
  115. /**
  116. * @return int Retorna la cantidad de puertos libres.
  117. */
  118. public function getFreePort()
  119. {
  120. $em = $this->getContainer()->get("doctrine.orm.entity_manager");
  121. $query = $em->createQuery('SELECT n.id, COUNT(DISTINCT n.id) AS usedPort FROM ' . ONU::class . ' o JOIN o.nap n where n.id = ' . $this->getId());
  122. $onusQuery = $query->getResult();
  123. $freePort = $this::MAX_NUMBER_ONU;
  124. foreach ($onusQuery as $key => $nap) {
  125. if (is_numeric($nap['usedPort'])) {
  126. $freePort = NAP::MAX_NUMBER_ONU - $nap['usedPort'];
  127. }
  128. }
  129. return $freePort;
  130. }
  131. }