| 
									
										
										
										
											2022-01-06 09:00:24 +01:00
										 |  |  | package log | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	"github.com/k3a/html2text" | 
					
						
							| 
									
										
										
										
											2022-04-27 01:01:45 +02:00
										 |  |  | 	"github.com/zitadel/logging" | 
					
						
							| 
									
										
										
										
											2024-04-03 13:43:43 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-04-27 01:01:45 +02:00
										 |  |  | 	"github.com/zitadel/zitadel/internal/notification/channels" | 
					
						
							| 
									
										
										
										
											2022-01-06 09:00:24 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-16 18:24:30 +01:00
										 |  |  | func InitStdoutChannel(config Config) channels.NotificationChannel { | 
					
						
							| 
									
										
										
										
											2022-01-06 09:00:24 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 22:39:55 +02:00
										 |  |  | 	logging.WithFields("logID", "NOTIF-D0164").Debug("successfully initialized stdout email and sms channel") | 
					
						
							| 
									
										
										
										
											2022-01-06 09:00:24 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return channels.HandleMessageFunc(func(message channels.Message) error { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 00:09:06 +02:00
										 |  |  | 		content, err := message.GetContent() | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							|  |  |  | 			return err | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2022-01-06 09:00:24 +01:00
										 |  |  | 		if config.Compact { | 
					
						
							|  |  |  | 			content = html2text.HTML2Text(content) | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-07-26 22:39:55 +02:00
										 |  |  | 		logging.WithFields("logID", "NOTIF-c73ba").WithFields(map[string]interface{}{ | 
					
						
							| 
									
										
										
										
											2022-01-06 09:00:24 +01:00
										 |  |  | 			"type":    fmt.Sprintf("%T", message), | 
					
						
							|  |  |  | 			"content": content, | 
					
						
							|  |  |  | 		}).Info("handling notification message") | 
					
						
							|  |  |  | 		return nil | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | } |