Skip to content

hugorosario/mumbojumbo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 

Repository files navigation

Mumbo jumbo

A small tool to obfuscate strings in your Go code

Description

When you want to store specific strings in your go code they are automatically searchable in the go binary.

For example take the following code (x.go):

    package main

    import (
        "fmt"
    )

    const (
        C = "hello"
    )

    func main() {
        fmt.Println(C)
    }

Now run go build ./x.go to build it and the run strings ./x | grep hello.

Surprise ! "hello" is visible to anyone who would get the go binary.

mumbojumbo tries to mitigate this problem by obfuscating the string so it is no longer searchable with strings.

Getting Started

You can install mumbojumbo by running:

go install github.com/jeromer/mumbojumbo

Usage

Once mumbojumbo is installed just run:

mumbojumbo -s=foo -p=bar

where foo is the string you want to obfuscate and bar is the name of the go package which will be generated.

For example, imagine I want to obfuscate the string some secret in pkg foo:

mumbojumbo -s="some secret" -p=foo | goimports > foo.go

No import foo.go in your project and call fmt.Println(foo.Get()) you should see "some secret"

Run mumbojumbo --help to get help

License

This project is licensed under the BSD 3-Clause License - see the LICENSE file for details

Acknowledgments

About

Obfuscates golang strings

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Go 100.0%