Skip to content
/ hush Public

Hush: A Go package for secure data masking and processing. Support for nested structures, and flexible masking rules.

License

Notifications You must be signed in to change notification settings

tlmanz/hush

Repository files navigation

CI CodeQL Coverage Status Open Issues Go Report Card GitHub release (latest by date)

Hush hush_logo

Hush is a Go package that provides a flexible and efficient way to process and mask sensitive data in structs and strings.

Features

  • Process structs and strings etc to mask, hide or remove sensitive information
  • Customizable field separators for nested structures
  • Support for custom masking functions
  • Concurrent processing of struct fields for improved performance
  • Option to include or exclude private fields
  • Context-aware processing with cancellation support
  • Consistent handling of maps and slices

Installation

To install Hush, use go get:

go get github.com/tlmanz/hush

Usage

Here's a basic example of how to use Hush:

package main

import (
	"context"
	"fmt"

	"github.com/tlmanz/hush"
)

type User struct {
	Name     string
	Password string   `hush:"hide"`
	Ages     []int    `hush:"mask"`
	Emails   []string `hush:"remove"`
}

func main() {
	user := User{
		Name:     "John",
		Password: "secret123",
		Ages:     []int{301, 312, 323},
		Emails:   []string{"john@example.com", "john2@example.com"},
	}

	husher := hush.NewHush()

	result, err := husher.Hush(context.Background(), 10, "TESTFIELD", hush.TagHide)
	if err != nil {
		panic(err)
	}

	fmt.Println("String Usage Example (With Prefix):")
	for _, field := range result {
		fmt.Printf("%s: %s\n", field[0], field[1])
	}

	result, err = husher.Hush(context.Background(), 10, hush.TagHide)
	if err != nil {
		panic(err)
	}

	fmt.Println("\nString Usage Example:")
	for _, field := range result {
		fmt.Printf("%s\n", field[0])
	}

	result, err = husher.Hush(context.Background(), user)
	if err != nil {
		panic(err)
	}

	fmt.Println("\nStruct Usage Example:")
	for _, field := range result {
		fmt.Printf("%s: %s\n", field[0], field[1])
	}
}

This will output:

String Usage Example (With Prefix):
TESTFIELD: HIDDEN

String Usage Example:
HIDDEN

Struct Usage Example:
Ages[0]: ***
Ages[1]: ***
Ages[2]: ***
Name: John
Password: HIDDEN

Configuration

Hush provides several options to customize its behavior:

  • WithSeparator(sep string): Set a custom separator for nested field names (default is ".")
  • WithMaskFunc(f func(string) string): Set a custom masking function
  • WithPrivateFields(include bool): Include or exclude private fields in the output

There are also options we can use specific to Non Composite types like strings, maps, slices, etc.

  • prefix string: Set a prefix for the field name
  • maskType hush.HushType (hush.TagMask or hush.TagHide): Set the type of masking to be applied. By default it will return the value as is.

Examples:

result, err := husher.Hush(context.Background(), data,
    hush.WithSeparator("_"),
    hush.WithPrivateFields(true),
    hush.WithMaskFunc(func(s string) string {
        return "CUSTOM_MASKED"
    }),
)
result, err := husher.Hush(context.Background(), "johndoe@mail.com", "EMAIL", hush.TagMask)

Private Fields

By default, Hush doesn't process private (unexported) fields. You can include private fields in the output by using the WithPrivateFields option:

result, err := husher.Hush(context.Background(), "",
    hush.WithPrivateFields(true),
)

This will include private fields in the output, applying the same masking rules as public fields.

Notes

  • Map keys are sorted alphabetically in the output for consistent results
  • Slices and arrays are processed with index-based field names

Examples

Check out the examples folder for more detailed usage examples:

  • basic_usage.go: Demonstrates basic usage with a simple struct
  • custom_options.go: Shows how to use custom options like separators and masking functions
  • complex_struct.go: Illustrates handling of complex structs with nested fields, slices, and maps
  • custom_options_table.go: Shows how to use custom options like separators and masking functions and display the result in a table
  • custom_regex_function.go: Shows how to use a custom regex function to mask the data
  • private_fields.go: Shows how to include private fields in the output

To run an example:

go run examples/basic_usage.go
go run examples/custom_options.go
go run examples/complex_struct.go
go run examples/custom_options_table.go
go run examples/private_fields.go
go run examples/custom_regex_function.go

License

Hush is released under the MIT License. See the LICENSE file for details.

About

Hush: A Go package for secure data masking and processing. Support for nested structures, and flexible masking rules.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages