ParserFile.php 32KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623
  1. <?php
  2. defined('BASEPATH') or exit('No direct script access allowed');
  3. class ParserFile extends CI_Controller
  4. {
  5. protected $rutaDiaria = FCPATH . "DOWNLOADS/DAILY/format";
  6. protected $rutaMensual = FCPATH . "DOWNLOADS/MONTH/format";
  7. protected $esquema = array('cbc-place-ext', 'cac-place-ext', 'cbc', 'cac', 'ns1');
  8. //TODO: Añadir los nodos que falten mirando la libreria de java
  9. //TODO: Crear las tablas segun el nodo
  10. //TODO: Insertar los datos que si existen en el insert_batch.
  11. public function __construct()
  12. {
  13. parent::__construct();
  14. $this->load->helper('file');
  15. $this->load->library('parserDatabase');
  16. }
  17. public function index()
  18. {
  19. $files = get_filenames($this->rutaDiaria, true);
  20. $contadorArchivos = 0;
  21. foreach ($files as $file) {
  22. $entrada = file_get_contents($file);
  23. $xml = simplexml_load_string($entrada);
  24. $aux = 0;
  25. $resultEntries = array();
  26. foreach ($xml->entry as $clave => $row) {
  27. $arrayDeletedEntries = $xml->children('at', true);
  28. $resultEntries[$aux]['general'] = $this->nodoEntry($row);
  29. $resultEntries[$aux]['contractInfo'] = $this->nodoContractFolderStatus($row);
  30. $resultEntries[$aux]['locatedContractingParty'] = $this->nodoLocatedContractingParty($row);
  31. $resultEntries[$aux]['party'] = $this->nodoParty($row);
  32. $resultEntries[$aux]['procurementProject'] = $this->nodoPresupuesto($row);
  33. $resultEntries[$aux]['procurementProjectLot'] = $this->nodoProcurementProjectLot($row);
  34. $resultEntries[$aux]['tenderingTerms'] = $this->nodoTenderingTerms($row);
  35. $resultEntries[$aux]['tenderingProcess'] = $this->nodoTenderingProcess($row);
  36. $resultEntries[$aux]['tenderingResult'] = $this->nodoTenderResult($row);
  37. $resultEntries[$aux]['legalDocs'] = $this->nodoLegalDoc($row);
  38. $resultEntries[$aux]['techicalDocs'] = $this->nodoTechnicalDocumentReference($row);
  39. $resultEntries[$aux]['validNoticeInfo'] = $this->nodoValidNoticeInfo($row);
  40. $resultEntries[$aux]['generalDocs'] = $this->nodoGeneralDocuments($row);
  41. $resultEntries[$aux]['additionalDocs'] = $this->nodoAdditionalDocumentReference($row);
  42. $aux++;
  43. }
  44. $str = print_r($resultEntries, true);
  45. file_put_contents($this->rutaDiaria . "/text" . $contadorArchivos . ".txt", $str);
  46. $contadorArchivos++;
  47. }
  48. }
  49. private function nodoEntry($xml)
  50. {
  51. $resultEntries = array();
  52. $resultEntries['id_url'] = (string) $xml->id;
  53. $resultEntries['id_licitacion'] = (string) substr($xml->id, strrpos($xml->id, '/') + 1);
  54. $resultEntries['link'] = (string) $xml->link;
  55. $resultEntries['link_uri'] = (string) $xml->link->attributes()['href'];
  56. $resultEntries['summary'] = (string) $xml->summary;
  57. $resultEntries['title'] = (string) $xml->title;
  58. $resultEntries['updated'] = (string) $xml->updated;
  59. return $resultEntries;
  60. }
  61. private function nodoContractFolderStatus($xml)
  62. {
  63. $resultEntries = array();
  64. if (isset($xml->ContractFolderStatus)) {
  65. $resultEntries['ContractFolderID'] = (string) $xml->ContractFolderStatus->ContractFolderID;
  66. $resultEntries['ContractFolderStatusCode'] = (string) $xml->ContractFolderStatus->ContractFolderStatusCode;
  67. $resultEntries['ContractFolderStatusCodeAttr'] = (string) $xml->ContractFolderStatus->ContractFolderStatusCode->attributes()['listURI'];
  68. }
  69. $resultFinal = $this->array_remove_empty($resultEntries);
  70. return $resultFinal;
  71. }
  72. private function nodoLocatedContractingParty($xml)
  73. {
  74. $resultEntries = array();
  75. if (isset($xml->ContractFolderStatus->LocatedContractingParty)) {
  76. $LocatedContractingParty = $xml->ContractFolderStatus->LocatedContractingParty;
  77. $resultEntries['contractingPartyTypeCode'] = $this->existNodo($LocatedContractingParty, "ContractingPartyTypeCode", 'string');
  78. $resultEntries['contractingPartyTypeCodeUri'] = (string) $LocatedContractingParty->ContractingPartyTypeCode->attributes()['listURI'];
  79. if (isset($LocatedContractingParty->ActivityCode)) {
  80. if (count($LocatedContractingParty->ActivityCode) > 1) {
  81. for ($i = 0; $i < count($LocatedContractingParty->ActivityCode); $i++) {
  82. $resultEntries['activityCode'][$i] = (string) $LocatedContractingParty->ActivityCode[$i];
  83. //$resultEntries['activityCodeUri'][$i] = $LocatedContractingParty->ActivityCode[$i]->attributes()['listURI'];
  84. }
  85. } else {
  86. $resultEntries['activityCode'][0] = $this->existNodo($LocatedContractingParty, "ActivityCode", 'string');
  87. $resultEntries['activityCodeUri'][0] = (string) $LocatedContractingParty->ActivityCode->attributes()['listURI'];
  88. }
  89. }
  90. $resultEntries['buyerProfileURIID'] = $this->existNodo($LocatedContractingParty, "BuyerProfileURIID", 'string');
  91. if (isset($LocatedContractingParty->ParentLocatedParty)) {
  92. $this->RecurseXML($LocatedContractingParty->ParentLocatedParty);
  93. }
  94. }
  95. $resultFinal = $this->array_remove_empty($resultEntries);
  96. return $resultFinal;
  97. }
  98. private function nodoParty($xml)
  99. {
  100. $resultEntries = array();
  101. $contractFolder = $xml->ContractFolderStatus->LocatedContractingParty;
  102. if (isset($contractFolder->Party)) {
  103. //Datos Empresa -> direccion,nif, etc
  104. //LocatedContractingParty->Party
  105. $party = $contractFolder->Party;
  106. $resultEntries['websiteURI'] = $this->existNodo($party, "WebsiteURI", 'string');
  107. if (isset($party->PartyIdentification)) {
  108. for ($i = 0; $i < $party->PartyIdentification; $i++) {
  109. $resultEntries['partyIdentification'][$i]['id'] = $this->existNodo($party->PartyIdentification, "ID", 'string');
  110. $resultEntries['partyIdentification'][$i]['attr'] = $party->PartyIdentification->attributes()['schemeName'];
  111. }
  112. }
  113. $resultEntries['partyName'] = $this->existNodo($party->PartyName, "Name", 'string');
  114. $resultEntries['city'] = $this->existNodo($party->PostalAddress, "CityName", 'string');
  115. $resultEntries['codpostal'] = $this->existNodo($party->PostalAddress, "PostalZone", 'string');
  116. $resultEntries['direccion'] = $this->existNodo($party->PostalAddress->AddressLine, "Line", 'string');
  117. $resultEntries['country'] = $this->existNodo($party->PostalAddress->Country, "Name", 'string');
  118. $resultEntries['contact_name'] = $this->existNodo($party->Contact, "Name", 'string');
  119. $resultEntries['contact_email'] = $this->existNodo($party->Contact, "ElectronicMail", 'string');
  120. }
  121. $resultFinal = $this->array_remove_empty($resultEntries);
  122. return $resultFinal;
  123. }
  124. private function nodoPresupuesto($xml)
  125. {
  126. $resultEntries = array();
  127. $procurementProject = $xml->ContractFolderStatus->ProcurementProject;
  128. if (isset($procurementProject)) {
  129. //ProcurementProject
  130. $resultEntries['name'] = $this->existNodo($procurementProject, 'Name', 'string');
  131. $resultEntries['typeCode'] = $this->existNodo($procurementProject, 'TypeCode', 'string');
  132. $resultEntries['subTypeCode'] = $this->existNodo($procurementProject, 'SubTypeCode', 'string');
  133. if (isset($procurementProject->BudgetAmount)) {
  134. $resultEntries['estimatedOverallContractAmount'] = $this->existNodo($procurementProject->BudgetAmount, 'EstimatedOverallContractAmount', 'string');
  135. $resultEntries['totalAmount'] = $this->existNodo($procurementProject->BudgetAmount, 'TotalAmount', 'string');
  136. $resultEntries['taxExclusiveAmount'] = $this->existNodo($procurementProject->BudgetAmount, 'TaxExclusiveAmount', 'string');
  137. }
  138. if (isset($procurementProject->RequiredCommodityClassification)) {
  139. for ($i = 0; $i < count($procurementProject->RequiredCommodityClassification); $i++) {
  140. $resultEntries['itemClassification_value'] = $this->existNodo($procurementProject->RequiredCommodityClassification[$i], 'ItemClassificationCode', 'string');
  141. $resultEntries['itemClassification_attr'] = (string) $procurementProject->RequiredCommodityClassification[$i]->ItemClassificationCode['listURI'];
  142. }
  143. }
  144. if (isset($procurementProject->RealizedLocation)) {
  145. $resultEntries['countrySubentity'] = $this->existNodo($procurementProject->RealizedLocation, 'CountrySubentity', 'string');
  146. if (isset($procurementProject->RealizedLocation->CountrySubentityCode)) {
  147. $resultEntries['countrySubentityCode'] = $this->existNodo($procurementProject->RealizedLocation, 'CountrySubentityCode', 'string');
  148. $resultEntries['countrySubentityCode'] = $procurementProject->RealizedLocation->CountrySubentityCode->attributes()['listURI'];
  149. }
  150. if (isset($procurementProject->RealizedLocation->Address)) {
  151. $resultEntries['cityName'] = $this->existNodo($procurementProject->RealizedLocation->Address->Country, 'CityName', 'string');
  152. $resultEntries['IdentificationCode'] = $this->existNodo($procurementProject->RealizedLocation->Address->Country, 'IdentificationCode', 'string');
  153. $resultEntries['countryName'] = $this->existNodo($procurementProject->RealizedLocation->Address->Country, 'Name', 'string');
  154. }
  155. }
  156. $resultEntries['durationMesure'] = $this->existNodo($procurementProject->PlannedPeriod, 'DurationMeasure', 'string');
  157. $resultEntries['duracion_inicio'] = $this->existNodo($procurementProject->PlannedPeriod, 'StartDate', 'string');
  158. $resultEntries['duracion_fin'] = $this->existNodo($procurementProject->PlannedPeriod, 'EndDate', 'string');
  159. if (isset($procurementProject->PlannedPeriod->DurationMeasure)) {
  160. $resultEntries['medida'] = (string) $procurementProject->PlannedPeriod->DurationMeasure->attributes()['unitCode'];
  161. }
  162. $resultEntries['contractExtension'] = $this->existNodo($procurementProject->ContractExtension, 'OptionsDescription', 'string');
  163. }
  164. $resultFinal = $this->array_remove_empty($resultEntries);
  165. return $resultFinal;
  166. }
  167. private function nodoProcurementProjectLot($xml)
  168. {
  169. $resultEntries = array();
  170. $procurementProjectLot = $xml->ContractFolderStatus->ProcurementProjectLot;
  171. if (isset($procurementProjectLot)) {
  172. for ($i = 0; $i < count($procurementProjectLot); $i++) {
  173. $resultEntries[$i]['id'] = $this->existNodo($procurementProjectLot[$i], 'ID', 'string');
  174. $resultEntries[$i]['name'] = $this->existNodo($procurementProjectLot[$i]->ProcurementProject, 'Name', 'string');
  175. $resultEntries[$i]['totalAmount'] = $this->existNodo($procurementProjectLot[$i]->ProcurementProject->BudgetAmount, 'TotalAmount', 'string');
  176. $resultEntries[$i]['taxExclusiveAmount'] = $this->existNodo($procurementProjectLot[$i]->ProcurementProject->BudgetAmount, 'TaxExclusiveAmount', 'string');
  177. $clasificacionItems = $procurementProjectLot[$i]->ProcurementProject->RequiredCommodityClassification;
  178. if (isset($clasificacionItems)) {
  179. for ($j = 0; $j < count($clasificacionItems); $j++) {
  180. $resultEntries[$i]['itemClassification']['id'][$j] = $clasificacionItems[$j]->ItemClassificationCode;
  181. $resultEntries[$i]['itemClassification']['id_attr'][$j] = (string) $clasificacionItems[$j]->ItemClassificationCode->attributes()['listURI'];
  182. }
  183. }
  184. if (isset($procurementProjectLot[$i]->RealizedLocation)) {
  185. $resultEntries[$i]['countrySubentity'] = $this->existNodo($procurementProjectLot[$i]->ProcurementProject->RealizedLocation, 'CountrySubentity', 'string');
  186. $resultEntries[$i]['countrySubentityCode'] = $this->existNodo($procurementProjectLot[$i]->ProcurementProject->RealizedLocation, 'CountrySubentityCode', 'string');
  187. $resultEntries[$i]['identificationCode'] = $this->existNodo($procurementProjectLot[$i]->ProcurementProject->RealizedLocation->Address->Country, 'IdentificationCode', 'string');
  188. $resultEntries[$i]['name'] = $this->existNodo($procurementProjectLot[$i]->ProcurementProject->RealizedLocation->Address->Country, 'Name', 'string');
  189. }
  190. }
  191. }
  192. $resultFinal = $this->array_remove_empty($resultEntries);
  193. return $resultFinal;
  194. }
  195. private function nodoTenderResult($xml)
  196. {
  197. $resultEntries = array();
  198. $tenderResult = $xml->ContractFolderStatus->TenderResult;
  199. for ($i = 0; $i < count($tenderResult); $i++) {
  200. $resultEntries[$i]['resultCode'] = $this->existNodo($tenderResult[$i], 'ResultCode', 'string');
  201. $resultEntries[$i]['description'] = $this->existNodo($tenderResult[$i], 'Description', 'string');
  202. $resultEntries[$i]['awardDate'] = $this->existNodo($tenderResult[$i], 'AwardDate', 'string');
  203. $resultEntries[$i]['receivedTenderQuantity'] = $this->existNodo($tenderResult[$i], 'ReceivedTenderQuantity', 'string');
  204. $resultEntries[$i]['lowerTenderAmount'] = $this->existNodo($tenderResult[$i], 'LowerTenderAmount', 'string');
  205. $resultEntries[$i]['higherTenderAmount'] = $this->existNodo($tenderResult[$i], 'HigherTenderAmount', 'string');
  206. $resultEntries[$i]['startDate'] = $this->existNodo($tenderResult[$i], 'StartDate', 'string');
  207. $resultEntries[$i]['smeawardedIndicator'] = $this->existNodo($tenderResult[$i], 'SMEAwardedIndicator', 'string');
  208. //AwardedTenderedProject
  209. $resultEntries[$i]['contract_id'] = $this->existNodo($tenderResult[$i]->Contract, 'ID', 'string');
  210. $resultEntries[$i]['contract_issueDate'] = $this->existNodo($tenderResult[$i]->Contract, 'IssueDate', 'string');
  211. $winningParty = $tenderResult[$i]->WinningParty;
  212. if (isset($winningParty)) {
  213. $resultEntries[$i]['partyIdentification'] = $this->existNodo($winningParty->PartyIdentification, 'ID', 'string');
  214. $resultEntries[$i]['partyName'] = $this->existNodo($winningParty->PartyName, 'Name', 'string');
  215. }
  216. $awardedTenderedProject = $tenderResult[$i]->AwardedTenderedProject;
  217. if (isset($awardedTenderedProject)) {
  218. $resultEntries[$i]['procurementProjectLotID'] = $this->existNodo($awardedTenderedProject, 'ProcurementProjectLotID', 'string');
  219. $resultEntries[$i]['TaxExclusiveAmount'] = $this->existNodo($awardedTenderedProject->LegalMonetaryTotal, 'TaxExclusiveAmount', 'string');
  220. $resultEntries[$i]['PayableAmount'] = $this->existNodo($awardedTenderedProject->LegalMonetaryTotal, 'PayableAmount', 'string');
  221. }
  222. }
  223. $resultFinal = $this->array_remove_empty($resultEntries);
  224. return $resultFinal;
  225. }
  226. private function nodoTenderingTerms($xml)
  227. {
  228. $resultEntries = array();
  229. $TenderingTerms = $xml->ContractFolderStatus->TenderingTerms;
  230. if (isset($TenderingTerms)) {
  231. $resultEntries['requiredCurriculaIndicator'] = $this->existNodo($TenderingTerms, 'RequiredCurriculaIndicator', 'string');
  232. $resultEntries['variantConstraintIndicator'] = $this->existNodo($TenderingTerms, 'VariantConstraintIndicator', 'string');
  233. $resultEntries['fundingProgramCode'] = $this->existNodo($TenderingTerms, 'FundingProgramCode', 'string');
  234. if (isset($TenderingTerms->RequiredFinancialGuarantee->GuaranteeTypeCode)) {
  235. $resultEntries['guaranteeTypeCode'] = $this->existNodo($TenderingTerms->RequiredFinancialGuarantee, 'GuaranteeTypeCode', 'string');
  236. $resultEntries['guaranteeTypeCode_attr'] = $TenderingTerms->RequiredFinancialGuarantee->GuaranteeTypeCode->attributes()['listURI'];
  237. $resultEntries['requiredFinancialGuarantee_Amount'] = $this->existNodo($TenderingTerms->RequiredFinancialGuarantee, 'AmountRate', 'string');
  238. }
  239. $resultEntries['procurementLegislationDocumentReference'] = $this->existNodo($TenderingTerms->ProcurementLegislationDocumentReference, 'ID', 'string');
  240. $resultEntries['allowedSubcontractTerms'] = $this->existNodo($TenderingTerms->AllowedSubcontractTerms, 'Description', 'string');
  241. $tendererAwardingTerms = $TenderingTerms->AwardingTerms;
  242. if (count($tendererAwardingTerms)) {
  243. for ($i = 0; $i < count($tendererAwardingTerms->AwardingCriteria); $i++) {
  244. $resultEntries['awardingTerms'][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($tendererAwardingTerms[$i], 'Description', 'string');
  245. $resultEntries['awardingTerms'][$i]['description'] = $this->existNodo($tendererAwardingTerms[$i], 'WeightNumeric', 'string');
  246. }
  247. }
  248. $tendererQualificationRequest = $TenderingTerms->TendererQualificationRequest;
  249. if (isset($tendererQualificationRequest)) {
  250. $resultEntries['tendererQualificationRequest']['description'] = $this->existNodo($tendererQualificationRequest, 'Description', 'string');
  251. for ($i = 0; $i < count($tendererQualificationRequest); $i++) {
  252. $resultEntries['tendererQualificationRequest'][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($tendererQualificationRequest[$i]->TechnicalEvaluationCriteria, 'EvaluationCriteriaTypeCode', 'string');
  253. $resultEntries['tendererQualificationRequest'][$i]['evaluationCriteriaTypeCode_attr'] = $tendererQualificationRequest[$i]->TechnicalEvaluationCriteria->EvaluationCriteriaTypeCode->attributes()['listURI'];
  254. $resultEntries['tendererQualificationRequest'][$i]['description'] = $this->existNodo($tendererQualificationRequest[$i]->TechnicalEvaluationCriteria, 'Description', 'string');
  255. }
  256. }
  257. $financialEvaluationCriteria = $TenderingTerms->TendererQualificationRequest->FinancialEvaluationCriteria;
  258. if (count($financialEvaluationCriteria)) {
  259. for ($i = 0; $i < count($financialEvaluationCriteria); $i++) {
  260. $resultEntries['financialEvaluationCriteria'][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($financialEvaluationCriteria[$i]->EvaluationCriteriaTypeCode, 'EvaluationCriteriaTypeCode', 'string');
  261. $resultEntries['financialEvaluationCriteria'][$i]['evaluationCriteriaTypeCode_attr'] = $financialEvaluationCriteria[$i]->EvaluationCriteriaTypeCode->EvaluationCriteriaTypeCode->attributes()['listURI'];
  262. $resultEntries['financialEvaluationCriteria'][$i]['description'] = $this->existNodo($financialEvaluationCriteria[$i]->EvaluationCriteriaTypeCode, 'Description', 'string');
  263. }
  264. }
  265. $specificTendererRequirement = $TenderingTerms->TendererQualificationRequest->SpecificTendererRequirement;
  266. if (count($specificTendererRequirement)) {
  267. for ($i = 0; $i < count($specificTendererRequirement); $i++) {
  268. $resultEntries['financialEvaluationCriteria'][$i]['evaluationCriteriaTypeCode'] = $this->existNodo($specificTendererRequirement[$i]->SpecificTendererRequirement, 'RequirementTypeCode', 'string');
  269. $resultEntries['financialEvaluationCriteria'][$i]['evaluationCriteriaTypeCode_attr'] = $specificTendererRequirement[$i]->SpecificTendererRequirement->RequirementTypeCode->attributes()['listURI'];
  270. }
  271. }
  272. $resultEntries['language'] = $this->existNodo($TenderingTerms->Language, 'ID', 'string');
  273. }
  274. $resultFinal = $this->array_remove_empty($resultEntries);
  275. return $resultFinal;
  276. }
  277. private function nodoTenderingProcess($xml)
  278. {
  279. $resultEntries = array();
  280. $tenderingProcess = $xml->ContractFolderStatus->TenderingProcess;
  281. if (isset($tenderingProcess)) {
  282. //TenderingProcess
  283. if (isset($tenderingProcess->ProcedureCode)) {
  284. $resultEntries['procedureCode'] = $this->existNodo($tenderingProcess, 'ProcedureCode', 'string');
  285. $resultEntries['procedureCode_attr'] = $tenderingProcess->ProcedureCode->attributes()['listURI'];
  286. }
  287. if (isset($tenderingProcess->UrgencyCode)) {
  288. $resultEntries['urgencyCode'] = $this->existNodo($tenderingProcess, 'UrgencyCode', 'string');
  289. $resultEntries['urgencyCode_attr'] = $tenderingProcess->UrgencyCode->attributes()['listURI'];
  290. }
  291. if (isset($tenderingProcess->ContractingSystemCode)) {
  292. $resultEntries['contractingSystemCode'] = $this->existNodo($tenderingProcess, 'ContractingSystemCode', 'string');
  293. $resultEntries['contractingSystemCode_attr'] = $tenderingProcess->ContractingSystemCode->attributes()['listURI'];
  294. }
  295. if (isset($tenderingProcess->partPresentationCode)) {
  296. $resultEntries['partPresentationCode'] = $this->existNodo($tenderingProcess, 'partPresentationCode', 'string');
  297. $resultEntries['partPresentationCode_attr'] = $tenderingProcess->partPresentationCode->attributes()['listURI'];
  298. }
  299. if (isset($tenderingProcess->submissionMethodCode)) {
  300. $resultEntries['submissionMethodCode'] = $this->existNodo($tenderingProcess, 'submissionMethodCode', 'string');
  301. $resultEntries['submissionMethodCode_attr'] = $tenderingProcess->submissionMethodCode->attributes()['listURI'];
  302. }
  303. $resultEntries['maximumLotPresentationQuantity'] = $this->existNodo($tenderingProcess, 'MaximumLotPresentationQuantity', 'string');
  304. $resultEntries['maximumTendererAwardedLotsQuantity'] = $this->existNodo($tenderingProcess, 'MaximumTendererAwardedLotsQuantity', 'string');
  305. $resultEntries['deadLineEndDate'] = $this->existNodo($tenderingProcess->TenderSubmissionDeadlinePeriod, 'EndDate', 'string');
  306. $resultEntries['deadLineEndTime'] = $this->existNodo($tenderingProcess->TenderSubmissionDeadlinePeriod, 'EndTime', 'string');
  307. $resultEntries['deadLineDescription'] = $this->existNodo($tenderingProcess->TenderSubmissionDeadlinePeriod, 'Description', 'string');
  308. $resultEntries['auctionTerms'] = $this->existNodo($tenderingProcess->AuctionTerms, 'AuctionConstraintIndicator', 'string');
  309. $resultEntries['LotsCombinationContractingAuthorityRights'] = $this->existNodo($tenderingProcess, 'LotsCombinationContractingAuthorityRights', 'string');
  310. $resultEntries['documentAvailablePeriod_EndDate'] = $this->existNodo($tenderingProcess->DocumentAvailabilityPeriod, 'EndDate', 'string');
  311. $resultEntries['documentAvailablePeriod_EndTime'] = $this->existNodo($tenderingProcess->DocumentAvailabilityPeriod, 'EndTime', 'string');
  312. }
  313. $resultFinal = $this->array_remove_empty($resultEntries);
  314. return $resultFinal;
  315. }
  316. private function nodoLegalDoc($xml)
  317. {
  318. $resultEntries = array();
  319. $legalDocumentReference = $xml->ContractFolderStatus->LegalDocumentReference;
  320. if (isset($legalDocumentReference)) {
  321. for ($i = 0; $i < count($legalDocumentReference); $i++) {
  322. $resultEntries[$i]['id'] = $this->existNodo($legalDocumentReference[$i], 'ID', 'string');
  323. $resultEntries[$i]['attachment'] = $this->existNodo($legalDocumentReference[$i]->Attachment->ExternalReference, 'URI', 'string');
  324. $resultEntries[$i]['documentHash'] = $this->existNodo($legalDocumentReference[$i]->Attachment->ExternalReference, 'DocumentHash', 'string');
  325. }
  326. }
  327. $resultFinal = $this->array_remove_empty($resultEntries);
  328. return $resultFinal;
  329. }
  330. private function nodoTechnicalDocumentReference($xml)
  331. {
  332. $resultEntries = array();
  333. $technicalDocumentReference = $xml->ContractFolderStatus->TechnicalDocumentReference;
  334. if (isset($technicalDocumentReference)) {
  335. for ($i = 0; $i < count($technicalDocumentReference); $i++) {
  336. $resultEntries[$i]['id'] = $this->existNodo($technicalDocumentReference[$i], 'ID', 'string');
  337. $resultEntries[$i]['attachment'] = $this->existNodo($technicalDocumentReference[$i]->Attachment->ExternalReference, 'URI', 'string');
  338. $resultEntries[$i]['documentHash'] = $this->existNodo($technicalDocumentReference[$i]->Attachment->ExternalReference, 'DocumentHash', 'string');
  339. }
  340. }
  341. $resultFinal = $this->array_remove_empty($resultEntries);
  342. return $resultFinal;
  343. }
  344. private function nodoAdditionalDocumentReference($xml)
  345. {
  346. $resultEntries = array();
  347. $additionalDocumentReference = $xml->ContractFolderStatus->AdditionalDocumentReference;
  348. if (isset($additionalDocumentReference)) {
  349. for ($i = 0; $i < count($additionalDocumentReference); $i++) {
  350. $resultEntries[$i]['id'] = $this->existNodo($additionalDocumentReference[$i], 'ID', 'string');
  351. $resultEntries[$i]['attachment'] = $this->existNodo($additionalDocumentReference[$i]->Attachment->ExternalReference, 'URI', 'string');
  352. $resultEntries[$i]['documentHash'] = $this->existNodo($additionalDocumentReference[$i]->Attachment->ExternalReference, 'DocumentHash', 'string');
  353. }
  354. }
  355. $resultFinal = $this->array_remove_empty($resultEntries);
  356. return $resultFinal;
  357. }
  358. private function nodoValidNoticeInfo($xml)
  359. {
  360. $resultEntries = array();
  361. $validNoticeInfo = $xml->ContractFolderStatus->ValidNoticeInfo;
  362. if (isset($validNoticeInfo)) {
  363. for ($i = 0; $i < count($validNoticeInfo); $i++) {
  364. $resultEntries[$i]['noticeTypeCode'] = $this->existNodo($validNoticeInfo[$i], 'NoticeTypeCode', 'string');
  365. $resultEntries[$i]['publicationMediaName'] = $this->existNodo($validNoticeInfo[$i]->AdditionalPublicationStatus, 'PublicationMediaName', 'string');
  366. if (isset($validNoticeInfo[$i]->AdditionalPublicationStatus)) {
  367. for ($j = 0; $j < count($validNoticeInfo[$i]->AdditionalPublicationStatus->AdditionalPublicationDocumentReference); $j++) {
  368. $resultEntries[$i]['fechas'] = $this->existNodo($validNoticeInfo[$i]->AdditionalPublicationStatus->AdditionalPublicationDocumentReference[$j], 'IssueDate', 'string');
  369. if ($validNoticeInfo[$i]->AdditionalPublicationStatus->AdditionalPublicationDocumentReference[$j]->DocumentTypeCode) {
  370. $resultEntries[$i]['documento']['documento'][] = $this->existNodo($validNoticeInfo[$i]->AdditionalPublicationStatus->AdditionalPublicationDocumentReference[$j]->Attachment->ExternalReference, 'URI', 'string');
  371. $resultEntries[$i]['documento']['filename'][] = $this->existNodo($validNoticeInfo[$i]->AdditionalPublicationStatus->AdditionalPublicationDocumentReference[$j]->Attachment->ExternalReference, 'FileName', 'string');
  372. }
  373. }
  374. }
  375. }
  376. }
  377. $resultFinal = $this->array_remove_empty($resultEntries);
  378. return $resultFinal;
  379. }
  380. private function nodoGeneralDocuments($xml)
  381. {
  382. $resultEntries = array();
  383. $generalDocument = $xml->ContractFolderStatus->GeneralDocument->GeneralDocumentDocumentReference;
  384. if (isset($generalDocument)) {
  385. for ($i = 0; $i < count($generalDocument); $i++) {
  386. $resultEntries[$i]['id'] = $this->existNodo($generalDocument[$i], 'ID', 'string');
  387. $resultEntries[$i]['attachment'] = $this->existNodo($generalDocument[$i]->Attachment->ExternalReference, 'URI', 'string');
  388. $resultEntries[$i]['documentHash'] = $this->existNodo($generalDocument[$i]->Attachment->ExternalReference, 'DocumentHash', 'string');
  389. }
  390. }
  391. $resultFinal = $this->array_remove_empty($resultEntries);
  392. return $resultFinal;
  393. }
  394. private function existNodo($nodo, $nodoHijo, $tipo)
  395. {
  396. if (isset($nodo) && @count($nodo) > 0) {
  397. return $this->switchTipo($tipo, $nodo->{$nodoHijo});
  398. } else {
  399. return "";
  400. }
  401. }
  402. private function switchTipo($tipo, $nodo)
  403. {
  404. switch ($tipo) {
  405. case 'string':
  406. return (string) $nodo;
  407. break;
  408. case 'int':
  409. return (int) $nodo;
  410. break;
  411. case 'array':
  412. return (array) $nodo;
  413. break;
  414. }
  415. }
  416. private function recurseXML($xml, $parent = "")
  417. {
  418. $child_count = 0;
  419. $result = array();
  420. foreach ($xml as $key => $value) {
  421. $child_count++;
  422. if ($this->RecurseXML($value, $parent . "." . $key) == 0) // no childern, aka "leaf node"
  423. {
  424. //print($parent . "." . (string) $key . " = " . (string) $value . "<BR>\n");
  425. }
  426. }
  427. return $child_count;
  428. }
  429. public function array_remove_empty($haystack)
  430. {
  431. foreach ($haystack as $key => $value) {
  432. if (is_array($value)) {
  433. $haystack[$key] = $this->array_remove_empty($haystack[$key]);
  434. }
  435. if (empty($haystack[$key])) {
  436. unset($haystack[$key]);
  437. }
  438. }
  439. return $haystack;
  440. }
  441. /* public function xml2array($xml)
  442. {
  443. $arr = array();
  444. foreach ($xml->getNamespaces() + array(null) as $prefix => $namespace) {
  445. foreach ($xml->attributes($namespace) as $key => $value) {
  446. // Add prefixes to prefixed attributes
  447. if (is_string($prefix)) {
  448. $key = $prefix . '.' . $key;
  449. }
  450. $arr['@attributes'][$key] = (string) $value;
  451. }
  452. }
  453. foreach ($xml as $name => $element) {
  454. $value = $element->children() ? $this->xml2array($element) : trim($element);
  455. if ($value) {
  456. if (!isset($arr[$name])) {
  457. $arr[$name] = $value;
  458. } else {
  459. foreach ((array) $value as $k => $v) {
  460. if (is_numeric($k)) {
  461. $arr[$name][] = $v;
  462. } else {
  463. $arr[$name][$k] = array_merge(
  464. (array) $arr[$name][$k],
  465. (array) $v
  466. );
  467. }
  468. }
  469. }
  470. }
  471. }
  472. if ($content = trim((string) $xml)) {
  473. $arr[] = $content;
  474. }
  475. return $arr;
  476. }
  477. $reader = new \XMLReader;
  478. $reader->open($file); // where $path is the file path to the xml file
  479. // using a dirty trick to skip most of the xml that is irrelevant where $nodeName is the node im looking for
  480. // then in the next while loop i skip to the next node
  481. $data = array();
  482. while ($reader->read() && $reader->name !== "data");
  483. while ($reader->name === "data") {
  484. $doc = new \DOMDocument;
  485. $dom = $doc->importNode($reader->expand(), true);
  486. $data = $this->processDom($dom);
  487. $reader->next($dom->localName);
  488. }
  489. public function processDom(\DOMNode $node)
  490. {
  491. $data = [];
  492. /** @var \DomNode $childNode
  493. foreach ($node->childNodes as $childNode) {
  494. // child nodes include of a lot of #text nodes which are irrelevant for me, so i just skip them
  495. if ($childNode->nodeName === '#text') {
  496. continue;
  497. }
  498. $childData = $this->processDom($childNode);
  499. if ($childData === null || $childData === []) {
  500. $data[$childNode->localName] = $childNode->nodeValue;
  501. } else {
  502. $data[$childNode->localName] = $childData;
  503. }
  504. }
  505. return $data;
  506. }
  507. */
  508. }
  509. /* End of file ParserFile.php */
  510. /* Location: ./application/controllers/ParserFile.php */