Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/seipan/loghook

⚡ logger to notify logs to slack,discord using webhook ⚡
https://github.com/seipan/loghook

discord go golang logger slack webhook

Last synced: 3 months ago
JSON representation

⚡ logger to notify logs to slack,discord using webhook ⚡

Awesome Lists containing this project

README

        

![Last commit](https://img.shields.io/github/last-commit/seipan/loghook?style=flat-square)
![Repository Stars](https://img.shields.io/github/stars/seipan/loghook?style=flat-square)
![Issues](https://img.shields.io/github/issues/seipan/loghook?style=flat-square)
![Open Issues](https://img.shields.io/github/issues-raw/seipan/loghook?style=flat-square)
[![go](https://github.com/seipan/loghook/actions/workflows/go.yml/badge.svg)](https://github.com/seipan/loghook/actions/workflows/go.yml)
[![codecov](https://codecov.io/gh/seipan/loghook/graph/badge.svg?token=OALYRHUB88)](https://codecov.io/gh/seipan/loghook)

eyecatch

# loghook

⚡ logger to notify logs to slack,discord using webhook ⚡




## Installation
```
go get github.com/seipan/loghook
```

## Usage
When using it, you need to obtain the default webhook for discord and the incoming webhook for slack in advance.
```go
package discord

import "github.com/seipan/loghook"

var (
// DiscordWebhookURL is a webhook url for discord.
DiscordWebhookURL = "https://discord.com/api/webhooks/xxxxxxxx/xxxxxxxx"
)

func main() {
logger := loghook.NewLogger("", "test", "discord", DiscordWebhookURL)
logger.SetLevel(loghook.DebugLevel)
logger.SetWebhook(DiscordWebhookURL)

logger.Debug("test")
logger.Infof("test %s", "info")
}
```

If you do not want to be notified of a particular log level, you can set
```go
package discord

import "github.com/seipan/loghook"

var (
// DiscordWebhookURL is a webhook url for discord.
DiscordWebhookURL = "https://discord.com/api/webhooks/xxxxxxxx/xxxxxxxx"
)

func main(){
logger := loghook.NewLogger("", "test", "discord", DiscordWebhookURL)

logger.NoSendDebug()
logger.Debug("test")
logger.NoSendInfo()
logger.Infof("test %s", "info")
}
```
You can also change the webhook to be notified for each log level
```go
package discord

import "github.com/seipan/loghook"

var (
// DiscordWebhookURL is a webhook url for discord.
DiscordWebhookURL = "https://discord.com/api/webhooks/xxxxxxxx/xxxxxxxx"
)

func main(){
logger := loghook.NewLogger("", "test", "discord", DiscordWebhookURL)

logger.SetErrorWebhook(DiscordErrorWebhookURL)
logger.Error("test")
}
```
There is also a method that takes 'context' as an argument
```go
package discord

import "github.com/seipan/loghook"

var (
// DiscordWebhookURL is a webhook url for discord.
DiscordWebhookURL = "https://discord.com/api/webhooks/xxxxxxxx/xxxxxxxx"
)

func main(){
logger := loghook.NewLogger("", "test", "discord", DiscordWebhookURL)

logger.ErrorContext("test")
}
```
If you want a more detailed example, please see the [examples](https://github.com/seipan/loghook/blob/main/example).
## License
Code licensed under
[the MIT License](https://github.com/seipan/loghook/blob/main/LICENSE).

## Author
[seipan](https://github.com/seipan).

## Star History

[![Star History Chart](https://api.star-history.com/svg?repos=seipan/loghook&type=Date)](https://star-history.com/#seipan/loghook&Date)