- Copy envd source from e2b-dev/infra, internalize shared dependencies
into envd/internal/shared/ (keys, filesystem, id, smap, utils)
- Switch from gRPC to Connect RPC for all envd services
- Update module paths to git.omukk.dev/wrenn/{sandbox,sandbox/envd}
- Add proto specs (process, filesystem) with buf-based code generation
- Implement full envd: process exec, filesystem ops, port forwarding,
cgroup management, MMDS integration, and HTTP API
- Update main module dependencies (firecracker SDK, pgx, goose, etc.)
- Remove placeholder .gitkeep files replaced by real implementations
36 lines
708 B
Go
36 lines
708 B
Go
package logs
|
|
|
|
import (
|
|
"context"
|
|
"io"
|
|
"os"
|
|
"time"
|
|
|
|
"github.com/rs/zerolog"
|
|
|
|
"git.omukk.dev/wrenn/sandbox/envd/internal/host"
|
|
"git.omukk.dev/wrenn/sandbox/envd/internal/logs/exporter"
|
|
)
|
|
|
|
func NewLogger(ctx context.Context, isNotFC bool, mmdsChan <-chan *host.MMDSOpts) *zerolog.Logger {
|
|
zerolog.TimestampFieldName = "timestamp"
|
|
zerolog.TimeFieldFormat = time.RFC3339Nano
|
|
|
|
exporters := []io.Writer{}
|
|
|
|
if isNotFC {
|
|
exporters = append(exporters, os.Stdout)
|
|
} else {
|
|
exporters = append(exporters, exporter.NewHTTPLogsExporter(ctx, isNotFC, mmdsChan), os.Stdout)
|
|
}
|
|
|
|
l := zerolog.
|
|
New(io.MultiWriter(exporters...)).
|
|
With().
|
|
Timestamp().
|
|
Logger().
|
|
Level(zerolog.DebugLevel)
|
|
|
|
return &l
|
|
}
|