Categorygithub.com/mrz1836/go-parameters
repositorypackage
1.0.0
Repository: https://github.com/mrz1836/go-parameters.git
Documentation: pkg.go.dev

# Packages

No description provided by the author

# README

go-parameters

Parameter multi-tool that parses json, msg pack, or multipart form data into a parameter object.

CI / CDQuality & SecurityDocs & MetaCommunity
Latest release
Build status
CodeQL
Last commit
Go Report Card
Code coverage
Security policy
Security policy
Go version
Go docs
AGENTS.md rules
MAGE-X Supported
Dependabot
Contributors
Sponsor
Donate Bitcoin

Table of Contents


Installation

go-parameters requires a supported release of Go.

go get -u github.com/mrz1836/go-parameters

Documentation

View the generated documentation

GoDoc

Features

  • This package uses the fastest router: Julien Schmidt's httprouter
  • Works with json, msgpack, and multi-part forms
  • Handles all standard types for GetParams
  • Handler methods like MakeParsedReq() for httprouter use
  • Imbue and Permit helper methods
  • GetParams() parses parameters only once
Development Setup (Getting Started)

Install MAGE-X build tool for development:

# Install MAGE-X for development and building
go install github.com/mrz1836/mage-x/cmd/magex@latest
magex update:install
Library Deployment

This project uses goreleaser for streamlined binary and library deployment to GitHub. To get started, install it via:

brew install goreleaser

The release process is defined in the .goreleaser.yml configuration file.

Then create and push a new Git tag using:

magex version:bump bump=patch push

This process ensures consistent, repeatable releases with properly versioned artifacts and citation metadata.

Build Commands

View all build commands

magex help
GitHub Workflows

🎛️ The Workflow Control Center

All GitHub Actions workflows in this repository are powered by configuration files: .env.base (default configuration) and optionally .env.custom (project-specific overrides) – your one-stop shop for tweaking CI/CD behavior without touching a single YAML file! 🎯

Configuration Files:

  • .env.base – Default configuration that works for most Go projects
  • .env.custom – Optional project-specific overrides

This magical file controls everything from:

  • 🚀 Go version matrix (test on multiple versions or just one)
  • 🏃 Runner selection (Ubuntu or macOS, your wallet decides)
  • 🔬 Feature toggles (coverage, fuzzing, linting, race detection, benchmarks)
  • 🛡️ Security tool versions (gitleaks, nancy, govulncheck)
  • 🤖 Auto-merge behaviors (how aggressive should the bots be?)
  • 🏷️ PR management rules (size labels, auto-assignment, welcome messages)

Pro tip: Want to disable code coverage? Just add ENABLE_CODE_COVERAGE=false to your .env.custom to override the default in .env.base and push. No YAML archaeology required!


Workflow NameDescription
auto-merge-on-approval.ymlAutomatically merges PRs after approval and all required checks, following strict rules.
codeql-analysis.ymlAnalyzes code for security vulnerabilities using GitHub CodeQL.
dependabot-auto-merge.ymlAutomatically merges Dependabot PRs that meet all requirements.
fortress.ymlRuns the GoFortress security and testing workflow, including linting, testing, releasing, and vulnerability checks.
pull-request-management.ymlLabels PRs by branch prefix, assigns a default user if none is assigned, and welcomes new contributors with a comment.
scorecard.ymlRuns OpenSSF Scorecard to assess supply chain security.
stale.ymlWarns about (and optionally closes) inactive issues and PRs on a schedule or manual trigger.
sync-labels.ymlKeeps GitHub labels in sync with the declarative manifest at .github/labels.yml.
Updating Dependencies

To update all dependencies (Go modules, linters, and related tools), run:

magex deps:update

This command ensures all dependencies are brought up to date in a single step, including Go modules and any managed tools. It is the recommended way to keep your development environment and CI in sync with the latest versions.


Examples & Tests

All unit tests and examples run via GitHub Actions and use Go version 1.24.x. View the configuration file.

Run all tests (fast):

magex test

Run all tests with race detector (slower):

magex test:race

Benchmarks

The following benchmarks were conducted to measure the performance of various functions in the github.com/mrz1836/go-parameters package. All tests were run on a machine with the following specifications:

  • Operating System: macOS (Darwin)
  • Architecture: ARM64
  • CPU: Apple M1 Max

Benchmark Results

View the latest benchmark results

BenchmarkIterationsns/opB/opallocs/op
UniqueUint6413,989,84184.49 ns64 B1
GetParams_ParseJSONBody209,700,8175.721 ns0 B0
GetParams209,668,8945.719 ns0 B0
Params_GetStringOk37,573,43431.96 ns16 B1
Params_GetBoolOk36,349,31633.15 ns16 B1
Params_GetBytesOk38,539,61631.52 ns16 B1
Params_GetBool35,637,43332.57 ns16 B1
Params_GetFloatOk22,064,58654.69 ns16 B1
Params_GetIntOk28,992,30441.78 ns16 B1
Params_GetInt64Ok28,752,84441.77 ns16 B1
Params_GetIntSliceOk38,099,67131.59 ns16 B1
Params_GetUint64Ok29,921,58039.68 ns16 B1

Benchmark Details

  • UniqueUint64: Measures the performance of generating unique uint64 values.
  • GetParams_ParseJSONBody: Benchmarks parsing a JSON body into parameters.
  • GetParams: Tests retrieving parameters without parsing.
  • Params_GetStringOk: Evaluates fetching a string parameter with success indication.
  • Params_GetBoolOk: Assesses fetching a boolean parameter with success indication.
  • Params_GetBytesOk: Measures retrieving a byte slice parameter with success indication.
  • Params_GetBool: Benchmarks fetching a boolean parameter without success indication.
  • Params_GetFloatOk: Tests fetching a float parameter with success indication.
  • Params_GetIntOk: Evaluates fetching an integer parameter with success indication.
  • Params_GetInt64Ok: Measures fetching a 64-bit integer parameter with success indication.
  • Params_GetIntSliceOk: Benchmarks retrieving a slice of integers with success indication.
  • Params_GetUint64Ok: Tests fetching an unsigned 64-bit integer parameter with success indication.

Benchmark Notes

  • Iterations: The number of times the benchmark function was executed.
  • ns/op: Nanoseconds per operation, indicating the average time taken for each operation.
  • B/op: Bytes allocated per operation, showing the memory usage.
  • allocs/op: Allocations per operation, indicating how many memory allocations occurred per operation.

How to Run Benchmarks

Run the Go benchmarks:

magex bench

Code Standards

Read more about this Go project's code standards.


AI Compliance

This project documents expectations for AI assistants using a few dedicated files:

  • AGENTS.md — canonical rules for coding style, workflows, and pull requests used by Codex.
  • CLAUDE.md — quick checklist for the Claude agent.
  • .cursorrules — machine-readable subset of the policies for Cursor and similar tools.
  • sweep.yaml — rules for Sweep, a tool for code review and pull request management.

Edit AGENTS.md first when adjusting these policies, and keep the other files in sync within the same pull request.


Maintainers

MrZkayleg
MrZkayleg

Contributing

View the contributing guidelines and please follow the code of conduct.

How can I help?

All kinds of contributions are welcome :raised_hands:! The most basic way to show your support is to star :star2: the project, or to raise issues :speech_balloon:. You can also support this project by becoming a sponsor on GitHub :clap: or by making a bitcoin donation to ensure this journey continues indefinitely! :rocket:

Stars


License

License