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

jq integration #89

Open
AlphaTechnolog opened this issue Oct 30, 2024 · 3 comments
Open

jq integration #89

AlphaTechnolog opened this issue Oct 30, 2024 · 3 comments

Comments

@AlphaTechnolog
Copy link
Contributor

AlphaTechnolog commented Oct 30, 2024

One of the ideas i think might be insanely cool to implement and have in cartero, is the ability to find queries parts inside cartero itself by using jq expressions... Maybe we could put like an input in the bottom of the request panel and then let the user write jq expressions there like .id and it will fetch the object id.

Maybe we could do a call to the jq binary like jq '{{expression}}' as the user types it so it gets real time, but this will also imply we add a new dependency to install, which is gonna be jq so we can access it this way, am not really sure how will this work in things like flatpak? Also, maybe we could use some jq bindings like these which am not fully sure how to integrate, but i suspect anyways will require us to rely on jq as a dependency, but we could discuss in the best way to implement something like jq integration so we can fetch certain parts of the request's response, might be awesome.

Saw this idea on the last stream of cartero development, and wanted to document it here

@danirod
Copy link
Owner

danirod commented Oct 31, 2024

Yeah, this could be very interesting and it has been discussed before on the stream.

Calling jq if available would be the easiest way to achieve this. Packaging jq into Flatpak would be a nightmare, but it seems that other people are doing it so maybe is not impossible.

Or use the binding. However, it seems that jq-sys hasn't been updated for 1.7. It seems that jaq is a thing that has been rewritten in Rust and is jq compatible. That could be another alternative.

@danirod danirod added this to Cartero Oct 31, 2024
@danirod danirod moved this to Needs Think in Cartero Oct 31, 2024
@AlphaTechnolog
Copy link
Contributor Author

Or use the binding. However, it seems that jq-sys hasn't been updated for 1.7. It seems that jaq is a thing that has been rewritten in Rust and is jq compatible. That could be another alternative.

Oh unfortunate yeah, jaq calls my attention, however, it seems like it's only binary, like only callable from shell commands, which tbh, may make the things easier, i could just spawn it passing the input query, check output and update the panel with the output it gives from within terminal, do you know if including jaq in the crates dependencies, we could somehow make it available to be called from within shell commands? or will happen the same thing as with packaging with jq that we would have to deal with flatpak things? asking this because tbh never used too much crates and don't know if installing it will automatically expose the bin version in this case of jaq, maybe i'd need to do my own research aswell about these kind of things lmao

but anyways another thing i found was jaq_interpret which seems to be a thing that's callable from within rust code but seems to be a thing to actually consume the json instead from the code which would probably need me to do some research on how to actually get a string representation, maybe serde could do something like that though, not sure, needs research... I could try doing some experiments about this issue by creating some input with an overlay in the response panel with regular jq to make some kind of proof of concept and show it to you so we can discuss what's the best way to deal with this, maybe this could also help resolve the "cartero has no way to find in the response panel" issue lmao

@AlphaTechnolog
Copy link
Contributor Author

2024-11-01_09-52-13.mp4

So i've made the proof of concept, the input doesn't looks that good, but the functionality is there, right now it's working by calling jq under the hood, so the only thing to make it work would be using jq as a new dependency for cartero.

lmk your comments

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

No branches or pull requests

2 participants