-
Notifications
You must be signed in to change notification settings - Fork 0
/
stackql-azure-cloud-shell.sh
75 lines (70 loc) · 2.49 KB
/
stackql-azure-cloud-shell.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#!/bin/sh
show_usage() {
echo "Script to run StackQL in Azure Cloud Shell"
echo
echo "Usage:"
echo " ./stackql-azure-cloud-shell.sh [shell | exec] [flags]"
echo
echo " Command (optional):"
echo " 'shell' (default) enters the StackQL command shell to execute queries interactively."
echo " 'exec' is used to execute StackQL queries or files to provide batch outputs"
echo " (such as CSV or JSON output files). If not specified, 'shell' is assumed."
echo
echo " Flags:"
echo " StackQL args are optional global flags, documented at https://stackql.io/docs/command-line-usage/global-flags"
echo
echo " Examples:"
echo " # Launch the StackQL shell using interactive authentication (default in Azure)"
echo " sh stackql-azure-cloud-shell.sh"
echo
echo " # Execute a query from a file, writing the output to a CSV file with interactive authentication"
echo " sh stackql-azure-cloud-shell.sh exec --infile /path/to/query.sql --output csv --outfile /path/to/output.csv"
echo
}
pull_azure_docs() {
echo "Pulling latest Azure provider (azure)..."
./stackql exec "REGISTRY PULL azure"
# echo "Pulling latest Azure Extras provider (azure_extras)..."
# ./stackql exec "REGISTRY PULL azure_extras"
# echo "Pulling latest Azure ISV provider (azure_isv)..."
# ./stackql exec "REGISTRY PULL azure_isv"
# echo "Pulling latest Azure Stack provider (azure_stack)..."
# ./stackql exec "REGISTRY PULL azure_stack"
}
CMD="shell" # Default to 'shell' command
FLAGS=""
# Parse command line arguments
while [ $# -gt 0 ]; do
case "$1" in
shell|exec)
CMD="$1"
shift # Move past the command
;;
*)
# Check if the argument contains spaces
if echo "$1" | grep -q " "; then
# Argument contains spaces, wrap it in quotes
FLAGS="$FLAGS \"$1\""
else
# Argument does not contain spaces, add as is
FLAGS="$FLAGS $1"
fi
shift # Move past each flag
;;
esac
done
# Execute the StackQL command
if [ "$CMD" = "shell" ]; then
pull_azure_docs
echo "Entering StackQL shell..."
eval "./stackql shell $FLAGS"
elif [ "$CMD" = "exec" ]; then
pull_azure_docs
echo "Executing StackQL query..."
eval "./stackql exec $FLAGS"
else
show_usage
echo
echo "Error: invalid command ($CMD)"
exit 1
fi