Skip to content

realtemirov/logt

Repository files navigation

Logt

Color logger for golang

Usage

func main() {
	// Create a new logger
	// Token: Telegram Bot token
    	// UserID: Telegram User ID
	// Logo: Set to true if you want to show logo
    	// NameSpace: Namespace of your project
    	// If you want use Telegrambot set your token and user id, else set to empty
	l := NewLog(&Log{
		Token:     "1234567890:ABCDEFGHIowX1FpcRML5frzcAylXEeEMB9I",
		UserID:    265943548,
		Logo:      false,
		NameSpace: "test",
	})

	// Initialize writer logger
    	// functionName: Function name
    	// saveFile: If you set to true, the file will be saved, 
	w := l.NewWriter("item.Create()", true)
	defer w.Close()

	// Write a message
	w.Data("Hello world")
	w.Debug("Hello world")
	w.Error(errors.New("hello world"))
	w.Info("Hello world")
	w.Msg("Hello world")
	w.Succes("Hello world")
	w.Warning("Hello world")

	user := User{
		Firstname: "Jahongir",
		Lastname:  "Temirov",
		Email:     "[email protected]",
		Password:  "12345678",
		Address: Address{
			Country: "Uzbekistan",
			City:    "Tashkent",
		},
	}

    	// Use w.Send method to send message to telegram
	w.Send([]any{user, "Hello world!", 123})

}

type User struct {
	Firstname string  `json:"first_name"`
	Lastname  string  `json:"last_name"`
	Email     string  `json:"email"`
	Password  string  `json:"password"`
	Address   Address `json:"address"`
}

type Address struct {
	Country string `json:"country"`
	City    string `json:"city"`
}

Output

console

WithContext

func main() {
    newLogger := logt.NewLog(&Log{NameSpace: "test"})
    
	ctx := context.Background()
    ctx = newLogger.SetContext(ctx,"data", 12345)
    
	s := NewServiceA(newLogger)
}

type myService struct {
	logger logt.ILog
}

func NewMyService(logger logt.ILog) *myService {
    return &myService{
        logger: logger,
    }
}

func (s *myService) myFunction(ctx context.Context) {
    w := s.logger.NewWriter("myService.myFunction", false) 

	w.Succes("log from myService") // not output to console from context
    w.FromContext(ctx).Succes("log from myService") // it will output to console from console
}

WithContext

Telegram Bot

[
  {
    "first_name": "Jahongir",
    "last_name": "Temirov",
    "email": "[email protected]",
    "password": "12345678",
    "address": {
      "country": "Uzbekistan",
      "city": "Tashkent"
    }
  },
  "Hello world!",
  123
]

File

Filename:

2023-09-10 14:42:42-item.Create().txt

Each function log can be saved as a separate file when the function is finished.

When outputting the file to the console, it will output with the previous colors.

file

TODO

  • Add writers with format
  • ...