ParserFile.php 43KB

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