Skip to content
This repository has been archived by the owner on Nov 30, 2023. It is now read-only.

Simple FastAPI interface to the HYDLLP executable shipped with Hydstra

License

Notifications You must be signed in to change notification settings

dew-waterscience/hydllp-server

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

20 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

hydllp-server

  • #f03c15 Note: this project is being archived as of November 2023 as we are no longer using Hydstra.

ASGI web app for the Hydstra HYDLLP executable, written in Python using the amazing fastapi package.

If you are looking for Python code to access Hydstra directly, you may want to check out pyhydllp. That calls the HYDLLP DLL directly, and has a lot of helper stuff in pandas.

I wrote this because (1) not all users have access to Hydstra executables locally on their machines and (2) the DLL code is finicky to get running.

Install

> pip install -U hydllp-server

Web app configuration

Create a TOML file with the details of your Hydstra installation:

hydllpx_exe = 't:\ts_manage\hyd\sys\run\hydllpx.exe'
user = "person"
pwd = "XYZ"
hyaccess = 't:\ts_manage\hyd\hyaccess.ini'
hyconfig = 't:\ts_manage\hyd\prod.local.hyconfig.ini'

And the details of how you want your web app served:

[cherrypy]
server-socket_host = "0.0.0.0"
server-socket_port = 8096
server-thread_pool = 20
engine-autoreload-on = false

These are passed directly to cherrypy.config, with the - replaced by ..

Run web app

See hydllp_server.webapp for various entry points, including the HYDLLPEndpoint cherrypy handler, which you can mount anywhere you like.

It can be run as a cherrypy server at http://server:port/api/ using a variety of entry points, the simplest of which is the hydllp-server executable:

> hydllp-server hydllp-server-config.toml
[07/May/2019:15:54:24] ENGINE Listening for SIGTERM.
[07/May/2019:15:54:24] ENGINE Bus STARTING
[07/May/2019:15:54:24] ENGINE Set handler for console events.
[07/May/2019:15:54:24] ENGINE Serving on http://127.0.0.1:8080
[07/May/2019:15:54:24] ENGINE Bus STARTED

Client-side use

POST your HYDLLP-formatted JSON request to the configured endpoint:

>>> import requests
>>> r = requests.post(
    "http://127.0.0.1:8080/api/",
    json={
        "function": "get_site_list", 
        "version": 1, 
        "params": {"site_list": "G7029021*"}
        },
    )
>>> r.json()
{'error_num': 0,
 'buff_required': 402,
 'return': {'sites': ['G702902137',
   'G702902138',
   'G702902139',
   'G702902140',
   'G702902141',
   'G702902142',
   'G702902143',
   'G702902144',
   'G702902145',
   'G702902146',
   'G702902147',
   'G702902148',
   'G702902149',
   'G702902150',
   'G702902151',
   'G702902152',
   'G702902159',
   'G702902160',
   'G702902161',
   'G702902163',
   'G702902164',
   'G702902165',
   'G702902166',
   'G702902168',
   'G702902169']},
 'buff_supplied': 3000}

The web app will automatically increase the buffer size as required.

License

MIT

About

Simple FastAPI interface to the HYDLLP executable shipped with Hydstra

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages