Uh oh!
There was an error while loading.Please reload this page.
- Notifications
You must be signed in to change notification settings - Fork0
License
stackql/stackql-devel
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
StackQL is an open-source project built with Golang that allows you to create, modify and query the state of services and resources across different local and remote interfaces, using SQL semantics. Such interfaces canonically include, but are not limited to, cloud and SaaS providers (Google, AWS, Azure, Okta, GitHub, etc.).
StackQL is a standalone application that can be used in client mode (viaexec orshell) or accessed via a Postgres wire protocol client (psycopg2, etc.) using server mode (srv).
StackQL parses SQL statements and transpiles them into API requests to the (cloud) resource provider. The API calls are then executed and the results are returned to the user.
StackQL provider interfaces are canonically defined in OpenAPI extensions to the providers' specification. These definitions are then used to generate the SQL schema and the API client. The source for the provider definitions are stored in theStackQL Registry. The semantics of provider interactions are defined inourany-sdk library. For more detail on nuts and bolts, please seethe localAGENTS.md file andthat ofany-sdk.
StackQL Context Diagram
The following context diagram describes the StackQL architecture at a high level:
flowchart LR subgraph StackQL direction BT subgraph ProviderDefs Registry[Provider Registry Docs] end subgraph App Proc[$ stackql exec\n$ stackql shell\n$ stackql srv] style Proc fill:#000,stroke:#000,color:#fff,text-align:left; %% ,font-family:'Courier New', Courier, monospace end end User((User)) <--> StackQL <--> Provider[Cloud Provider API] ProviderDefs --> AppMore detailed design documentation can be found in thehere.
StackQL is available for Windows, MacOS, Linux, Docker, GitHub Actions and more. See the installation instructions below for your platform.
Installing on MacOS
- Homebrew (
amd64andarm64)brew install stackqlorbrew tap stackql/tap && brew install stackql/tap/stackql
- MacOS PKG Installer (
amd64andarm64)- download the latestMacOS PKG installer for StackQL
- run the installer and follow the prompts
Installing on Windows
- MSI Installer
- download the latestMSI installer for StackQL
- run the installer and follow the prompts
- Chocolatey
- installChocolatey
- run
choco install stackql
- ZIP Archive
- download the latestWindows ZIP archive for StackQL
- extract the archive (code signed
stackql.exefile) to a directory of your choice - add the directory to your
PATHenvironment variable (optional)
Installing on Linux
- ZIP Archive
- download the latestLinux ZIP archive for StackQL
- or via
curl -L https://bit.ly/stackql-zip -O && unzip stackql-zip
- or via
- extract the archive (
stackqlfile) to a directory of your choice - add the directory to your
PATHenvironment variable (optional)
- download the latestLinux ZIP archive for StackQL
Getting StackQL from DockerHub
View all available StackQL images onDockerHub. Images available include
stackql,stackql-jupyter-demoand more. Pull the latest StackQL base image using:
docker pull stackql/stackql
Using StackQL with GitHub Actions
Use StackQL in your GitHub Actions workflows to automate cloud infrastructure provisioning, IaC assurance, or compliance/security. Available GitHub Actions include:
setup-stackql,stackql-execand more
StackQL can be used via the interactive REPL shell, or via theexec command or ran as a server using thePostgres wire protocol.
ℹ️ StackQL does not require or install a database.
Interactive Shell
# run interactive stackql queriesstackql shell --auth="${AUTH}"
Execute a statement or file
stackqlexec --auth="${AUTH}" -i myscript.iql --iqldata vars.jsonnet --output json# orstackqlexec --auth="${AUTH}""SELECT id, status FROM aws.ec2.instances WHERE region = 'us-east-1'"
ℹ️ output options of
json,csv,tableandtextare available for theexeccommand using the--outputflagℹ️ StackQL supports passing parameters using
jsonnetorjson, seeUsing VariablesServer
# serve client requests over the Postgres wire protocol (psycopg2, etc.)stackql srv --auth="${AUTH}"
For more examples, please check ourBlog
Contributions are welcome and encouraged. For more information on how to contribute, please see ourcontributing guide.
Distributed under the MIT License. SeeLICENSE for more information. Licenses for third party software we are using are included in the/docs/licenses directory.
Get in touch with us via Twitter at@stackql, email us atinfo@stackql.io or start a conversation usingdiscussions.
Forks of the following support our work:
- vitess
- kin-openapi
- gorilla/mux
- readline
- psql-wire
- mcp-postgres
- the
golangMCP SDK - ...and more. Please excuse us for any omissions.
We gratefully acknowledge these pieces of work.
About
Resources
License
Code of conduct
Contributing
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Sponsor this project
Uh oh!
There was an error while loading.Please reload this page.
Packages0
Uh oh!
There was an error while loading.Please reload this page.
Contributors6
Uh oh!
There was an error while loading.Please reload this page.


