access.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. package log
  2. import (
  3. "log"
  4. "os"
  5. )
  6. type AccessStatus string
  7. const (
  8. AccessAccepted = AccessStatus("accepted")
  9. AccessRejected = AccessStatus("rejected")
  10. )
  11. type accessLogger interface {
  12. Log(from, to string, status AccessStatus, reason string)
  13. }
  14. type noOpAccessLogger struct {
  15. }
  16. func (logger *noOpAccessLogger) Log(from, to string, status AccessStatus, reason string) {
  17. // Swallow
  18. }
  19. type accessLog struct {
  20. From string
  21. To string
  22. Status AccessStatus
  23. Reason string
  24. }
  25. type fileAccessLogger struct {
  26. queue chan *accessLog
  27. logger *log.Logger
  28. }
  29. func (logger *fileAccessLogger) Log(from, to string, status AccessStatus, reason string) {
  30. logger.queue <- &accessLog{
  31. From: from,
  32. To: to,
  33. Status: status,
  34. Reason: reason,
  35. }
  36. }
  37. func (logger *fileAccessLogger) Run() {
  38. for entry := range logger.queue {
  39. logger.logger.Println(entry.From + " " + string(entry.Status) + " " + entry.To + " " + entry.Reason)
  40. }
  41. }
  42. func newFileAccessLogger(path string) accessLogger {
  43. file, err := os.OpenFile(path, os.O_APPEND|os.O_WRONLY|os.O_CREATE, 0600)
  44. if err != nil {
  45. log.Printf("Unable to create or open file (%s): %v\n", path, err)
  46. return nil
  47. }
  48. return &fileAccessLogger{
  49. queue: make(chan *accessLog, 16),
  50. logger: log.New(file, "", log.Ldate|log.Ltime),
  51. }
  52. }
  53. var accessLoggerInstance accessLogger = &noOpAccessLogger{}
  54. func InitAccessLogger(file string) {
  55. logger := newFileAccessLogger(file)
  56. if logger != nil {
  57. go logger.(*fileAccessLogger).Run()
  58. accessLoggerInstance = logger
  59. }
  60. }
  61. func Access(from, to string, status AccessStatus, reason string) {
  62. accessLoggerInstance.Log(from, to, status, reason)
  63. }