mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-25 07:29:47 +00:00 
			
		
		
		
	feat: call webhooks at least once (#5454)
* feat: call webhooks at least once * self review * feat: improve notification observability * feat: add notification tracing * test(e2e): test at-least-once webhook delivery * fix webhook notifications * dedicated quota notifications handler * fix linting * fix e2e test * wait less in e2e test * fix: don't ignore failed events in handlers * fix: don't ignore failed events in handlers * faster requeues * question * fix retries * fix retries * retry * don't instance ids query * revert handler_projection * statements can be nil * cleanup * make unit tests pass * add comments * add comments * lint * spool only active instances * feat(config): handle inactive instances * customizable HandleInactiveInstances * call inactive instances quota webhooks * test: handling with and w/o inactive instances * omit retrying noop statements * docs: describe projection options * enable global handling of inactive instances * self review * requeue quota notifications every 5m * remove caos_errors reference * fix comment styles * make handlers package flat * fix linting * fix repeating quota notifications * test with more usage * debug log channel init failures
This commit is contained in:
		| @@ -2,19 +2,16 @@ package fs | ||||
|  | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"io/ioutil" | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"sort" | ||||
| 	"strings" | ||||
| 	"time" | ||||
|  | ||||
| 	"github.com/k3a/html2text" | ||||
| 	"github.com/zitadel/logging" | ||||
|  | ||||
| 	caos_errors "github.com/zitadel/zitadel/internal/errors" | ||||
|  | ||||
| 	"github.com/k3a/html2text" | ||||
|  | ||||
| 	"github.com/zitadel/zitadel/internal/errors" | ||||
| 	"github.com/zitadel/zitadel/internal/notification/channels" | ||||
| 	"github.com/zitadel/zitadel/internal/notification/messages" | ||||
| ) | ||||
| @@ -29,7 +26,10 @@ func InitFSChannel(config Config) (channels.NotificationChannel, error) { | ||||
| 	return channels.HandleMessageFunc(func(message channels.Message) error { | ||||
|  | ||||
| 		fileName := fmt.Sprintf("%d_", time.Now().Unix()) | ||||
| 		content := message.GetContent() | ||||
| 		content, err := message.GetContent() | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		switch msg := message.(type) { | ||||
| 		case *messages.Email: | ||||
| 			recipients := make([]string, len(msg.Recipients)) | ||||
| @@ -41,10 +41,12 @@ func InitFSChannel(config Config) (channels.NotificationChannel, error) { | ||||
| 			} | ||||
| 		case *messages.SMS: | ||||
| 			fileName = fileName + "sms_to_" + msg.RecipientPhoneNumber + ".txt" | ||||
| 		case *messages.JSON: | ||||
| 			fileName = "message.json" | ||||
| 		default: | ||||
| 			return caos_errors.ThrowUnimplementedf(nil, "NOTIF-6f9a1", "filesystem provider doesn't support message type %T", message) | ||||
| 			return errors.ThrowUnimplementedf(nil, "NOTIF-6f9a1", "filesystem provider doesn't support message type %T", message) | ||||
| 		} | ||||
|  | ||||
| 		return ioutil.WriteFile(filepath.Join(config.Path, fileName), []byte(content), 0666) | ||||
| 		return os.WriteFile(filepath.Join(config.Path, fileName), []byte(content), 0666) | ||||
| 	}), nil | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Elio Bischof
					Elio Bischof