Severity: 8192
Message: Return type of CI_Session_files_driver::open($save_path, $name) should either be compatible with SessionHandlerInterface::open(string $path, string $name): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice
Filename: drivers/Session_files_driver.php
Line Number: 132
Backtrace:
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/apprQZ2LZ/controllers/Welcome.php
Line: 9
Function: __construct
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/index.php
Line: 315
Function: require_once
Severity: 8192
Message: Return type of CI_Session_files_driver::close() should either be compatible with SessionHandlerInterface::close(): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice
Filename: drivers/Session_files_driver.php
Line Number: 292
Backtrace:
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/apprQZ2LZ/controllers/Welcome.php
Line: 9
Function: __construct
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/index.php
Line: 315
Function: require_once
Severity: 8192
Message: Return type of CI_Session_files_driver::read($session_id) should either be compatible with SessionHandlerInterface::read(string $id): string|false, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice
Filename: drivers/Session_files_driver.php
Line Number: 166
Backtrace:
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/apprQZ2LZ/controllers/Welcome.php
Line: 9
Function: __construct
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/index.php
Line: 315
Function: require_once
Severity: 8192
Message: Return type of CI_Session_files_driver::write($session_id, $session_data) should either be compatible with SessionHandlerInterface::write(string $id, string $data): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice
Filename: drivers/Session_files_driver.php
Line Number: 235
Backtrace:
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/apprQZ2LZ/controllers/Welcome.php
Line: 9
Function: __construct
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/index.php
Line: 315
Function: require_once
Severity: 8192
Message: Return type of CI_Session_files_driver::destroy($session_id) should either be compatible with SessionHandlerInterface::destroy(string $id): bool, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice
Filename: drivers/Session_files_driver.php
Line Number: 315
Backtrace:
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/apprQZ2LZ/controllers/Welcome.php
Line: 9
Function: __construct
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/index.php
Line: 315
Function: require_once
Severity: 8192
Message: Return type of CI_Session_files_driver::gc($maxlifetime) should either be compatible with SessionHandlerInterface::gc(int $max_lifetime): int|false, or the #[\ReturnTypeWillChange] attribute should be used to temporarily suppress the notice
Filename: drivers/Session_files_driver.php
Line Number: 356
Backtrace:
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/apprQZ2LZ/controllers/Welcome.php
Line: 9
Function: __construct
File: /home/pedrorui/code.pedroruizhidalgo.es/api/v5/index.php
Line: 315
Function: require_once
Any service call has https://code.pedroruizhidalgo.es/api/v5
as API root. Let's call it in this manual [apiroot]
For every service call you need to provide your own [apikey]
. This can be obtained in https://pedroruizhidalgo.es/createapiaccount.
The [apikey]
consists in a string of 32 character length.
The general url format is [apiroot]/[service]/[renderway]/[apikey]
.
For example: To get your user data visit [apiroot]/user/json/[apikey]
There are three ways to render the results:
Ex: If you want to get your geolocation data in json format, call it like. [apiroot]/users/json/[apikey]
.
A successfull process will display this screen:
After create your account you will receive an email like :
Of course, activation service has the three render ways. Nevertheless, if you follow the email's link, shall render in html, unless you type manually the url. Like this:
[apiroot]/activation/[rendermode]/[apikey]
Access mode [apiroot]/checkiban/[rendermode]/[iban]/[apikey]
(This example was obtained when searching in google "example iban".)
{ "account": "0532013000", "bank": "37040044", "bban": "370400440532013000", "branch": "", "checksum": "89", "country": "DE", "country_central": "Deutsche Bundesbank", "country_central_url": "http://www.bundesbank.de/", "human_format": "DE89 3704 0044 0532 0130 00", "nationalchecksum": "" }
As you can see, we provide the iban decomposed format, human readable format, the sum of control and the national bank of this country, among others.
If iban is not valid we provide:
{ "iban": "DE89370400440532013014", "validate": "false" }
Access mode:
[apiroot]/currencies/[rendermode]/[apikey]
Bellow are shown not real exchanges. We present random data.
{ "datetime": "2024-09-13 19:36:38", "currency": "EUR", "AED": 8.2682548683455, "AFN": 4.5998712655156, "ALL": 11.313693930541, "AMD": 3.9441687450484, "ANG": 8.4070134127545, "AOA": 8.5906672247642, "ARS": 6.7568639324777, "AUD": 6.7383583983119, "AWG": 9.7582133816361, "AZN": 10.534355275582, "BAM": 6.3024414862983, "BBD": 4.1044517518508, "BDT": 6.5588047246257, "BGN": 7.5537753247441, "BHD": 5.1800854807627, "BIF": 8.7494558793257, "BMD": 10.505268063166, "BND": 7.5542170217048, "BOB": 8.7818443471481, "BRL": 4.3608565676775, "BSD": 9.4193989273251, "BTC": 11.650649213535, "BTN": 10.548652177466, "BWP": 4.2006677385423, "BYN": 3.9436977286561, "BYR": 4.2446690822228, "BZD": 6.2999392013531, "CAD": 5.902004164598, "CDF": 8.8181503404948, "CHF": 9.4832524347507, "CLF": 10.227971267061, "CLP": 9.1526039220172, "CNY": 8.0840736981873, "COP": 7.1754715960359, "CRC": 6.1080562687051, "CUC": 7.8818647055337, "CUP": 6.9702168018418, "CVE": 4.4179755861023, "CZK": 11.183567102618, "DJF": 4.8978257663072, "DKK": 8.5753503933434, "DOP": 6.2418010217332, "DZD": 7.8591337664328, "EGP": 7.287220675632, "ERN": 6.6972693557373, "ETB": 11.952585896921, "EUR": 1, "FJD": 7.8023430643614, "FKP": 5.8264392529737, "GBP": 4.0317199006824, "GEL": 7.8000102382153, "GGP": 7.4146231764064, "GHS": 7.3494711147386, "GIP": 10.550350033003, "GMD": 8.3377048784577, "GNF": 6.2422499336499, "GTQ": 3.0252256207286, "GYD": 6.7693504503785, "HKD": 5.4608659522891, "HNL": 7.2222079104847, "HRK": 7.6007380171682, "HTG": 7.0538093364117, "HUF": 5.4070129992473, "IDR": 6.8442140113768, "ILS": 8.730179860131, "IMP": 7.6130653920644, "INR": 5.7999692679383, "IQD": 5.3190341276671, "IRR": 4.0483133415917, "ISK": 11.853465710698, "JEP": 11.922534083446, "JMD": 6.7331035121964, "JOD": 6.8175006126135, "JPY": 6.9757767384759, "KES": 4.1446261108595, "KGS": 3.4447102260053, "KHR": 10.41442327081, "KMF": 4.3866978899514, "KPW": 6.356901092621, "KRW": 9.978890697462, "KWD": 4.4712555401359, "KYD": 6.7852525505169, "KZT": 9.0755254477614, "LAK": 9.8503371825676, "LBP": 8.4761351651867, "LKR": 5.3269138053651, "LRD": 12.354984653813, "LSL": 6.4965434020835, "LTL": 9.8898672838182, "LVL": 3.3201852749661, "LYD": 11.88096993737, "MAD": 8.910013975068, "MDL": 6.3545879318167, "MGA": 9.3822621765464, "MKD": 5.5546116407749, "MMK": 11.161652004422, "MNT": 7.9684405247534, "MOP": 6.4354789151975, "MRO": 4.0237118410988, "MUR": 11.465546720878, "MVR": 9.7094729005869, "MWK": 9.2044955614044, "MXN": 8.2217853475464, "MYR": 5.6468176379087, "MZN": 5.3902671087488, "NAD": 9.0322039723546, "NGN": 6.3438648243173, "NIO": 9.0007822480988, "NOK": 10.623682553239, "NPR": 9.6239525776468, "NZD": 4.5531671101009, "OMR": 4.1829743702817, "PAB": 10.073797942639, "PEN": 8.7677771070822, "PGK": 6.0657352926516, "PHP": 7.6010145487269, "PKR": 7.7480118264202, "PLN": 7.9195343860982, "PYG": 6.2291545626843, "QAR": 8.2864857117117, "RON": 5.2838233356754, "RSD": 7.3003683012446, "RUB": 11.148561597871, "RWF": 11.115004410555, "SAR": 10.394890070145, "SBD": 6.5319694357607, "SCR": 7.1989754299628, "SDG": 8.8367130792871, "SEK": 7.8184625454333, "SGD": 5.4644765613901, "SHP": 4.3561102716979, "SLL": 5.179389623543, "SOS": 7.4600552415755, "SRD": 10.30988801518, "STD": 3.8952950443585, "SVC": 9.3795264732929, "SYP": 4.6105001385373, "SZL": 8.558896311819, "THB": 9.8815764667846, "TJS": 8.0182881401937, "TMT": 8.0231096791211, "TND": 7.8164635555895, "TOP": 5.1858603047141, "TRY": 8.077915888316, "TTD": 8.1463331548247, "TWD": 5.5154688723923, "TZS": 6.0654013362086, "UAH": 6.6281816836578, "UGX": 12.772042269712, "USD": 9.590802605539, "UYU": 7.4638426673896, "UZS": 9.3343351987816, "VEF": 7.398247531335, "VND": 6.1686936915706, "VUV": 6.0019774278635, "WST": 10.135269125987, "XAF": 8.1836819961591, "XAG": 9.2879982452318, "XAU": 9.6120832453538, "XCD": 5.9165994696862, "XDR": 5.9151236554213, "XOF": 12.325955593645, "XPF": 8.1203140202539, "YER": 9.3409216102869, "ZAR": 5.464685403027, "ZMK": 8.2232108773772, "ZMW": 8.0304812789105, "ZWL": 10.25450142578 }go to summary
The ISO 4217 code list is used in banking and business globally.
Access mode:[apiroot]/currencies/[coin_names]/[render]/[apikey]
{ "AED": "United Arab Emirates Dirham", "AFN": "Afghanistan Afghani", "ALL": "Albania Lek", "AMD": "Armenia Dram", "ANG": "Netherlands Antilles Guilder", "AOA": "Angola Kwanza", "ARS": "Argentina Peso", "AUD": "Australia Dollar", "AWG": "Aruba Guilder", "AZN": "Azerbaijan Manat", "BAM": "Bosnia and Herzegovina Convertible Marka", "BBD": "Barbados Dollar", "BDT": "Bangladesh Taka", "BGN": "Bulgaria Lev", "BHD": "Bahrain Dinar", "BIF": "Burundi Franc", "BMD": "Bermuda Dollar", ... "VEF": "Venezuela Bolívar", "VND": "Viet Nam Dong", "VUV": "Vanuatu Vatu", "WST": "Samoa Tala", "XAF": "Communauté Financière Africaine (BEAC) CFA Franc BEAC", "XCD": "East Caribbean Dollar", "XDR": "International Monetary Fund (IMF) Special Drawing Rights", "XOF": "Communauté Financière Africaine (BCEAO) Franc", "XPF": "Comptoirs Français du Pacifique (CFP) Franc", "YER": "Yemen Rial", "ZAR": "South Africa Rand", "ZMW": "Zambia Kwacha", "ZWD": "Zimbabwe Dollar" }
Alias of currency service
Access mode:
[apiroot]/geolocation/[rendermode]/[apikey]/[optional IP address]
Call geolocation service whith out the optional IP address for get your own IP. In other words, if you do not provide an IP address, the service will proccess your current IP address.
{ "area_code": "", "city": "", "continent": "North America", "continent_code": "NA", "country_code": "US", "country_name": "United States", "currency": "USD", "currency_simbol": "$", "currency_utf8": "$", "current_time": "2018-10-25 21:22:50", "in_eu": "no", "IP": "70.110.40.10", "latitude": "37.751", "longitude": "-97.822", "region": "", "region_code": "", "region_name": "", "tax_percent": false, "time_zone": "", "usdollar_to_usd": "1" }
An egyptian example.
{ "area_code": "", "city": "Cairo", "continent": "Africa", "continent_code": "AF", "country_code": "EG", "country_name": "Egypt", "currency": "EGP", "currency_simbol": "£", "currency_utf8": "£", "current_time": "2018-10-25 21:24:34", "in_eu": "no", "IP": "45.100.28.10", "latitude": "30.0771", "longitude": "31.2859", "region": "Cairo Governorate", "region_code": "C", "region_name": "Cairo Governorate", "tax_percent": false, "time_zone": "Africa/Cairo", "usdollar_to_egp": "17.953" }
Another european example:
{ "area_code": "", "city": "", "continent": "Europe", "continent_code": "EU", "country_code": "IT", "country_name": "Italy", "currency": "EUR", "currency_simbol": "€", "currency_utf8": "€", "current_time": "2018-10-25 21:26:12", "in_eu": "yes", "IP": "94.80.188.102", "latitude": "43.1479", "longitude": "12.1097", "region": "", "region_code": "", "region_name": "", "tax_percent": 22, "time_zone": "Europe/Rome", "usdollar_to_eur": "0.8765" }
As you can observe, we convert the currency from us dollar to local.
There are two identification documents for people in Spain. NIF (means Fiscal Identification Number), and NIE (means Foreign Identification Number).
The NIF, has eight numbers and a leter as checksum. And NIE consists in first letter (X,Y or Z), seven digits an identical letter as checksum.
This software is provided as is. We have no responsibility for the use for the end user.
Access mode:[apiroot]/spanishdni/[rendermode]/[NIF or NIE]/[apikey]
Ex: https://code.pedroruizhidalgo.es/api/v5/spanishcif/json/12378978V/[apikey]
{ "literal": "Z", "numeral": "12345678", "raw_literal": "V", "validate": "false" }
But I can amend it like;
https://code.pedroruizhidalgo.es/api/v5/spanishcif/json/12345678Z/[apikey], to get:
{ "literal": "Z", "numeral": "12345678", "raw_literal": "Z", "validate": "true" }
Let's try now with a NIE.
{ "literal": "L", "numeral": "1234567", "raw_literal": "P", "validate": "false" }
And now with the correct letter...
{ "literal": "L", "numeral": "1234567", "raw_literal": "L", "validate": "true" }
I'm sure you understand the advantages...
Each company in Spain has a code associated with tax purposes. This code is called CIF.
The CIF code determines the type of company and the province to which it belongs. We decompose the code and present the extracted data.
Access mode: [apiroot]/spanishcif/A12345678/json/[apikey]
will show...
{ "abbreviation": "SA, SAL, SAU, SAE", "check_sum": 0, "checksum_type": "Number", "province": "Castellón", "province_code": "12", "raw_number": "34567", "raw_type": "A", "type": "Sociedad Anónima", "validate": "false" }
If we correct the checsum... [apiroot]/spanishcif/A12345670/json/[apikey]
{ "abbreviation": "SA, SAL, SAU, SAE", "check_sum": 0, "checksum_type": "Number", "province": "Castellón", "province_code": "12", "raw_number": "34567", "raw_type": "A", "type": "Sociedad Anónima", "validate": "true" }
You dig it?...
Navigate to https://pedroruizhidalgo.es/resetapikey
and follow instructions.
Enter your registered email if you are non free user, and follow instructions... Finallly, we will email you a new APIKEY.
Access way: [apiroot]/users/[rendermode]/[apikey]
Enter your registered email, and go on... We will email you a new APIKEY.
{ "activation_code": "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx", "active": "1", "can_activate": "1", "company": "", "date_creation": "2018-10-22 18:08:44", "date_modification": "2018-10-26 09:35:30", "email": "your@email.com", "first_name": "Free", "forgotten_password_code": "", "forgotten_password_time": "0", "lang": "en", "last_login": "2018-10-26 11:35:30", "last_name": "User", "phone": "", "remember_code": "", "username": "freeuser" }go to summary
Access mode: [apiroot]/getconnectioncounter/[rendermode]/[apikey]
It does not make sense for users who are not free.
{ "count": 9, "user": "freeuser" }
If you are not a free user will obtain that:
{ "count": "Your plan is not countable", "user": "nonfreeuser" }
Access mode: [apiroot]/servepdf/[rendermode]/[apikey]
The post format content is divided in sections. Each section name must be enclosed in square brackets. These are:
We use the FPDF syntax. Every single line content is separated by comma, and its structure is very simple. The first item must be the PFDF, function name (see manual) and it follows, allways separated by comma, the rest of params. Send the script using http POST as raw text.
[armor] is a end part of [head].
[afterloop] is executed immediately after [loop] section.
[filename] only needs one only row, where you describe the final name of your document.
If you declare [utf8] (as void section) your final document will be utf8 encoded.
[header] image,assets/img/logo.png,65,13,15,15 SetFont,Arial,B,13 cell,30 cell,120,10,API SERVICES V5,0,0,C ln,5 setfont,arial,,8 cell,30 cell,120,8,@pedroruizhidalg,0,1,C cell,30 SetFont,times,i,10 settextcolor,180,180,180 cell,120,3,"Coding the world since 1983!",0,1,C ln,10 SetFont,Arial,B,8 settextcolor,0,0,0 [armor] cell,10,4.5,Num,1,0,C cell,50,4.5,Name,1,0,C cell,50,4.5,Address,1,0,C cell,20,4.5,Phone,1,0,C cell,50,4.5,Email,1,1,C SetFont,Arial,,8 [loop] 1,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 2,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 3,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 4,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 5,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 6,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 7,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 8,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 9,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 10,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com ... 95,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 96,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 97,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 98,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 99,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com 100,Lorem ipsum dolor sit amet,Praesent varius tellus id urna ida,Integer ut,quam@pellentesque.com [afterloop] ln,10 setx,30 cell,30,4.5,This text goes after loop.,0,1,L setx,30 cell,30,4.5,Try it and enjoy!,0,1,L [footer] sety,-15 setfont,arial,i,8 [footer] sety,-15 setfont,arial,i,8 [pagename] Spanish accent Página [filename] prueba.pdf [response] download
Access mode: [apiroot]/creditcardvalidate/[rendermode]/[card name]/[card number]/[apikey]
Card name can be one of this values:
By example: https://code.pedroruizhidalgo.es/api/v5/creditcardvalidate/json/amex/378282246310005/[apikey]
Responses as:
{ "cardnum": "378282246310005", "cardtype": "amex", "human_format": "3782 8224 6310 005", "message": "your 'amex' credit card is valid", "validation": "true" }or
{ "cardnum": "23423423", "cardtype": "amex", "human_format": "null", "message": "sorry, your 'amex' credit card is not valid", "validation": "false" }
Access mode: [apiroot]/barcodes/
All input data must be provided in json format as HTTP POST request method as is below shown:
{ "data_to_code" : "data to encode", "apikey" : "youruserapikey", "type_result" : "type_result", "codification" : "BAR_CODE_TYPE" }
Type Results:
BAR_CODE_TYPE, one of:
Keep in mind not all type of barcode, by its own definition, can produce alphanumerical data.
Type | Alphanumerical |
---|---|
TYPE_CODE_39 | yes |
TYPE_CODE_39_CHECKSUM | yes |
TYPE_CODE_39E | yes |
TYPE_CODE_39E_CHECKSUM | yes |
TYPE_CODE_93 | yes |
TYPE_STANDARD_2_5 | no |
TYPE_STANDARD_2_5_CHECKSUM | no |
TYPE_INTERLEAVED_2_5 | no |
TYPE_INTERLEAVED_2_5_CHECKSUM | no |
TYPE_CODE_128 | no |
TYPE_CODE_128_A | no |
TYPE_CODE_128_B | no |
TYPE_CODE_128_C | no |
TYPE_EAN_2 | no |
TYPE_EAN_5 | no |
TYPE_EAN_8 | no |
TYPE_EAN_13 | no |
TYPE_UPC_A | yes |
TYPE_UPC_E | yes |
TYPE_MSI | no |
TYPE_MSI_CHECKSUM | no |
TYPE_POSTNET | no |
TYPE_PLANET | no |
TYPE_RMS4CC | no |
TYPE_KIX | no |
TYPE_IMB | no |
TYPE_CODABAR | no |
TYPE_CODE_11 | no |
TYPE_PHARMA_CODE | no |
TYPE_PHARMA_CODE_TWO_TRACKS | no |
An example as response of:
{ "data_to_code" : "test code bar", "apikey" : "verysecretapikey", "type_result" : "html", "codification" : "TYPE_CODE_39" }
Access mode: [apiroot]/qrcodes/
All input data must be provided in json format as HTTP POST request method as is below shown:
{ "data" : "this is the data to codify", "apikey" : "yourverysecretapikey", "level" : "M", "size" : 3, "black" : "255,255,255", "quality" : true, "white" : "0,0,255" }
Free users can send data and apikey.
To convert the API request to an image, you can do something like that: (For convenience, we expose the code in PHP, but you can do it with you preferred language)
$post = json_encode( array( "data" => "your text to code", "apikey" => "yourapikey", "level" => "M", "size" => 4, "black" => "255,255,255", "quality" => true, "white" => "30,30,255" ) ); $ch = curl_init('https://code.pedroruizhidalgo.es/api/v5/qrcodes'); curl_setopt( $ch , CURLOPT_CUSTOMREQUEST , "POST"); curl_setopt( $ch , CURLOPT_POSTFIELDS , $post ); curl_setopt( $ch , CURLOPT_RETURNTRANSFER , true ); curl_setopt( $ch , CURLOPT_HTTPHEADER , array ( 'Content-Type: application/json', 'Content-Length: ' . strlen($post)) ); $result = curl_exec( $ch );and finally...
echo <img src="data:image/png;base64,' . base64_encode ( $result ) . '">';This image is generated on the fly whith the current date: 2024-09-13 19:36:38, check it!
Severity: Compile Warning
Message: "boolean" will be interpreted as a class name. Did you mean "bool"? Write "\boolean" to suppress this warning
Filename: libraries/App.php
Line Number: 131
Backtrace: