gobox

package module
v0.0.0-...-21d585c Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Dec 6, 2024 License: Apache-2.0 Imports: 0 Imported by: 0

README

gobox

go.dev reference Generated via Bootstrap Coverage Status

A collection of libraries that are useful for implementing Go services, libraries, and more.

Contributing

Please read the CONTRIBUTING.md document for guidelines on developing and contributing changes.

High-level Overview

Please see individual packages in the generated documentation for overviews on each.

Go idioms

Standard idioms

Please see Code review comments, go proverbs and Idiomatic Go.

Log errors with events.NewErrorInfo

When logging errors, use log.Debug(ctx, "some debug event", events.NewErrorInfo(err)) instead of using log.F{"error": err}. NewErrorInfo logs errors using outreach naming conventions and logs stack traces.

Do not use context.WithValue

Context is often abused for thread-local state. There are very few legitimate uses for this (tracing is one of those).

Do not use fmt.PrintXXX or the standard log package

Prefer the gobox log package. This logs data in a structured format suitable for outreach Go services.

Do not use non-literal messages with log

Do not use the following pattern:

   message := fmt.Sprintf("working on org: %s", model.Org.ShortName)
   log.Info(ctx, message, modelInfo)

The first arg of log.XXX calls should be a literal string so we can quickly find out where a log message comes from. The rest of the args can hold any structured data we want. The events package exposes a few common logging structures.

Use code generation for stringifying enums

See go generate:

For example, given this snippet,

package painkiller

//go:generate ./scripts/gobin.sh golang.org/x/tools/cmd/stringer@v0.1.0 -type=Pill
type Pill int

const (
  Placebo Pill = iota
  Aspirin
  Ibuprofen
  Paracetamol
  Acetaminophen = Paracetamol
)

running go generate ./... from the root of the repo will create the file pill_string.go, in package painkiller, containing a definition of func (Pill) String() string which can be used to get the string representation of the enum.

A suggested workflow is to run go generate ./... from the root of the repo before sending PRs out.

Use events.Org for logging org tenancy info.

Org information can be logged with standard naming conventions using:

   orgInfo := events.Org{Bento: xyz, DatabaseHost: ...}
   log.Debug(ctx, "doing xyz", orgInfo)

In most cases, though you probably have some other model struct which has this info. In those cases, the preferred route is to make those model types themselves loggable:

type Model struct {...}

func (m *Model) MarshalLog(addField func(key string, value interface{}) {
     m.Org().MarshalLog(addField)
     ... add any custom fields you want: addField("myCustomField", m.CustomInfo)...
}

func (m *Model) Org() events.Org {
     return events.Org{...}
}

Now Model can be used in logs like so:

   var myModel m
   log.Debug(ctx, "doing xyz", myModel)

Better still is to generate the MarshalLog function using struct tags

Documentation

Overview

Package gobox is a collection of go libraries

Directories

Path Synopsis
examples
internal
call
Package call helps support tracking latency and other metrics for calls.
Package call helps support tracking latency and other metrics for calls.
logf
Package logf has the log.F implementation
Package logf has the log.F implementation
pkg
app
Package app has the static app info
Package app has the static app info
async
Package async has helper utilities for running async code with proper tracing.
Package async has helper utilities for running async code with proper tracing.
async/pool
Package pool implements an async pool
Package pool implements an async pool
box
Package box implements the definitions of a box configuration file and tools to access it.
Package box implements the definitions of a box configuration file and tools to access it.
caller
Package caller provides info on the caller
Package caller provides info on the caller
callerinfo
Package callerinfo provides the GetCallerFunction to get the name of the module and function that has called you.
Package callerinfo provides the GetCallerFunction to get the name of the module and function that has called you.
cfg
Package cfg manages config for go services
Package cfg manages config for go services
cleanup
Package cleanup provides helpers to make it easy to do cleanups.
Package cleanup provides helpers to make it easy to do cleanups.
codec
Package codec provides encoding/decoding utilities.
Package codec provides encoding/decoding utilities.
differs
Description: Implements a custom Comperer that turns an a function into a Comparer
Description: Implements a custom Comperer that turns an a function into a Comparer
env
Package env provides environment specific overrides
Package env provides environment specific overrides
events
Package events defines the standard logging event structures
Package events defines the standard logging event structures
exec
Package exec implements os/exec stdlib helpers
Package exec implements os/exec stdlib helpers
log
Package log implements standard go logging
Package log implements standard go logging
log/adapters
Package adapters integrates the logger with 3rd party loggers
Package adapters integrates the logger with 3rd party loggers
log/internal/entries
Package entries provides an interface to work with Entries
Package entries provides an interface to work with Entries
log/logtest
logtest provides the ability to test logs
logtest provides the ability to test logs
maps
Package maps provides a bunch of functions to work with maps This is originally intended to remove repeated code such as merging maps
Package maps provides a bunch of functions to work with maps This is originally intended to remove repeated code such as merging maps
metrics
Package metrics implements the outreach metrics API
Package metrics implements the outreach metrics API
olog
Package olog implements a lightweight logging library built around the slog package.
Package olog implements a lightweight logging library built around the slog package.
orerr
Description: Bed request error
Description: Bed request error
orio
Description: Implements a buffered writer that writes the last N bytes written to it
Description: Implements a buffered writer that writes the last N bytes written to it
pointer
Package pointer is an attempt to provide functions to convert data to pointers using generics.
Package pointer is an attempt to provide functions to convert data to pointers using generics.
queue
Package queue provides queue data structure.
Package queue provides queue data structure.
region
Description: This file contains the read through cache implementation for this package.
Description: This file contains the read through cache implementation for this package.
secrets
Package secrets manages secrets config for outreach applications
Package secrets manages secrets config for outreach applications
serviceactivities/automemlimit
Package automemlimit implements a service activity that sets the GOMEMLIMIT[1] to be a percentage of the total cgroup memory limit.
Package automemlimit implements a service activity that sets the GOMEMLIMIT[1] to be a percentage of the total cgroup memory limit.
serviceactivities/shutdown
Package shut down is a service activity that handles graceful shutdowns.
Package shut down is a service activity that handles graceful shutdowns.
shuffler
Package shuffler primarily provides the Suite struct that functions as a test runner and randomizer when embedded in your test struct.
Package shuffler primarily provides the Suite struct that functions as a test runner and randomizer when embedded in your test struct.
sshconfig
Package sshconfig implements a small ssh config parser based on the output of `ssh -G`.
Package sshconfig implements a small ssh config parser based on the output of `ssh -G`.
sshhelper
Package sshhelper is a toolkit for common ssh-related operations.
Package sshhelper is a toolkit for common ssh-related operations.
statuscodes
Package statuscodes is an attempt to create very-high-level buckets/classifications of errors, for two and ONLY two purposes:
Package statuscodes is an attempt to create very-high-level buckets/classifications of errors, for two and ONLY two purposes:
tester
Package tester implements a test runner compatible with testing.T
Package tester implements a test runner compatible with testing.T
trace
Package trace wraps standard tracing for outreach.
Package trace wraps standard tracing for outreach.
ometrics Module
tools
logger
main
main

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL