mirror of
https://github.com/DeBrosOfficial/orama.git
synced 2026-03-17 12:06:57 +00:00
- Introduced `secrets` command for managing function secrets, including set, list, and delete operations. - Added `triggers` command for managing PubSub triggers associated with functions, allowing addition, listing, and deletion of triggers. - Implemented API handlers for secrets management, including setting, listing, and deleting secrets. - Updated serverless handlers to support new secrets and triggers functionalities. - Enhanced tests for the new features, ensuring proper functionality and error handling.
152 lines
3.8 KiB
Go
152 lines
3.8 KiB
Go
package functions
|
|
|
|
import (
|
|
"bytes"
|
|
"encoding/json"
|
|
"fmt"
|
|
"io"
|
|
"text/tabwriter"
|
|
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
var triggerTopic string
|
|
|
|
// TriggersCmd is the parent command for trigger management.
|
|
var TriggersCmd = &cobra.Command{
|
|
Use: "triggers",
|
|
Short: "Manage function PubSub triggers",
|
|
Long: `Add, list, and delete PubSub triggers for your serverless functions.
|
|
|
|
When a message is published to a topic, all functions with a trigger on
|
|
that topic are automatically invoked with the message as input.
|
|
|
|
Examples:
|
|
orama function triggers add my-function --topic calls:invite
|
|
orama function triggers list my-function
|
|
orama function triggers delete my-function <trigger-id>`,
|
|
}
|
|
|
|
// TriggersAddCmd adds a PubSub trigger to a function.
|
|
var TriggersAddCmd = &cobra.Command{
|
|
Use: "add <function-name>",
|
|
Short: "Add a PubSub trigger",
|
|
Long: "Registers a PubSub trigger so the function is invoked when a message is published to the topic.",
|
|
Args: cobra.ExactArgs(1),
|
|
RunE: runTriggersAdd,
|
|
}
|
|
|
|
// TriggersListCmd lists triggers for a function.
|
|
var TriggersListCmd = &cobra.Command{
|
|
Use: "list <function-name>",
|
|
Short: "List triggers for a function",
|
|
Args: cobra.ExactArgs(1),
|
|
RunE: runTriggersList,
|
|
}
|
|
|
|
// TriggersDeleteCmd deletes a trigger.
|
|
var TriggersDeleteCmd = &cobra.Command{
|
|
Use: "delete <function-name> <trigger-id>",
|
|
Short: "Delete a trigger",
|
|
Args: cobra.ExactArgs(2),
|
|
RunE: runTriggersDelete,
|
|
}
|
|
|
|
func init() {
|
|
TriggersCmd.AddCommand(TriggersAddCmd)
|
|
TriggersCmd.AddCommand(TriggersListCmd)
|
|
TriggersCmd.AddCommand(TriggersDeleteCmd)
|
|
|
|
TriggersAddCmd.Flags().StringVar(&triggerTopic, "topic", "", "PubSub topic to trigger on (required)")
|
|
TriggersAddCmd.MarkFlagRequired("topic")
|
|
}
|
|
|
|
func runTriggersAdd(cmd *cobra.Command, args []string) error {
|
|
funcName := args[0]
|
|
|
|
body, _ := json.Marshal(map[string]string{
|
|
"topic": triggerTopic,
|
|
})
|
|
|
|
resp, err := apiRequest("POST", "/v1/functions/"+funcName+"/triggers", bytes.NewReader(body), "application/json")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
defer resp.Body.Close()
|
|
|
|
respBody, err := io.ReadAll(resp.Body)
|
|
if err != nil {
|
|
return fmt.Errorf("failed to read response: %w", err)
|
|
}
|
|
|
|
if resp.StatusCode != 201 && resp.StatusCode != 200 {
|
|
return fmt.Errorf("API error (%d): %s", resp.StatusCode, string(respBody))
|
|
}
|
|
|
|
var result map[string]interface{}
|
|
if err := json.Unmarshal(respBody, &result); err != nil {
|
|
return fmt.Errorf("failed to parse response: %w", err)
|
|
}
|
|
|
|
fmt.Printf("Trigger added: %s → %s (id: %s)\n", triggerTopic, funcName, result["trigger_id"])
|
|
return nil
|
|
}
|
|
|
|
func runTriggersList(cmd *cobra.Command, args []string) error {
|
|
funcName := args[0]
|
|
|
|
result, err := apiGet("/v1/functions/" + funcName + "/triggers")
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
triggers, _ := result["triggers"].([]interface{})
|
|
if len(triggers) == 0 {
|
|
fmt.Printf("No triggers for function %q.\n", funcName)
|
|
return nil
|
|
}
|
|
|
|
w := tabwriter.NewWriter(cmd.OutOrStdout(), 0, 0, 2, ' ', 0)
|
|
fmt.Fprintln(w, "ID\tTOPIC\tENABLED")
|
|
for _, t := range triggers {
|
|
tr, ok := t.(map[string]interface{})
|
|
if !ok {
|
|
continue
|
|
}
|
|
id, _ := tr["ID"].(string)
|
|
if id == "" {
|
|
id, _ = tr["id"].(string)
|
|
}
|
|
topic, _ := tr["Topic"].(string)
|
|
if topic == "" {
|
|
topic, _ = tr["topic"].(string)
|
|
}
|
|
enabled := true
|
|
if e, ok := tr["Enabled"].(bool); ok {
|
|
enabled = e
|
|
} else if e, ok := tr["enabled"].(bool); ok {
|
|
enabled = e
|
|
}
|
|
fmt.Fprintf(w, "%s\t%s\t%v\n", id, topic, enabled)
|
|
}
|
|
w.Flush()
|
|
return nil
|
|
}
|
|
|
|
func runTriggersDelete(cmd *cobra.Command, args []string) error {
|
|
funcName := args[0]
|
|
triggerID := args[1]
|
|
|
|
result, err := apiDelete("/v1/functions/" + funcName + "/triggers/" + triggerID)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if msg, ok := result["message"]; ok {
|
|
fmt.Println(msg)
|
|
} else {
|
|
fmt.Println("Trigger deleted.")
|
|
}
|
|
return nil
|
|
}
|