Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jeffry-luqman/zlog
Formatted slog.Logger, slog is Go stdlib which provides structured logging, in which log records include a message, a severity level, and various other attributes expressed as key-value pairs, zlog make it more colorfull, beautifull and readable.
https://github.com/jeffry-luqman/zlog
Last synced: about 2 months ago
JSON representation
Formatted slog.Logger, slog is Go stdlib which provides structured logging, in which log records include a message, a severity level, and various other attributes expressed as key-value pairs, zlog make it more colorfull, beautifull and readable.
- Host: GitHub
- URL: https://github.com/jeffry-luqman/zlog
- Owner: jeffry-luqman
- License: mit
- Created: 2023-09-21T00:18:41.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-09-25T09:43:52.000Z (over 1 year ago)
- Last Synced: 2024-08-04T10:02:48.542Z (5 months ago)
- Language: Go
- Homepage:
- Size: 17.6 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-slog - zlog
README
# zlog
Zlog is formatted slog.Logger. [slog](https://pkg.go.dev/log/slog) provides structured logging, in which log records include a message, a severity level, and various other attributes expressed as key-value pairs, zlog make it more colorfull, beautifull and readable.## Getting Started
1. Import the zlog Package
```go
import "github.com/jeffry-luqman/zlog"
```2. Override some config if needed
```go
zlog.TimeFormat := time.RFC3339Nano
```3. Create a Logger Instance
```go
logger := zlog.New()
```4. Call it as slog logger from everywhere
```go
logger.Debug("Hello, World!")
logger.Info("Hello, World!")
logger.Warn("Hello, World!")
logger.Error("Hello, World!")
```## Example Usage
Here's an example of how to use zlog to log different types of messages:### Example 1
#### Code
```go
package mainimport (
"log/slog""github.com/jeffry-luqman/zlog"
)func main() {
logger := zlog.New()
logger.Debug("Hello, World!")
logger.Info("Hello, World!")
logger.Warn("Hello, World!", slog.String("foo", "bar"), slog.Bool("baz", true))
logger.Error("Hello, World!", slog.String("foo", "bar"))
}
```#### Output
![image](https://github.com/jeffry-luqman/zlog/assets/11884257/c09f486e-b359-448b-bf66-17e68012067c)### Example 2
#### Code
```go
package mainimport (
"log/slog"
"net/http"
"time""github.com/jeffry-luqman/zlog"
)func main() {
zlog.HandlerOptions = &slog.HandlerOptions{Level: slog.LevelDebug}
zlog.FmtDuration = []int{zlog.FgMagenta, zlog.FmtItalic}
zlog.FmtPath = []int{zlog.FgHiCyan}
logger := zlog.New()start := time.Now()
time.Sleep(200 * time.Millisecond)logger.Debug("heloo 1",
slog.Duration(zlog.KeyDuration, time.Now().Sub(start)),
slog.Int(zlog.KeyStatus, http.StatusOK),
slog.String(zlog.KeyMethod, http.MethodGet),
slog.String(zlog.KeyPath, "/api/products"),
slog.String("foo", "bar"),
slog.Int("baz", 123),
)
time.Sleep(time.Millisecond)logger.Info("heloo 2",
slog.Duration(zlog.KeyDuration, time.Now().Sub(start)),
slog.Int(zlog.KeyStatus, http.StatusCreated),
slog.String(zlog.KeyMethod, http.MethodPost),
slog.String(zlog.KeyPath, "/api/products"),
slog.String("foo", "bar"),
slog.Int("baz", 123),
)
time.Sleep(time.Millisecond)logger.Warn("heloo 3",
slog.Duration(zlog.KeyDuration, time.Now().Sub(start)),
slog.Int(zlog.KeyStatus, http.StatusBadRequest),
slog.String(zlog.KeyMethod, http.MethodPut),
slog.String(zlog.KeyPath, "/api/products/1"),
slog.String("foo", "bar"),
slog.Int("baz", 123),
)
time.Sleep(time.Millisecond)logger.Error("heloo 4",
slog.Duration(zlog.KeyDuration, time.Now().Sub(start)),
slog.Int(zlog.KeyStatus, http.StatusInternalServerError),
slog.String(zlog.KeyMethod, http.MethodPatch),
slog.String(zlog.KeyPath, "/api/products/1"),
slog.String("foo", "bar"),
slog.Int("baz", 123),
)
time.Sleep(time.Millisecond)logger.Info("heloo 5",
slog.Duration(zlog.KeyDuration, time.Now().Sub(start)),
slog.Int(zlog.KeyStatus, http.StatusNoContent),
slog.String(zlog.KeyMethod, http.MethodDelete),
slog.String(zlog.KeyPath, "/api/products/1"),
slog.String("foo", "bar"),
slog.Int("baz", 123),
)
}
```
#### Output
![image](https://github.com/jeffry-luqman/zlog/assets/11884257/591d196b-cf72-48d5-aee0-34b3dac019de)## Customizing Log Output
You can customize the log output by modifying the logger instance and the log handler options. Refer to the zlog.HandlerOptions and other variables defined in the zlog package for customization options.## Logging with Enhanced Formatting
You can use the Fmt function from zlog to format your log messages with various attributes and colors. Here's an example:
```go
// Log a message with bold red text
logger.Info(zlog.Fmt("This is an important message!", zlog.FmtBold, zlog.FgRed))
```
In the example above, we use zlog.Fmt to format the log message with bold and red text.## Contribute
If you find issues or have suggestions for improvements, please open an issue or create a pull request on the GitHub repository.Happy logging with zlog!