ParserFile.php 43KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661
  1. <?php
  2. defined('BASEPATH') or exit('No direct script access allowed');
  3. error_reporting(E_ALL & ~E_NOTICE);
  4. class ParserFile
  5. {
  6. protected $idLicitacion = 0;
  7. protected $datos_iniciales = array();
  8. protected $contrat_folder = array();
  9. protected $keyPadreRecursiva = "";
  10. protected $rutaDiaria = "";
  11. protected $rutaMensual = FCPATH . "DOWNLOADS/MONTH/format";
  12. protected $fechaInicioParser = "";
  13. //TODO: Añadir los nodos que falten mirando la libreria de java
  14. //TODO Nuevo Nodo: Proveedor de pliegos->TenderingTerms->DocumentProviderParty
  15. //TODO Nuevo Nodo: Lugar de recepción->TenderingTerms->TenderRecipientParty
  16. //TODO Nuevo Nodo: Proveedor de información adicional->TenderingTerms->AdditionalInformationParty
  17. //TODO Nuevo Nodo: Información sobre recursos//Lugar de presentación de recursos//Fecha límite de presentación de recursos//Arbitraje->TenderingTerms->AppealTerms
  18. //TODO Nuevo Nodo: Eventos->TenderingProcess->OpenTenderEvent
  19. public function __construct()
  20. {
  21. $this->CI = &get_instance();
  22. $this->CI->load->helper('file');
  23. $this->CI->load->library('parserdatabasebruto');
  24. $this->CI->load->library('parserdatabaselimpio');
  25. }
  26. public function index($rutaDiariaDownloader, $fechaInicioParser, $datosPerfil)
  27. {
  28. $this->rutaDiaria = $rutaDiariaDownloader . "/format/";
  29. $this->fechaInicioParser = $fechaInicioParser;
  30. $files = get_filenames($this->rutaDiaria, true);
  31. guardar_log("setLicitacion__" . $datosPerfil->prefijos_tablas . "__" . $fechaInicioParser, "----------------------------------", false);
  32. foreach ($files as $file) {
  33. $resultEntries = array();
  34. $entrada = file_get_contents($file);
  35. $xml = simplexml_load_string($entrada, "SimpleXMLElement", LIBXML_NOCDATA);
  36. $json = json_encode($xml);
  37. $array = json_decode($json, true);
  38. $filename = basename($file);
  39. $aux = 0;
  40. foreach ($array['entry'] as $clave => $row) {
  41. $arrayDeletedEntries = $xml->children('at', true);
  42. $resultEntries[$filename]['general'][$aux] = $this->nodoEntry($row, $xml->entry[$clave], $datosPerfil->id);
  43. $resultEntries[$filename]['contractInfo'][$aux] = $this->nodoContractFolderStatus($row, $xml->entry[$clave]);
  44. $resultEntries[$filename]['locatedContractingParty'][$aux] = $this->nodoLocatedContractingParty($row, $xml->entry[$clave]);
  45. $resultEntries[$filename]['party'][$aux] = $this->nodoParty($row, $xml->entry[$clave]);
  46. $resultEntries[$filename]['procurementProject'][$aux] = $this->nodoPresupuesto($row, $xml->entry[$clave]);
  47. $resultEntries[$filename]['procurementProjectLot'][$aux] = $this->nodoProcurementProjectLot($row, $xml->entry[$clave]);
  48. $resultEntries[$filename]['tenderingTerms'][$aux] = $this->nodoTenderingTerms($row, $xml->entry[$clave]);
  49. $resultEntries[$filename]['tenderingProcess'][$aux] = $this->nodoTenderingProcess($row, $xml->entry[$clave]);
  50. $resultEntries[$filename]['tenderingResult'][$aux] = $this->nodoTenderResult($row, $xml->entry[$clave]);
  51. //$resultEntries[$filename]['validNoticeInfo'][$aux] = $this->nodoValidNoticeInfo($row);
  52. $resultEntries[$filename]['legalDocs'][$aux] = $this->nodoLegalDoc($row, $xml->entry[$clave]);
  53. $resultEntries[$filename]['technicalDocs'][$aux] = $this->nodoTechnicalDocumentReference($row, $xml->entry[$clave]);
  54. $resultEntries[$filename]['generalDocs'][$aux] = $this->nodoGeneralDocuments($row, $xml->entry[$clave]);
  55. $resultEntries[$filename]['additionalDocs'][$aux] = $this->nodoAdditionalDocumentReference($row, $xml->entry[$clave]);
  56. $aux++;
  57. //$this->recurseXML($array['entry'], true);
  58. }
  59. $this->CI->parserdatabasebruto->setDatosParser($resultEntries, $fechaInicioParser, $datosPerfil);
  60. $resultEntries = array();
  61. $this->CI->parserdatabaselimpio->index($fechaInicioParser);
  62. }
  63. return;
  64. }
  65. private function nodoEntry($xml, $xmlPrimitivo, $tipoPerfil)
  66. {
  67. $resultEntries = array();
  68. $id_licitacion = (string) substr($xml['id'], strrpos($xml['id'], '/') + 1);
  69. $resultEntries['url_id_licitacion'] = (string) $xml['id'];
  70. $resultEntries['id_licitacion'] = $id_licitacion;
  71. $this->idLicitacion = $id_licitacion;
  72. $resultEntries['link_uri'] = (string) $this->existAttribute($xmlPrimitivo, "link", "string", 'href');
  73. $resultEntries['summary'] = (string) $xml['summary'];
  74. $resultEntries['title'] = (string) $xml['title'];
  75. $resultEntries['updated'] = (string) $xml['updated'];
  76. $resultEntries['tipo_perfil_licitacion'] = $tipoPerfil;
  77. $resultEntries['fecha_creacion_log'] = $this->fechaInicioParser;
  78. return $resultEntries;
  79. }
  80. private function nodoContractFolderStatus($xml, $xmlPrimitivo)
  81. {
  82. $resultEntries = array();
  83. if (array_key_exists("ContractFolderStatus", $xml)) {
  84. $contractFolder = $xml['ContractFolderStatus'];
  85. $resultEntries['ContractFolderID'] = (string) $contractFolder['ContractFolderID'];
  86. $resultEntries['ContractFolderStatusCode'] = (string) $contractFolder['ContractFolderStatusCode'];
  87. $resultEntries['ContractFolderStatusCodeAttr'] = $this->existAttribute($xmlPrimitivo->ContractFolderStatus, "ContractFolderStatusCode", "string", 'listURI');
  88. $resultEntries['id_ajena_licitacion'] = $this->idLicitacion;
  89. $resultEntries['id_compuesta'] = $this->idLicitacion . "_01";
  90. $resultEntries['fecha_creacion_log'] = $this->fechaInicioParser;
  91. }
  92. return $resultEntries;
  93. }
  94. private function nodoLocatedContractingParty($xml, $xmlPrimitivo)
  95. {
  96. $resultEntries = array();
  97. if (array_key_exists("LocatedContractingParty", $xml['ContractFolderStatus'])) {
  98. $LocatedContractingParty = $xml['ContractFolderStatus']['LocatedContractingParty'];
  99. $resultEntries['locatedContractingParty']['contractingPartyTypeCode'] = $this->existNodo($LocatedContractingParty, "ContractingPartyTypeCode", 'string');
  100. $resultEntries['locatedContractingParty']['contractingPartyTypeCodeUri'] = $this->existAttribute($xmlPrimitivo->ContractFolderStatus->LocatedContractingParty, "ContractingPartyTypeCode", "string", 'listURI');
  101. //$resultEntries['locatedContractingParty']['contractingPartyTypeCodeUri'] = $this->existAttribute($LocatedContractingParty, "ContractingPartyTypeCode", 'string', 'listURI');
  102. if (array_key_exists("ActivityCode", $xml['ContractFolderStatus']['LocatedContractingParty'])) {
  103. $activity = $xml['ContractFolderStatus']['LocatedContractingParty']['ActivityCode'];
  104. if (!is_array($activity)) {
  105. $activity = array(0 => $activity);
  106. }
  107. for ($i = 0; $i < count($activity); $i++) {
  108. $resultEntries['activity'][$i]['activityCode'] = (string) $activity[$i];
  109. //$resultEntries['activity'][$i]['activityCodeUri'] = (string) $activity[$i]->attributes()['listURI'];
  110. $resultEntries['activity'][$i]['activityCodeUri'] = $this->existAttribute($xmlPrimitivo->ContractFolderStatus->LocatedContractingParty, "ActivityCode", "string", 'listURI');
  111. $resultEntries['activity'][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  112. $resultEntries['activity'][$i]['id_compuesta_padre'] = $this->idLicitacion . "_02_";
  113. $resultEntries['activity'][$i]['id_compuesta'] = $this->idLicitacion . "_02_" . $i;
  114. $resultEntries['activity'][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  115. }
  116. }
  117. $resultEntries['locatedContractingParty']['buyerProfileURIID'] = $this->existNodo($LocatedContractingParty, "BuyerProfileURIID", 'string');
  118. $resultEntries['locatedContractingParty']['id_ajena_licitacion'] = $this->idLicitacion;
  119. $resultEntries['locatedContractingParty']['id_compuesta'] = $this->idLicitacion . "_02";
  120. $resultEntries['locatedContractingParty']['fecha_creacion_log'] = $this->fechaInicioParser;
  121. }
  122. return $resultEntries;
  123. }
  124. private function nodoParty($xml, $xmlPrimitivo)
  125. {
  126. $resultEntries = array();
  127. if (array_key_exists("Party", $xml['ContractFolderStatus']['LocatedContractingParty'])) {
  128. $party = $xml['ContractFolderStatus']['LocatedContractingParty']['Party'];
  129. $resultEntries['party']['websiteURI'] = $this->existNodo($party, "WebsiteURI", 'string');
  130. if (array_key_exists("PartyIdentification", $party)) {
  131. for ($i = 0; $i < count($party['PartyIdentification']); $i++) {
  132. $resultEntries['partyIdentification'][$i]['idPartyIdent'] = $this->existNodo($party['PartyIdentification'][$i], "ID", 'string');
  133. //$resultEntries['partyIdentification'][$i]['attr'] = $this->existAttribute($party, $party['PartyIdentification'][$i]['ID'], "string", 'schemeName');
  134. $resultEntries['partyIdentification'][$i]['attr'] = $this->existAttribute($xmlPrimitivo->ContractFolderStatus->LocatedContractingParty->Party->PartyIdentification[$i], "ID", "string", 'schemeName');
  135. $resultEntries['partyIdentification'][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  136. $resultEntries['partyIdentification'][$i]['id_compuesta'] = $this->idLicitacion . "_03_" . $i;
  137. $resultEntries['partyIdentification'][$i]['id_compuesta_padre'] = $this->idLicitacion . "_03";
  138. $resultEntries['partyIdentification'][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  139. }
  140. }
  141. $resultEntries['party']['partyName'] = $this->existNodo($party['PartyName'], "Name", 'string');
  142. $resultEntries['party']['city'] = $this->existNodo($party['PostalAddress'], "CityName", 'string');
  143. $resultEntries['party']['codpostal'] = $this->existNodo($party['PostalAddress'], "PostalZone", 'string');
  144. $resultEntries['party']['direccion'] = $this->existNodo($party['PostalAddress']['AddressLine'], "Line", 'string');
  145. $resultEntries['party']['country'] = $this->existNodo($party['PostalAddress']['Country'], "Name", 'string');
  146. $resultEntries['party']['contact_name'] = $this->existNodo($party['Contact'], "Name", 'string');
  147. $resultEntries['party']['contact_email'] = $this->existNodo($party['Contact'], "ElectronicMail", 'string');
  148. $resultEntries['party']['id_ajena_licitacion'] = $this->idLicitacion;
  149. $resultEntries['party']['id_compuesta'] = $this->idLicitacion . "_03";
  150. $resultEntries['party']['fecha_creacion_log'] = $this->fechaInicioParser;
  151. }
  152. return $resultEntries;
  153. }
  154. private function nodoPresupuesto($xml, $xmlPrimitivo)
  155. {
  156. $resultEntries = array();
  157. //$procurementProject = $xml->ContractFolderStatus->ProcurementProject;
  158. if (array_key_exists("ProcurementProject", $xml['ContractFolderStatus'])) {
  159. $procurementProject = $xml['ContractFolderStatus']['ProcurementProject'];
  160. $resultEntries['budget']['id_ajena_licitacion'] = $this->idLicitacion;
  161. $resultEntries['budget']['id_compuesta'] = $this->idLicitacion . "_04";
  162. $resultEntries['budget']['fecha_creacion_log'] = $this->fechaInicioParser;
  163. $resultEntries['budget']['name'] = $this->existNodo($procurementProject, 'Name', 'string');
  164. $resultEntries['budget']['typeCode'] = $this->existNodo($procurementProject, 'TypeCode', 'string');
  165. $resultEntries['budget']['subTypeCode'] = $this->existNodo($procurementProject, 'SubTypeCode', 'string');
  166. if (array_key_exists("BudgetAmount", $procurementProject)) {
  167. $resultEntries['budget']['estimatedOverallContractAmount'] = $this->existNodo($procurementProject['BudgetAmount'], 'EstimatedOverallContractAmount', 'string');
  168. $resultEntries['budget']['totalAmount'] = $this->existNodo($procurementProject['BudgetAmount'], 'TotalAmount', 'string');
  169. $resultEntries['budget']['taxExclusiveAmount'] = $this->existNodo($procurementProject['BudgetAmount'], 'TaxExclusiveAmount', 'string');
  170. }
  171. if (array_key_exists("RequiredCommodityClassification", $procurementProject)) {
  172. $firstKey = array_key_first($procurementProject['RequiredCommodityClassification']);
  173. if ($this->idLicitacion == "8815986") {
  174. $var = 1;
  175. }
  176. if ($firstKey === "ItemClassificationCode") {
  177. $procurementProject['RequiredCommodityClassification'] = array(0 => $procurementProject['RequiredCommodityClassification']);
  178. }
  179. for ($i = 0; $i < count($procurementProject['RequiredCommodityClassification']); $i++) {
  180. $resultEntries['itemClass'][$i]['itemClassification_value'] = $this->existNodo($procurementProject['RequiredCommodityClassification'][$i], 'ItemClassificationCode', 'string');
  181. //$resultEntries['itemClass'][$i]['itemClassification_attr'] = (string) $procurementProject['RequiredCommodityClassification'][$i]['ItemClassificationCode']['listURI'];
  182. $resultEntries['itemClass'][$i]['itemClassification_attr'] = $this->existAttribute($xmlPrimitivo->ContractFolderStatus->ProcurementProject->RequiredCommodityClassification[$i], "ItemClassificationCode", "string", 'listURI');
  183. $resultEntries['itemClass'][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  184. $resultEntries['itemClass'][$i]['id_compuesta_padre'] = $this->idLicitacion . "_04";
  185. $resultEntries['itemClass'][$i]['id_compuesta'] = $this->idLicitacion . "_04_" . $i;
  186. $resultEntries['itemClass'][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  187. }
  188. }
  189. if (array_key_exists("RealizedLocation", $procurementProject)) {
  190. $resultEntries['budget']['countrySubentity'] = $this->existNodo($procurementProject['RealizedLocation'], 'CountrySubentity', 'string');
  191. if (array_key_exists("CountrySubentityCode", $procurementProject['RealizedLocation'])) {
  192. $resultEntries['budget']['countrySubentityCode'] = $this->existNodo($procurementProject['RealizedLocation'], 'CountrySubentityCode', 'string');
  193. $resultEntries['budget']['countrySubentityCode'] = $this->existAttribute($xmlPrimitivo->ContractFolderStatus->ProcurementProject->RealizedLocation, "CountrySubentityCode", "string", 'listURI');
  194. //$resultEntries['budget']['countrySubentityCodeAttr'] = $this->existAttribute($procurementProject['RealizedLocation'], "CountrySubentityCode", "string", 'listURI');
  195. }
  196. if (array_key_exists("Address", $procurementProject['RealizedLocation'])) {
  197. $resultEntries['budget']['cityName'] = $this->existNodo($procurementProject['RealizedLocation']['Address']['Country'], 'CityName', 'string');
  198. $resultEntries['budget']['IdentificationCode'] = $this->existNodo($procurementProject['RealizedLocation']['Address']['Country'], 'IdentificationCode', 'string');
  199. $resultEntries['budget']['countryName'] = $this->existNodo($procurementProject['RealizedLocation']['Address']['Country'], 'Name', 'string');
  200. }
  201. }
  202. $resultEntries['budget']['durationMesure'] = $this->existNodo($procurementProject['PlannedPeriod'], 'DurationMeasure', 'string');
  203. $resultEntries['budget']['duracion_inicio'] = $this->existNodo($procurementProject['PlannedPeriod'], 'StartDate', 'string');
  204. $resultEntries['budget']['duracion_fin'] = $this->existNodo($procurementProject['PlannedPeriod'], 'EndDate', 'string');
  205. $resultEntries['budget']['medida'] = $this->existAttribute($xmlPrimitivo->ContractFolderStatus->ProcurementProject->PlannedPeriod, "DurationMeasure", "string", 'unitCode');
  206. //$resultEntries['budget']['medida'] = $this->existAttribute($procurementProject['PlannedPeriod'], "DurationMeasure", "string", 'unitCode');
  207. if (array_key_exists("ContractExtension", $procurementProject)) {
  208. $resultEntries['budget']['contractExtension'] = $this->existNodo($procurementProject['ContractExtension'], 'OptionsDescription', 'string');
  209. }
  210. }
  211. return $resultEntries;
  212. }
  213. private function nodoProcurementProjectLot($xml, $xmlPrimitivo)
  214. {
  215. $resultEntries = array();
  216. if (array_key_exists("ProcurementProjectLot", $xml['ContractFolderStatus'])) {
  217. $procurementProjectLot = $xml['ContractFolderStatus']['ProcurementProjectLot'];
  218. $firstKey = array_key_first($procurementProjectLot);
  219. if ($firstKey !== 0) {
  220. $procurementProjectLot = array(0 => $procurementProjectLot);
  221. }
  222. for ($i = 0; $i < count($procurementProjectLot); $i++) {
  223. $resultEntries["lot"][$i]['idProcurementLot'] = $this->existNodo($procurementProjectLot[$i], 'ID', 'string');
  224. $resultEntries["lot"][$i]['name'] = $this->existNodo($procurementProjectLot[$i]['ProcurementProject'], 'Name', 'string');
  225. $resultEntries["lot"][$i]['totalAmount'] = $this->existNodo($procurementProjectLot[$i]['ProcurementProject']['BudgetAmount'], 'TotalAmount', 'string');
  226. $resultEntries["lot"][$i]['taxExclusiveAmount'] = $this->existNodo($procurementProjectLot[$i]['ProcurementProject']['BudgetAmount'], 'TaxExclusiveAmount', 'string');
  227. $resultEntries["lot"][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  228. $resultEntries["lot"][$i]['id_compuesta'] = $this->idLicitacion . "_05_" . $i;
  229. $resultEntries["lot"][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  230. if (array_key_exists("RealizedLocation", $procurementProjectLot[$i]['ProcurementProject'])) {
  231. $resultEntries["lot"][$i]['countrySubentity'] = $this->existNodo($procurementProjectLot[$i]['ProcurementProject']['RealizedLocation'], 'CountrySubentity', 'string');
  232. $resultEntries["lot"][$i]['countrySubentityCode'] = $this->existNodo($procurementProjectLot[$i]['ProcurementProject']['RealizedLocation'], 'CountrySubentityCode', 'string');
  233. $resultEntries["lot"][$i]['identificationCode'] = $this->existNodo($procurementProjectLot[$i]['ProcurementProject']['RealizedLocation']['Address']['Country'], 'IdentificationCode', 'string');
  234. $resultEntries["lot"][$i]['nameLocation'] = $this->existNodo($procurementProjectLot[$i]['ProcurementProject']['RealizedLocation']['Address']['Country'], 'Name', 'string');
  235. if (array_key_exists("RequiredCommodityClassification", $procurementProjectLot[$i]['ProcurementProject'])) {
  236. $clasificacionItems = $procurementProjectLot[$i]['ProcurementProject']['RequiredCommodityClassification'];
  237. $firstKey = array_key_first($clasificacionItems);
  238. if ($firstKey !== 0) {
  239. $clasificacionItems = array(0 => $clasificacionItems);
  240. }
  241. for ($j = 0; $j < count($clasificacionItems); $j++) {
  242. $resultEntries['itemClassification'][] = array(
  243. "idItem" => $this->existNodo($clasificacionItems[$j], "ItemClassificationCode", "string"),
  244. "id_ajena_licitacion" => $this->idLicitacion,
  245. "id_compuesta" => $this->idLicitacion . "_05_" . $i . "_" . $j,
  246. "id_compuesta_padre" => $this->idLicitacion . "_05_" . $i,
  247. "fecha_creacion_log" => $this->fechaInicioParser,
  248. "id_attr" => $this->existAttribute($xmlPrimitivo->ContractFolderStatus->ProcurementProjectLot->RequiredCommodityClassification, "ItemClassificationCode", "string", 'listURI'),
  249. //$resultEntries["itemClassification"][$i]['itemClassification'][$j]['id_attr'] = $this->existAttribute($clasificacionItems[$j], "ItemClassificationCode", "string", 'listURI');
  250. );
  251. }
  252. }
  253. }
  254. }
  255. }
  256. return $resultEntries;
  257. }
  258. private function nodoTenderResult($xml)
  259. {
  260. $resultEntries = array();
  261. if (array_key_exists("TenderResult", $xml['ContractFolderStatus'])) {
  262. $tenderResult = $xml['ContractFolderStatus']['TenderResult'];
  263. $firstKey = array_key_first($tenderResult);
  264. if ($firstKey !== 0) {
  265. $tenderResult = array(0 => $tenderResult);
  266. }
  267. for ($i = 0; $i < count($tenderResult); $i++) {
  268. $resultEntries[$i]['id_ajena_licitacion'] = $this->idLicitacion;
  269. $resultEntries[$i]['id_compuesta'] = $this->idLicitacion . "_06_" . $i;
  270. $resultEntries[$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  271. $resultEntries[$i]['resultCode'] = $this->existNodo($tenderResult[$i], 'ResultCode', 'string');
  272. $resultEntries[$i]['description'] = $this->existNodo($tenderResult[$i], 'Description', 'string');
  273. $resultEntries[$i]['awardDate'] = $this->existNodo($tenderResult[$i], 'AwardDate', 'string');
  274. $resultEntries[$i]['receivedTenderQuantity'] = $this->existNodo($tenderResult[$i], 'ReceivedTenderQuantity', 'string');
  275. $resultEntries[$i]['lowerTenderAmount'] = $this->existNodo($tenderResult[$i], 'LowerTenderAmount', 'string');
  276. $resultEntries[$i]['higherTenderAmount'] = $this->existNodo($tenderResult[$i], 'HigherTenderAmount', 'string');
  277. $resultEntries[$i]['startDate'] = $this->existNodo($tenderResult[$i], 'StartDate', 'string');
  278. $resultEntries[$i]['smeawardedIndicator'] = $this->existNodo($tenderResult[$i], 'SMEAwardedIndicator', 'string');
  279. //AwardedTenderedProject
  280. $resultEntries[$i]['contract_id'] = $this->existNodo($tenderResult[$i]->Contract, 'ID', 'string');
  281. $resultEntries[$i]['contract_issueDate'] = $this->existNodo($tenderResult[$i]->Contract, 'IssueDate', 'string');
  282. if (array_key_exists("WinningParty", $tenderResult[$i])) {
  283. $winningParty = $tenderResult[$i]['WinningParty'];
  284. $resultEntries[$i]['partyIdentification'] = $this->existNodo($winningParty['PartyIdentification'], 'ID', 'string');
  285. $resultEntries[$i]['partyName'] = $this->existNodo($winningParty['PartyName'], 'Name', 'string');
  286. }
  287. if (array_key_exists("AwardedTenderedProject", $tenderResult[$i])) {
  288. $awardedTenderedProject = $tenderResult[$i]['AwardedTenderedProject'];
  289. $resultEntries[$i]['procurementProjectLotID'] = $this->existNodo($awardedTenderedProject, 'ProcurementProjectLotID', 'string');
  290. $resultEntries[$i]['TaxExclusiveAmount'] = $this->existNodo($awardedTenderedProject->LegalMonetaryTotal, 'TaxExclusiveAmount', 'string');
  291. $resultEntries[$i]['PayableAmount'] = $this->existNodo($awardedTenderedProject->LegalMonetaryTotal, 'PayableAmount', 'string');
  292. }
  293. }
  294. }
  295. //$resultFinal = $this->array_remove_empty($resultEntries);
  296. return $resultEntries;
  297. }
  298. private function nodoTenderingTerms($xml)
  299. {
  300. $resultEntries = array();
  301. if (array_key_exists("TenderingTerms", $xml['ContractFolderStatus'])) {
  302. $TenderingTerms = $xml['ContractFolderStatus']['TenderingTerms'];
  303. $resultEntries['tenderingTerm']['requiredCurriculaIndicator'] = $this->existNodo($TenderingTerms, 'RequiredCurriculaIndicator', 'string');
  304. $resultEntries['tenderingTerm']['variantConstraintIndicator'] = $this->existNodo($TenderingTerms, 'VariantConstraintIndicator', 'string');
  305. $resultEntries['tenderingTerm']['fundingProgramCode'] = $this->existNodo($TenderingTerms, 'FundingProgramCode', 'string');
  306. $resultEntries['tenderingTerm']['id_ajena_licitacion'] = $this->idLicitacion;
  307. $resultEntries['tenderingTerm']['id_compuesta'] = $this->idLicitacion . "_07";
  308. $resultEntries['tenderingTerm']['fecha_creacion_log'] = $this->fechaInicioParser;
  309. if (array_key_exists("RequiredFinancialGuarantee", $TenderingTerms)) {
  310. $resultEntries['tenderingTerm']['guaranteeTypeCode'] = $this->existNodo($TenderingTerms['RequiredFinancialGuarantee'], 'GuaranteeTypeCode', 'string');
  311. $resultEntries['tenderingTerm']['guaranteeTypeCode_attr'] = $this->existAttribute($TenderingTerms['RequiredFinancialGuarantee'], "GuaranteeTypeCode", "string", 'listURI');
  312. $resultEntries['tenderingTerm']['requiredFinancialGuarantee_Amount'] = $this->existNodo($TenderingTerms['RequiredFinancialGuarantee'], 'AmountRate', 'string');
  313. }
  314. $resultEntries['tenderingTerm']['procurementLegislationDocumentReference'] = $this->existNodo($TenderingTerms['ProcurementLegislationDocumentReference'], 'ID', 'string');
  315. $resultEntries['tenderingTerm']['allowedSubcontractTerms'] = $this->existNodo($TenderingTerms['AllowedSubcontractTerms'], 'Description', 'string');
  316. if (array_key_exists("AwardingTerms", $TenderingTerms)) {
  317. $tendererAwardingTerms = $TenderingTerms['AwardingTerms']['AwardingCriteria'];
  318. for ($i = 0; $i < count($tendererAwardingTerms); $i++) {
  319. $resultEntries["awardingCriteria"][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($tendererAwardingTerms[$i], 'Description', 'string');
  320. $resultEntries["awardingCriteria"][$i]['description'] = $this->existNodo($tendererAwardingTerms[$i], 'WeightNumeric', 'string');
  321. $resultEntries["awardingCriteria"][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  322. $resultEntries["awardingCriteria"][$i]['id_compuesta'] = $this->idLicitacion . "_07_" . $i;
  323. $resultEntries["awardingCriteria"][$i]['id_compuesta_padre'] = $this->idLicitacion . "_07";
  324. $resultEntries['awardingCriteria'][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  325. }
  326. }
  327. if (array_key_exists("TendererQualificationRequest", $TenderingTerms)) {
  328. $tendererQualificationRequest = $TenderingTerms['TendererQualificationRequest'];
  329. $resultEntries['tenderingTerm']['description'] = $this->existNodo($tendererQualificationRequest, 'Description', 'string');
  330. $resultEntries['tenderingTerm']['personalSituation'] = $this->existNodo($tendererQualificationRequest, 'PersonalSituation', 'string');
  331. for ($i = 0; $i < count($tendererQualificationRequest); $i++) {
  332. if (isset($tendererQualificationRequest[$i]['EvaluationCriteriaTypeCode'])) {
  333. $resultEntries["TendererQualificationRequest"][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($tendererQualificationRequest[$i]['TechnicalEvaluationCriteria'], 'EvaluationCriteriaTypeCode', 'string');
  334. $resultEntries["TendererQualificationRequest"][$i]['evaluationCriteriaTypeCode_attr'] = $this->existAttribute($tendererQualificationRequest[$i]['TechnicalEvaluationCriteria'], "EvaluationCriteriaTypeCode", "sting", 'listURI');
  335. $resultEntries["TendererQualificationRequest"][$i]['description'] = $this->existNodo($tendererQualificationRequest[$i]['TechnicalEvaluationCriteria'], 'Description', 'string');
  336. $resultEntries["TendererQualificationRequest"][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  337. $resultEntries["TendererQualificationRequest"][$i]['id_compuesta'] = $this->idLicitacion . "_07_" . $i;
  338. $resultEntries["TendererQualificationRequest"][$i]['id_compuesta_padre'] = $this->idLicitacion . "_07";
  339. $resultEntries['TendererQualificationRequest'][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  340. }
  341. }
  342. if (array_key_exists("FinancialEvaluationCriteria", $TenderingTerms['TendererQualificationRequest'])) {
  343. $financialEvaluationCriteria = $TenderingTerms['TendererQualificationRequest']['FinancialEvaluationCriteria'];
  344. for ($i = 0; $i < count($financialEvaluationCriteria); $i++) {
  345. $resultEntries["FinancialEvaluationCriteria"][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($financialEvaluationCriteria[$i], 'EvaluationCriteriaTypeCode', 'string');
  346. $resultEntries["FinancialEvaluationCriteria"][$i]['evaluationCriteriaTypeCode_attr'] = $this->existAttribute($financialEvaluationCriteria[$i], "EvaluationCriteriaTypeCode", "string", 'listURI');
  347. $resultEntries["FinancialEvaluationCriteria"][$i]['description'] = $this->existNodo($financialEvaluationCriteria[$i], 'Description', 'string');
  348. $resultEntries["FinancialEvaluationCriteria"][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  349. $resultEntries["FinancialEvaluationCriteria"][$i]['id_compuesta'] = $this->idLicitacion . "_07_" . $i;
  350. $resultEntries["FinancialEvaluationCriteria"][$i]['id_compuesta_padre'] = $this->idLicitacion . "_07";
  351. $resultEntries['FinancialEvaluationCriteria'][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  352. }
  353. }
  354. if (array_key_exists("SpecificTendererRequirement", $TenderingTerms['TendererQualificationRequest'])) {
  355. $specificTendererRequirement = $TenderingTerms['TendererQualificationRequest']['SpecificTendererRequirement'];
  356. for ($i = 0; $i < count($specificTendererRequirement); $i++) {
  357. $resultEntries["SpecificTendererRequirement"][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($specificTendererRequirement[$i]['SpecificTendererRequirement'], 'RequirementTypeCode', 'string');
  358. $resultEntries["SpecificTendererRequirement"][$i]['evaluationCriteriaTypeCode_attr'] = $this->existAttribute($specificTendererRequirement[$i]['SpecificTendererRequirement'], "RequirementTypeCode", "string", 'listURI');
  359. $resultEntries["SpecificTendererRequirement"][$i]['id_ajena_licitacion'] = $this->idLicitacion;
  360. $resultEntries["SpecificTendererRequirement"][$i]['id_compuesta'] = $this->idLicitacion . "_07_" . $i;
  361. $resultEntries["SpecificTendererRequirement"][$i]['id_compuesta_padre'] = $this->idLicitacion . "_07";
  362. $resultEntries['SpecificTendererRequirement'][$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  363. }
  364. }
  365. }
  366. $resultEntries["tenderingTerm"]['language'] = $this->existNodo($TenderingTerms['Language'], 'ID', 'string');
  367. }
  368. return $resultEntries;
  369. }
  370. private function nodoTenderingProcess($xml)
  371. {
  372. $resultEntries = array();
  373. if (array_key_exists("TenderingProcess", $xml['ContractFolderStatus'])) {
  374. $tenderingProcess = $xml['ContractFolderStatus']['TenderingProcess'];
  375. //TenderingProcess
  376. $resultEntries['procedureCode'] = $this->existNodo($tenderingProcess, 'ProcedureCode', 'string');
  377. $resultEntries['procedureCode_attr'] = $this->existAttribute($tenderingProcess, "ProcedureCode", "string", 'listURI');
  378. $resultEntries['urgencyCode'] = $this->existNodo($tenderingProcess, 'UrgencyCode', 'string');
  379. $resultEntries['urgencyCode_attr'] = $this->existAttribute($tenderingProcess, "UrgencyCode", "string", 'listURI');
  380. $resultEntries['contractingSystemCode'] = $this->existNodo($tenderingProcess, 'ContractingSystemCode', 'string');
  381. $resultEntries['contractingSystemCode_attr'] = $this->existAttribute($tenderingProcess, "ContractingSystemCode", "string", 'listURI');
  382. $resultEntries['partPresentationCode'] = $this->existNodo($tenderingProcess, 'PartPresentationCode', 'string');
  383. $resultEntries['partPresentationCode_attr'] = $this->existAttribute($tenderingProcess, "PartPresentationCode", "string", 'listURI');
  384. $resultEntries['submissionMethodCode'] = $this->existNodo($tenderingProcess, 'SubmissionMethodCode', 'string');
  385. $resultEntries['submissionMethodCode_attr'] = $this->existAttribute($tenderingProcess, "SubmissionMethodCode", "string", 'listURI');
  386. $resultEntries['maximumLotPresentationQuantity'] = $this->existNodo($tenderingProcess, 'MaximumLotPresentationQuantity', 'string');
  387. $resultEntries['maximumTendererAwardedLotsQuantity'] = $this->existNodo($tenderingProcess, 'MaximumTendererAwardedLotsQuantity', 'string');
  388. $resultEntries['deadLineEndDate'] = $this->existNodo($tenderingProcess['TenderSubmissionDeadlinePeriod'], 'EndDate', 'string');
  389. $resultEntries['deadLineEndTime'] = $this->existNodo($tenderingProcess['TenderSubmissionDeadlinePeriod'], 'EndTime', 'string');
  390. $resultEntries['deadLineDescription'] = $this->existNodo($tenderingProcess['TenderSubmissionDeadlinePeriod'], 'Description', 'string');
  391. $resultEntries['auctionTerms'] = $this->existNodo($tenderingProcess['AuctionTerms'], 'AuctionConstraintIndicator', 'string');
  392. $resultEntries['LotsCombinationContractingAuthorityRights'] = $this->existNodo($tenderingProcess, 'LotsCombinationContractingAuthorityRights', 'string');
  393. $resultEntries['documentAvailablePeriod_EndDate'] = $this->existNodo($tenderingProcess['DocumentAvailabilityPeriod'], 'EndDate', 'string');
  394. $resultEntries['documentAvailablePeriod_EndTime'] = $this->existNodo($tenderingProcess['DocumentAvailabilityPeriod'], 'EndTime', 'string');
  395. $resultEntries['id_ajena_licitacion'] = $this->idLicitacion;
  396. $resultEntries['id_compuesta'] = $this->idLicitacion . "_08";
  397. $resultEntries['fecha_creacion_log'] = $this->fechaInicioParser;
  398. }
  399. return $resultEntries;
  400. }
  401. private function nodoLegalDoc($xml)
  402. {
  403. $resultEntries = array();
  404. if (array_key_exists("LegalDocumentReference", $xml['ContractFolderStatus'])) {
  405. $legalDocumentReference = $xml['ContractFolderStatus']['LegalDocumentReference'];
  406. $resultEntries['idDoc'] = $this->existNodo($legalDocumentReference, 'ID', 'string');
  407. $resultEntries['attachment'] = $this->existNodo($legalDocumentReference['Attachment']['ExternalReference'], 'URI', 'string');
  408. $resultEntries['documentHash'] = $this->existNodo($legalDocumentReference['Attachment']['ExternalReference'], 'DocumentHash', 'string');
  409. $resultEntries['id_ajena_licitacion'] = $this->idLicitacion;
  410. $resultEntries['id_compuesta'] = $this->idLicitacion . "_09";
  411. $resultEntries['fecha_creacion_log'] = $this->fechaInicioParser;
  412. return $resultEntries;
  413. }
  414. //$resultFinal = $this->checkArrayValuesEmpty($resultEntries);
  415. //return $this->idLicitacion;
  416. }
  417. private function nodoTechnicalDocumentReference($xml)
  418. {
  419. $resultEntries = array();
  420. if (array_key_exists("TechnicalDocumentReference", $xml['ContractFolderStatus'])) {
  421. $technicalDocumentReference = $xml['ContractFolderStatus']['TechnicalDocumentReference'];
  422. $resultEntries['idDoc'] = $this->existNodo($technicalDocumentReference, 'ID', 'string');
  423. $resultEntries['attachment'] = $this->existNodo($technicalDocumentReference['Attachment']['ExternalReference'], 'URI', 'string');
  424. $resultEntries['documentHash'] = $this->existNodo($technicalDocumentReference['Attachment']['ExternalReference'], 'DocumentHash', 'string');
  425. $resultEntries['id_ajena_licitacion'] = $this->idLicitacion;
  426. $resultEntries['id_compuesta'] = $this->idLicitacion . "_10";
  427. $resultEntries['fecha_creacion_log'] = $this->fechaInicioParser;
  428. return $resultEntries;
  429. }
  430. //$resultFinal = $this->checkArrayValuesEmpty($resultEntries);
  431. //return $this->idLicitacion;
  432. }
  433. private function nodoAdditionalDocumentReference($xml)
  434. {
  435. $resultEntries = array();
  436. if (array_key_exists("AdditionalDocumentReference", $xml['ContractFolderStatus'])) {
  437. $additionalDocumentReference = $xml['ContractFolderStatus']['AdditionalDocumentReference'];
  438. if (array_key_first($additionalDocumentReference) !== 0) {
  439. $additionalDocumentReference = array(0 => $additionalDocumentReference);
  440. }
  441. for ($i = 0; $i < count($additionalDocumentReference); $i++) {
  442. $resultEntries[$i]['idDoc'] = $this->existNodo($additionalDocumentReference[$i], 'ID', 'string');
  443. $resultEntries[$i]['attachment'] = $this->existNodo($additionalDocumentReference[$i]['Attachment']['ExternalReference'], 'URI', 'string');
  444. $resultEntries[$i]['documentHash'] = $this->existNodo($additionalDocumentReference[$i]['Attachment']['ExternalReference'], 'DocumentHash', 'string');
  445. $resultEntries[$i]['id_ajena_licitacion'] = $this->idLicitacion;
  446. $resultEntries[$i]['id_compuesta'] = $this->idLicitacion . "_11_" . $i;
  447. $resultEntries[$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  448. }
  449. return $resultEntries;
  450. }
  451. //$resultFinal = $this->checkArrayValuesEmpty($resultEntries);
  452. //return $this->idLicitacion;
  453. }
  454. private function nodoGeneralDocuments($xml)
  455. {
  456. $resultEntries = array();
  457. if (array_key_exists("GeneralDocument", $xml['ContractFolderStatus'])) {
  458. $generalDocument = $xml['ContractFolderStatus']['GeneralDocument'];
  459. if (array_key_first($generalDocument) !== 0) {
  460. $generalDocument = array(0 => $generalDocument);
  461. }
  462. for ($i = 0; $i < count($generalDocument); $i++) {
  463. $resultEntries[$i]['idDoc'] = $this->existNodo($generalDocument[$i]['GeneralDocumentDocumentReference'], 'ID', 'string');
  464. $resultEntries[$i]['attachment'] = $this->existNodo($generalDocument[$i]['GeneralDocumentDocumentReference']['Attachment']['ExternalReference'], 'URI', 'string');
  465. $resultEntries[$i]['fileName'] = $this->existNodo($generalDocument[$i]['GeneralDocumentDocumentReference']['Attachment']['ExternalReference'], 'FileName', 'string');
  466. $resultEntries[$i]['id_ajena_licitacion'] = $this->idLicitacion;
  467. $resultEntries[$i]['id_compuesta'] = $this->idLicitacion . "_13_" . $i;
  468. $resultEntries[$i]['fecha_creacion_log'] = $this->fechaInicioParser;
  469. }
  470. return $resultEntries;
  471. }
  472. //return $this->idLicitacion;
  473. }
  474. /*private function nodoValidNoticeInfo($xml)
  475. {
  476. $resultEntries = array();
  477. if (array_key_exists("ValidNoticeInfo", $xml['ContractFolderStatus'])) {
  478. $validNoticeInfo = $xml['ContractFolderStatus']['ValidNoticeInfo'];
  479. $firstKey = array_key_first($validNoticeInfo);
  480. if ($firstKey !== 0) {
  481. $validNoticeInfo = array(0 => $validNoticeInfo);
  482. }
  483. for ($i = 0; $i < count($validNoticeInfo); $i++) {
  484. $resultEntries[$i]['noticeTypeCode'] = $this->existNodo($validNoticeInfo[$i], 'NoticeTypeCode', 'string');
  485. $resultEntries[$i]['publicationMediaName'] = $this->existNodo($validNoticeInfo[$i]['AdditionalPublicationStatus'], 'PublicationMediaName', 'string');
  486. $resultEntries[$i]['id_ajena_licitacion'] = $this->idLicitacion;
  487. $resultEntries[$i]['id_compuesta'] = $this->idLicitacion . "_12_" . $i;
  488. if (array_key_exists("AdditionalPublicationStatus", $xml['ContractFolderStatus']['ValidNoticeInfo'][$i])) {
  489. $additionalPublicationDocument = $xml['ContractFolderStatus']['ValidNoticeInfo'][$i]['AdditionalPublicationStatus'];
  490. //echo ($this->idLicitacion . "</br>");
  491. if (!is_countable($additionalPublicationDocument['AdditionalPublicationDocumentReference'])) {
  492. echo "idlici" . $this->idLicitacion;
  493. }
  494. if ($firstKey !== 0) {
  495. $additionalPublicationDocument['AdditionalPublicationDocumentReference'] = array(0 => $additionalPublicationDocument['AdditionalPublicationDocumentReference']);
  496. }
  497. for ($j = 0; $j < count($additionalPublicationDocument['AdditionalPublicationDocumentReference']); $j++) {
  498. $firstKey = array_key_first($additionalPublicationDocument['AdditionalPublicationDocumentReference']);
  499. $resultEntries[$i]['fechas'][$j]['fechas'] = $this->existNodo($additionalPublicationDocument['AdditionalPublicationDocumentReference'][$j], 'IssueDate', 'string');
  500. $resultEntries[$i]['fechas'][$j]['id_ajena_licitacion'] = $this->idLicitacion;
  501. $resultEntries[$i]['fechas'][$j]['id_compuesta'] = $this->idLicitacion . "_12_" . $i . "_" . $j;
  502. if ($additionalPublicationDocument['AdditionalPublicationDocumentReference'][$j]['DocumentTypeCode']) {
  503. $resultEntries[$i]['documento'][$j]['documento'] = $this->existNodo($additionalPublicationDocument['AdditionalPublicationDocumentReference'][$j]['Attachment']['ExternalReference'], 'URI', 'string');
  504. $resultEntries[$i]['documento'][$j]['filename'] = $this->existNodo($additionalPublicationDocument['AdditionalPublicationDocumentReference'][$j]['Attachment']['ExternalReference'], 'FileName', 'string');
  505. $resultEntries[$i]['documento'][$j]['id_ajena_licitacion'] = $this->idLicitacion;
  506. $resultEntries[$i]['documento'][$j]['id_compuesta'] = $this->idLicitacion . "_12_" . $i . "_" . $j;
  507. }
  508. }
  509. }
  510. }
  511. }
  512. //$resultFinal = $this->checkArrayValuesEmpty($resultEntries);
  513. return $resultEntries;
  514. }*/
  515. private function existNodo($nodo, $nodoHijo, $tipo)
  516. {
  517. if (isset($nodo) && @count($nodo) > 0) {
  518. return $this->switchTipo($tipo, $nodo[$nodoHijo]);
  519. } else {
  520. return "";
  521. }
  522. }
  523. private function existAttribute($nodo, $nodoHijo, $tipo, $nombreAttributo)
  524. {
  525. $nodoFinal = $nodo->{$nodoHijo};
  526. if (isset($nodoFinal) && !empty($nodoFinal)) {
  527. //if (@count($nodo->{$nodoHijo}) > 0) {
  528. return $this->switchTipoAttribute($tipo, $nodo->{$nodoHijo}, $nombreAttributo);
  529. //}
  530. } else {
  531. return "";
  532. }
  533. }
  534. private function switchTipo($tipo, $nodo)
  535. {
  536. switch ($tipo) {
  537. case 'string':
  538. return (string) $nodo;
  539. break;
  540. case 'int':
  541. return (int) $nodo;
  542. break;
  543. case 'array':
  544. return (array) $nodo;
  545. break;
  546. }
  547. }
  548. private function switchTipoAttribute($tipo, $nodo, $attributo)
  549. {
  550. switch ($tipo) {
  551. case 'string':
  552. return (string) $nodo->attributes()[$attributo];
  553. break;
  554. }
  555. }
  556. }
  557. /* End of file ParserFile.php */
  558. /* Location: ./application/libraries/ParserFile.php */