Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Return just query URL without doing the query #3144

Closed
pllim opened this issue Dec 4, 2024 · 10 comments
Closed

Return just query URL without doing the query #3144

pllim opened this issue Dec 4, 2024 · 10 comments

Comments

@pllim
Copy link
Member

pllim commented Dec 4, 2024

This was brought up by @ejeschke at Astropy ALOHA 2024 workshop. User wishes to use Astroquery to construct a query, however user does not want to actually execute the query, but rather wants to store the final query URL for later use. This is desirable when user wants complete control on when network access happens, and not necessarily when the query was created (e.g., this query is generated by downstream in an async away).

Might be related:

@keflavich
Copy link
Contributor

This isn't possible for most services; in general, queries are performed via POST requests, not GET requests, and for such cases, the query is not encoded into the URL.

I therefore would regard this request as 'not possible'.

@pllim
Copy link
Member Author

pllim commented Dec 4, 2024

How about return it when possible and some form of exception when not?

@keflavich
Copy link
Contributor

'When possible' is limited to a small handful of the services that astroquery works with, and I don't know which ones - it would be significant effort to figure out which do and to implement param-based queries.

From a user perspective: this is why we made astroquery in the first place. There were lots of online services that provided un-reproducible workflows (you constructed a post query through the web form), and there was no easy way to do it from the command line. Astroquery exists in part to fill that role.

Addressing the original concern: Is it any more difficult to copy an astroquery query command than a URL? It shouldn't be, generally.

@pllim
Copy link
Member Author

pllim commented Dec 4, 2024

I'll have to defer to @ejeschke to elaborate on the affected use case. 🙏

@bsipocz
Copy link
Member

bsipocz commented Dec 4, 2024

Also, we'll be adding more, real async accesses, but also, a lot of the modules are switching to VO backends. So if someone wants to have this much level of control, they could use pyvo/the vo services directly at the point of need in their pipeline/processing workflow rather than passing around reverse-engineered URLs.

So, overall I agree with Adam that it it very unlikely that this feature request will be implemented, even where it is technically possible: This ask would require a significant amount of engineering that only affects a handful of modules, most of which modules are not having any observatory/archive support and thus are already maintained on volunteer and best effort level and that contains some of the reverse engineered API access.

@keflavich
Copy link
Contributor

I'm going to close this. If there is a more specific use case that we can reasonably accommodate, either reopen this one with more details, or open a different one that is more specific.

@pllim
Copy link
Member Author

pllim commented Jan 13, 2025

I think the original context was for use in Ginga for Catalogs plugin.

The services used in https://github.com/ejeschke/ginga/blob/main/ginga/util/catalog.py are the following:

  • ned
  • simbad
  • skyview
  • vizier
  • vo_conesearch

However, I do not know the exact workflow for when only URL is wanted but not the actual query, or whether only a subset of these need that feature. That is something @ejeschke could clarify if he would like to pursue this issue.

@pllim pllim added the wontfix label Jan 13, 2025
@bsipocz
Copy link
Member

bsipocz commented Jan 13, 2025

vo_conesearch is being used by ginga? Any chance to change that to use pyvo instead? I mean it would really nice to finally clean up that module.

@pllim
Copy link
Member Author

pllim commented Jan 13, 2025

Any chance to change that to use pyvo instead?

Sure, but someone needs to put in the work and I won't have time. The translation isn't one-to-one (e.g., API different, output different), so it is not a simple search and replace. However, given that astroquery already pulls in pyvo, introducing new dependency is a non-issue at least.

I opened ejeschke/ginga#1113

@bsipocz
Copy link
Member

bsipocz commented Jan 13, 2025

However, given that astroquery already pulls in pyvo

Point is that we want to cull this altogether (with some deprecations first) as 1) no one has time to maintain this module, and it's being dragged around while being a bit odd one out 2) we expect it doesn't really have much usage, I was surprised thus I surprised why ginga uses it at all.

So, the master plan is to point people to use pyvo instead and then cut this technical debt. Some docs for that would be nice, but no code production is expected.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants