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

Pass a configuration filepath as an argument to the streampipe command. #4202

Closed
aitoehigie opened this issue Mar 18, 2024 · 9 comments
Closed
Labels
enhancement New feature or request

Comments

@aitoehigie
Copy link

Is your feature request related to a problem? Please describe.
I'm always frustrated when I cannot dynamically pass the Steampipe configuration file path (spc file) as an argument to the Steampipe command. This limitation prevents me from seamlessly integrating Steampipe into my web application where each user supplies their API tokens, and the configuration needs to be generated on the fly.

Describe the solution you'd like
I would like the ability to pass the Steampipe configuration file path (spc file) as an argument to the Steampipe command. This enhancement would allow me to dynamically generate the configuration file for each user in my web application context, ensuring that each user's API tokens are used for querying with Steampipe.

Describe alternatives you've considered
One alternative solution could be to set up separate Steampipe instances for each user, each with their own pre-configured spc file. However, this approach would be less scalable and would require significant overhead in managing multiple instances.

Additional context
This feature would greatly enhance the flexibility and usability of Steampipe in web application contexts, enabling seamless integration with user-specific API tokens and configurations. It would simplify the deployment and management of Steampipe in multi-user environments and improve the overall user experience.

@aitoehigie aitoehigie added the enhancement New feature or request label Mar 18, 2024
@johnsmyth
Copy link

johnsmyth commented Mar 20, 2024

We could add the ability to specify the config path but I'm not sure that it would solve your particular problem. The plugin configuration defines connections which are global - they are server-level objects, not client settings. A single Steampipe DB instance has the same connections for all clients. That means that if you want a different connection config for each user you would have to create a DB instance for each user. You can do this today using --install-dir, STEAMPIPE_INSTALL_DIR or the install_dir workspace argument.

An alternative is to create a connection for every user and set the search path on a per-client basis to default to "their" connection. This doesn't preclude them from using any other connection however, just sets the connection that would be used for unqualified queries. You could conceivably use Postgres permissions to lock this down, but you would have to implement that yourself. Steampipe creates a single steampipe user, as the Steampipe CLI is optimized for a single user.

You could also explore Turbot Pipes. Where Steampipe CLI is meant for a single person doing a single thing at a single point in time, Pipes is intended to allow many people doing many things over time.

@aitoehigie
Copy link
Author

aitoehigie commented Mar 20, 2024 via email

@johnsmyth
Copy link

I guess I misunderstood your request. It sounded like you wanted to share the same database instance from different clients, with different configurations for each. If you are going to start a separate DB instance for each user then it is reasonable to add a config path arg to the service start command. Is that what you are looking for?

As for the --install-dir, that needs to point to the equivalent of the ~/.steampipe directory. The drawback is that you would have to install the plugins in each of these instances.

@aitoehigie
Copy link
Author

Exactly.
I would like to add a config path argument to the Steampipe command.
The steampipe instances aren't long-running instances as I intend calling it from a web server context (with Python's subprocess, then passing a config file containing the Stripe API key, that I created in that request cycle) and displaying the output in a dashboard.
Can I do this currently with Steampipe?

@johnsmyth
Copy link

When you say displaying output in a dashboard do you mean a Steampipe/Powerpipe dashboard or your own application's dashboard?

@johnsmyth
Copy link

If you are treating these instances as ephemeral and short-lived, and you are only accessing them through your own code on the back end, perhaps the SQLite Extensions or Export CLIs might be a better, more lightweight fit?

@aitoehigie
Copy link
Author

When you say displaying output in a dashboard do you mean a Steampipe/Powerpipe dashboard or your own application's dashboard?

My application's dashboard

@aitoehigie
Copy link
Author

If you are treating these instances as ephemeral and short-lived, and you are only accessing them through your own code on the back end, perhaps the SQLite Extensions or Export CLIs might be a better, more lightweight fit?

I think I will try the export CLI, I see it allows me to pass a --config flag. Which is fits what I am trying to accomplish.

@kaidaguerre
Copy link
Contributor

closing this issue - please raise another or get in touch via the steampipe community of you have further issues/questions

@kaidaguerre kaidaguerre closed this as not planned Won't fix, can't repro, duplicate, stale Mar 21, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants