Devolver ultimo valor si IOL se cae
This commit is contained in:
parent
3fa1975c69
commit
338944d82c
@ -12,10 +12,14 @@ SECRET = open("/var/openfaas/secrets/iol-api-secret").read().strip()
|
|||||||
|
|
||||||
router = APIRouter()
|
router = APIRouter()
|
||||||
|
|
||||||
|
last_results = {}
|
||||||
|
|
||||||
|
|
||||||
def get_ttl_hash(seconds=3600):
|
def get_ttl_hash(seconds=3600):
|
||||||
"""Return the same value withing `seconds` time period"""
|
"""Return the same value withing `seconds` time period"""
|
||||||
return round(time.time() / seconds)
|
return round(time.time() / seconds)
|
||||||
|
|
||||||
|
|
||||||
@lru_cache
|
@lru_cache
|
||||||
def get_token(ttl_hash=None):
|
def get_token(ttl_hash=None):
|
||||||
logging.error("getting token")
|
logging.error("getting token")
|
||||||
@ -41,11 +45,14 @@ paises = {
|
|||||||
"AR": "argentina",
|
"AR": "argentina",
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@lru_cache
|
@lru_cache
|
||||||
def get(url, ttl_hash=None):
|
def get(url, ttl_hash=None):
|
||||||
logging.error("getting data")
|
logging.error("getting data")
|
||||||
access, refresh = get_token(ttl_hash=get_ttl_hash())
|
access, refresh = get_token(ttl_hash=get_ttl_hash())
|
||||||
response = r.get(url, headers={"Authorization": "Bearer " + access, "Accept": "application/json"})
|
response = r.get(
|
||||||
|
url, headers={"Authorization": "Bearer " + access, "Accept": "application/json"}
|
||||||
|
)
|
||||||
return response.json()
|
return response.json()
|
||||||
|
|
||||||
|
|
||||||
@ -61,7 +68,14 @@ def get_accion(secret, pais, accion):
|
|||||||
+ f"/api/v2/Cotizaciones/acciones/{pais}/Todos?cotizacionInstrumentoModel.instrumento=acciones&cotizacionInstrumentoModel.pais={paises[pais]}&api_key={access}"
|
+ f"/api/v2/Cotizaciones/acciones/{pais}/Todos?cotizacionInstrumentoModel.instrumento=acciones&cotizacionInstrumentoModel.pais={paises[pais]}&api_key={access}"
|
||||||
)
|
)
|
||||||
data = get(url, ttl_hash=get_ttl_hash())
|
data = get(url, ttl_hash=get_ttl_hash())
|
||||||
return [a for a in data["titulos"] if a["simbolo"] == accion][0]
|
try:
|
||||||
|
last_results[f"accion/{pais}/{accion}"] = [
|
||||||
|
a for a in data["titulos"] if a["simbolo"] == accion
|
||||||
|
][0]
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
return last_results[f"accion/{pais}/{accion}"]
|
||||||
|
|
||||||
|
|
||||||
@router.get("/{secret}/bono/{nombre}")
|
@router.get("/{secret}/bono/{nombre}")
|
||||||
def get_bono(secret, nombre):
|
def get_bono(secret, nombre):
|
||||||
@ -74,7 +88,14 @@ def get_bono(secret, nombre):
|
|||||||
+ f"/api/v2/Cotizaciones/titulosPublicos/ar/Todos?cotizacionInstrumentoModel.instrumento=titulosPublicos&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
+ f"/api/v2/Cotizaciones/titulosPublicos/ar/Todos?cotizacionInstrumentoModel.instrumento=titulosPublicos&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
||||||
)
|
)
|
||||||
data = get(url, ttl_hash=get_ttl_hash())
|
data = get(url, ttl_hash=get_ttl_hash())
|
||||||
return [a for a in data["titulos"] if a["simbolo"] == nombre][0]
|
try:
|
||||||
|
last_results[f"bono/{nombre}"] = [
|
||||||
|
a for a in data["titulos"] if a["simbolo"] == nombre
|
||||||
|
][0]
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
return last_results[f"bono/{nombre}"]
|
||||||
|
|
||||||
|
|
||||||
@router.get("/{secret}/cedear/{nombre}")
|
@router.get("/{secret}/cedear/{nombre}")
|
||||||
def get_cedear(secret, nombre):
|
def get_cedear(secret, nombre):
|
||||||
@ -87,7 +108,14 @@ def get_cedear(secret, nombre):
|
|||||||
+ f"/api/v2/Cotizaciones/cedears/ar/Todos?cotizacionInstrumentoModel.instrumento=cedears&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
+ f"/api/v2/Cotizaciones/cedears/ar/Todos?cotizacionInstrumentoModel.instrumento=cedears&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
||||||
)
|
)
|
||||||
data = get(url, ttl_hash=get_ttl_hash())
|
data = get(url, ttl_hash=get_ttl_hash())
|
||||||
return [a for a in data["titulos"] if a["simbolo"] == nombre][0]
|
try:
|
||||||
|
last_results[f"cedear/{nombre}"] = [
|
||||||
|
a for a in data["titulos"] if a["simbolo"] == nombre
|
||||||
|
][0]
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
return last_results[f"cedear/{nombre}"]
|
||||||
|
|
||||||
|
|
||||||
@router.get("/{secret}/ON/{nombre}")
|
@router.get("/{secret}/ON/{nombre}")
|
||||||
def get_on(secret, nombre):
|
def get_on(secret, nombre):
|
||||||
@ -100,7 +128,14 @@ def get_on(secret, nombre):
|
|||||||
+ f"/api/v2/Cotizaciones/obligacionesnegociables/ar/Todos?cotizacionInstrumentoModel.instrumento=obligacionesNegociables&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
+ f"/api/v2/Cotizaciones/obligacionesnegociables/ar/Todos?cotizacionInstrumentoModel.instrumento=obligacionesNegociables&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
||||||
)
|
)
|
||||||
data = get(url, ttl_hash=get_ttl_hash())
|
data = get(url, ttl_hash=get_ttl_hash())
|
||||||
return [a for a in data["titulos"] if a["simbolo"] == nombre][0]
|
try:
|
||||||
|
last_results[f"ON/{nombre}"] = [
|
||||||
|
a for a in data["titulos"] if a["simbolo"] == nombre
|
||||||
|
][0]
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
return last_results[f"ON/{nombre}"]
|
||||||
|
|
||||||
|
|
||||||
@router.get("/{secret}/ADR/{nombre}")
|
@router.get("/{secret}/ADR/{nombre}")
|
||||||
def get_adrs(secret, nombre):
|
def get_adrs(secret, nombre):
|
||||||
@ -113,7 +148,15 @@ def get_adrs(secret, nombre):
|
|||||||
+ f"/api/v2/Cotizaciones/adrs/us/Todos?cotizacionInstrumentoModel.instrumento=aDRs&cotizacionInstrumentoModel.pais=estados_Unidos&api_key={access}"
|
+ f"/api/v2/Cotizaciones/adrs/us/Todos?cotizacionInstrumentoModel.instrumento=aDRs&cotizacionInstrumentoModel.pais=estados_Unidos&api_key={access}"
|
||||||
)
|
)
|
||||||
data = get(url, ttl_hash=get_ttl_hash())
|
data = get(url, ttl_hash=get_ttl_hash())
|
||||||
return [a for a in data["titulos"] if a["simbolo"] == nombre][0]
|
try:
|
||||||
|
last_results[f"ADR/{nombre}"] = [
|
||||||
|
a for a in data["titulos"] if a["simbolo"] == nombre
|
||||||
|
][0]
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
return last_results[f"ADR/{nombre}"]
|
||||||
|
|
||||||
|
|
||||||
@router.get("/{secret}/ON/{nombre}")
|
@router.get("/{secret}/ON/{nombre}")
|
||||||
def get_on(secret, nombre):
|
def get_on(secret, nombre):
|
||||||
if secret != SECRET:
|
if secret != SECRET:
|
||||||
@ -125,4 +168,8 @@ def get_on(secret, nombre):
|
|||||||
+ f"/api/v2/Cotizaciones/obligacionesnegociables/ar/Todos?cotizacionInstrumentoModel.instrumento=obligacionesNegociables&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
+ f"/api/v2/Cotizaciones/obligacionesnegociables/ar/Todos?cotizacionInstrumentoModel.instrumento=obligacionesNegociables&cotizacionInstrumentoModel.pais=argentina&api_key={access}"
|
||||||
)
|
)
|
||||||
data = get(url, ttl_hash=get_ttl_hash())
|
data = get(url, ttl_hash=get_ttl_hash())
|
||||||
return [a for a in data["titulos"] if a["simbolo"] == nombre][0]
|
try:
|
||||||
|
last_results[f"ON/{nombre}"]=[a for a in data["titulos"] if a["simbolo"] == nombre][0]
|
||||||
|
except:
|
||||||
|
pass
|
||||||
|
return last_results[f"ON/{nombre}"]
|
Loading…
Reference in New Issue
Block a user