🚚 Move Slug/Hash Generators to own file
This commit is contained in:
parent
586fe4f1de
commit
1d0f2238b3
7 changed files with 193 additions and 162 deletions
81
gen_file.go
Normal file
81
gen_file.go
Normal file
|
|
@ -0,0 +1,81 @@
|
||||||
|
package nomino
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/md5"
|
||||||
|
"crypto/sha1"
|
||||||
|
"crypto/sha256"
|
||||||
|
"errors"
|
||||||
|
"fmt"
|
||||||
|
"hash"
|
||||||
|
|
||||||
|
"github.com/gosimple/slug"
|
||||||
|
)
|
||||||
|
|
||||||
|
// ErrMissingOriginal is the error returned by Slug if there is no filename
|
||||||
|
var ErrMissingOriginal = errors.New("missing original filename")
|
||||||
|
|
||||||
|
func getOriginal(c *Config) (string, error) {
|
||||||
|
if c.original == "" {
|
||||||
|
return "", ErrMissingOriginal
|
||||||
|
}
|
||||||
|
name := c.original
|
||||||
|
c.original = ""
|
||||||
|
return name, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Slug generates a name from the original filename.
|
||||||
|
// When this is used, the original filename will be removed from the final filename.
|
||||||
|
// If a language is specified, that may affect the resulting slug.
|
||||||
|
func Slug(lang ...string) Generator {
|
||||||
|
ret := slug.Make
|
||||||
|
if len(lang) > 0 {
|
||||||
|
ret = func(in string) string {
|
||||||
|
return slug.MakeLang(in, lang[0])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return func(c *Config) (string, error) {
|
||||||
|
name, err := getOriginal(c)
|
||||||
|
return ret(name), err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// HashingFunc is a function that generates a hash.Hash
|
||||||
|
type HashingFunc func() hash.Hash
|
||||||
|
|
||||||
|
//go:generate stringer -type=HashType -trimprefix=Hash
|
||||||
|
|
||||||
|
// HashType represents a particular hashing algorithm
|
||||||
|
type HashType uint8
|
||||||
|
|
||||||
|
const (
|
||||||
|
HashMD5 HashType = iota + 1
|
||||||
|
HashSHA1
|
||||||
|
HashSHA256
|
||||||
|
)
|
||||||
|
|
||||||
|
// ErrInvalidHashType is returned by the Hash generator when an invalid HashType is passed
|
||||||
|
var ErrInvalidHashType = errors.New("invalid hash type")
|
||||||
|
|
||||||
|
var hashMap = map[HashType]HashingFunc{
|
||||||
|
HashMD5: md5.New,
|
||||||
|
HashSHA1: sha1.New,
|
||||||
|
HashSHA256: sha256.New,
|
||||||
|
}
|
||||||
|
|
||||||
|
// Hash generates a name from a hash of the filename.
|
||||||
|
// When this is used, the original filename will be removed from the final filename.
|
||||||
|
func Hash(t HashType) Generator {
|
||||||
|
f, ok := hashMap[t]
|
||||||
|
return func(c *Config) (string, error) {
|
||||||
|
if !ok {
|
||||||
|
return "", fmt.Errorf("%w: %s", ErrInvalidHashType, t)
|
||||||
|
}
|
||||||
|
name, err := getOriginal(c)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
hs := f()
|
||||||
|
hs.Write([]byte(name))
|
||||||
|
return fmt.Sprintf("%x", hs.Sum(nil)), nil
|
||||||
|
}
|
||||||
|
}
|
||||||
66
gen_file_examples_test.go
Normal file
66
gen_file_examples_test.go
Normal file
|
|
@ -0,0 +1,66 @@
|
||||||
|
package nomino_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"codeberg.org/danjones000/nomino"
|
||||||
|
)
|
||||||
|
|
||||||
|
func ExampleSlug() {
|
||||||
|
conf := nomino.NewConfig(
|
||||||
|
nomino.WithOriginal("My name is Jimmy"),
|
||||||
|
nomino.WithGenerator(nomino.Slug()),
|
||||||
|
)
|
||||||
|
str, _ := nomino.Make(conf)
|
||||||
|
fmt.Println(str)
|
||||||
|
|
||||||
|
// Output: my-name-is-jimmy.txt
|
||||||
|
}
|
||||||
|
|
||||||
|
func ExampleSlug_withLang() {
|
||||||
|
conf := nomino.NewConfig(
|
||||||
|
nomino.WithOriginal("Diese & Dass"),
|
||||||
|
nomino.WithGenerator(nomino.Slug("de")),
|
||||||
|
)
|
||||||
|
|
||||||
|
str, _ := nomino.Make(conf)
|
||||||
|
fmt.Println(str)
|
||||||
|
|
||||||
|
// Output: diese-und-dass.txt
|
||||||
|
}
|
||||||
|
|
||||||
|
func ExampleHash_mD5() {
|
||||||
|
conf := nomino.NewConfig(
|
||||||
|
nomino.WithOriginal("foobar"),
|
||||||
|
nomino.WithGenerator(
|
||||||
|
nomino.Hash(nomino.HashMD5),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
str, _ := nomino.Make(conf)
|
||||||
|
fmt.Println(str)
|
||||||
|
// Output: 3858f62230ac3c915f300c664312c63f.txt
|
||||||
|
}
|
||||||
|
|
||||||
|
func ExampleHash_sHA1() {
|
||||||
|
conf := nomino.NewConfig(
|
||||||
|
nomino.WithOriginal("foobar"),
|
||||||
|
nomino.WithGenerator(
|
||||||
|
nomino.Hash(nomino.HashSHA1),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
str, _ := nomino.Make(conf)
|
||||||
|
fmt.Println(str)
|
||||||
|
// Output: 8843d7f92416211de9ebb963ff4ce28125932878.txt
|
||||||
|
}
|
||||||
|
|
||||||
|
func ExampleHash_sHA256() {
|
||||||
|
conf := nomino.NewConfig(
|
||||||
|
nomino.WithOriginal("foobar"),
|
||||||
|
nomino.WithGenerator(
|
||||||
|
nomino.Hash(nomino.HashSHA256),
|
||||||
|
),
|
||||||
|
)
|
||||||
|
str, _ := nomino.Make(conf)
|
||||||
|
fmt.Println(str)
|
||||||
|
// Output: c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2.txt
|
||||||
|
}
|
||||||
42
gen_file_test.go
Normal file
42
gen_file_test.go
Normal file
|
|
@ -0,0 +1,42 @@
|
||||||
|
package nomino
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"github.com/stretchr/testify/assert"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestSlugMissingFilename(t *testing.T) {
|
||||||
|
conf := NewConfig(WithGenerator(Slug()))
|
||||||
|
st, err := conf.generator(&conf)
|
||||||
|
assert.Zero(t, st)
|
||||||
|
assert.ErrorIs(t, err, ErrMissingOriginal)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestSlugRemovesOriginal(t *testing.T) {
|
||||||
|
conf := NewConfig(WithGenerator(Slug()), WithOriginal("Hello, World"))
|
||||||
|
st, err := conf.generator(&conf)
|
||||||
|
assert.Zero(t, conf.original)
|
||||||
|
assert.Equal(t, "hello-world", st)
|
||||||
|
assert.NoError(t, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHashBadHash(t *testing.T) {
|
||||||
|
conf := NewConfig(WithOriginal("foobar"), WithGenerator(Hash(0)))
|
||||||
|
st, err := conf.generator(&conf)
|
||||||
|
assert.Equal(t, "", st)
|
||||||
|
assert.ErrorIs(t, err, ErrInvalidHashType)
|
||||||
|
assert.ErrorContains(t, err, "invalid hash type: HashType(0)")
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHashMissingOriginal(t *testing.T) {
|
||||||
|
conf := NewConfig(WithGenerator(Hash(HashMD5)))
|
||||||
|
st, err := conf.generator(&conf)
|
||||||
|
assert.Equal(t, "", st)
|
||||||
|
assert.ErrorIs(t, err, ErrMissingOriginal)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestHashTypeStringer(t *testing.T) {
|
||||||
|
s := HashMD5.String()
|
||||||
|
assert.Equal(t, "MD5", s)
|
||||||
|
}
|
||||||
|
|
@ -1,15 +1,9 @@
|
||||||
package nomino
|
package nomino
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"crypto/md5"
|
|
||||||
"crypto/sha1"
|
|
||||||
"crypto/sha256"
|
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
|
||||||
"hash"
|
|
||||||
|
|
||||||
"github.com/google/uuid"
|
"github.com/google/uuid"
|
||||||
"github.com/gosimple/slug"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// Generator is a function that returns the "random" portion of the returned filename.
|
// Generator is a function that returns the "random" portion of the returned filename.
|
||||||
|
|
@ -62,74 +56,3 @@ func uuidGen(*Config) (string, error) {
|
||||||
func UUID() Generator {
|
func UUID() Generator {
|
||||||
return uuidGen
|
return uuidGen
|
||||||
}
|
}
|
||||||
|
|
||||||
// ErrMissingOriginal is the error returned by Slug if there is no filename
|
|
||||||
var ErrMissingOriginal = errors.New("missing original filename")
|
|
||||||
|
|
||||||
func getOriginal(c *Config) (string, error) {
|
|
||||||
if c.original == "" {
|
|
||||||
return "", ErrMissingOriginal
|
|
||||||
}
|
|
||||||
name := c.original
|
|
||||||
c.original = ""
|
|
||||||
return name, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// Slug generates a name from the original filename.
|
|
||||||
// When this is used, the original filename will be removed from the final filename.
|
|
||||||
func Slug() Generator {
|
|
||||||
return func(c *Config) (string, error) {
|
|
||||||
name, err := getOriginal(c)
|
|
||||||
return slug.Make(name), err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// SlugWithLang generates a name from the original filename, accounting for the given language.
|
|
||||||
// When this is used, the original filename will be removed from the final filename.
|
|
||||||
func SlugWithLang(lang string) Generator {
|
|
||||||
return func(c *Config) (string, error) {
|
|
||||||
name, err := getOriginal(c)
|
|
||||||
return slug.MakeLang(name, lang), err
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// HashingFunc is a function that generates a hash.Hash
|
|
||||||
type HashingFunc func() hash.Hash
|
|
||||||
|
|
||||||
//go:generate stringer -type=HashType
|
|
||||||
|
|
||||||
// HashType represents a particular hashing algorithm
|
|
||||||
type HashType uint8
|
|
||||||
|
|
||||||
const (
|
|
||||||
MD5 HashType = iota + 1
|
|
||||||
SHA1
|
|
||||||
SHA256
|
|
||||||
)
|
|
||||||
|
|
||||||
// ErrInvalidHashType is returned by the Hash generator when an invalid HashType is passed
|
|
||||||
var ErrInvalidHashType = errors.New("invalid hash type")
|
|
||||||
|
|
||||||
var hashMap = map[HashType]HashingFunc{
|
|
||||||
MD5: md5.New,
|
|
||||||
SHA1: sha1.New,
|
|
||||||
SHA256: sha256.New,
|
|
||||||
}
|
|
||||||
|
|
||||||
// Hash generates a name from a hash of the filename.
|
|
||||||
// When this is used, the original filename will be removed from the final filename.
|
|
||||||
func Hash(t HashType) Generator {
|
|
||||||
f, ok := hashMap[t]
|
|
||||||
return func(c *Config) (string, error) {
|
|
||||||
if !ok {
|
|
||||||
return "", fmt.Errorf("%w: %s", ErrInvalidHashType, t)
|
|
||||||
}
|
|
||||||
name, err := getOriginal(c)
|
|
||||||
if err != nil {
|
|
||||||
return "", err
|
|
||||||
}
|
|
||||||
hs := f()
|
|
||||||
hs.Write([]byte(name))
|
|
||||||
return fmt.Sprintf("%x", hs.Sum(nil)), nil
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -18,49 +18,3 @@ func ExampleWithGenerator_custom_generator() {
|
||||||
// hello.txt
|
// hello.txt
|
||||||
// hello
|
// hello
|
||||||
}
|
}
|
||||||
|
|
||||||
func ExampleSlug() {
|
|
||||||
conf := NewConfig(WithGenerator(Slug()), WithOriginal("My name is Jimmy"))
|
|
||||||
str, _ := Make(conf)
|
|
||||||
fmt.Println(str)
|
|
||||||
|
|
||||||
// Output: my-name-is-jimmy.txt
|
|
||||||
}
|
|
||||||
|
|
||||||
func ExampleSlugWithLang() {
|
|
||||||
conf := NewConfig(WithGenerator(SlugWithLang("de")), WithOriginal("Diese & Dass"))
|
|
||||||
str, _ := Make(conf)
|
|
||||||
fmt.Println(str)
|
|
||||||
|
|
||||||
// Output: diese-und-dass.txt
|
|
||||||
}
|
|
||||||
|
|
||||||
func ExampleHash_mD5() {
|
|
||||||
conf := NewConfig(
|
|
||||||
WithOriginal("foobar"),
|
|
||||||
WithGenerator(Hash(MD5)),
|
|
||||||
)
|
|
||||||
str, _ := Make(conf)
|
|
||||||
fmt.Println(str)
|
|
||||||
// Output: 3858f62230ac3c915f300c664312c63f.txt
|
|
||||||
}
|
|
||||||
|
|
||||||
func ExampleHash_sHA1() {
|
|
||||||
conf := NewConfig(
|
|
||||||
WithOriginal("foobar"),
|
|
||||||
WithGenerator(Hash(SHA1)),
|
|
||||||
)
|
|
||||||
str, _ := Make(conf)
|
|
||||||
fmt.Println(str)
|
|
||||||
// Output: 8843d7f92416211de9ebb963ff4ce28125932878.txt
|
|
||||||
}
|
|
||||||
|
|
||||||
func ExampleHash_sHA256() {
|
|
||||||
conf := NewConfig(
|
|
||||||
WithOriginal("foobar"),
|
|
||||||
WithGenerator(Hash(SHA256)),
|
|
||||||
)
|
|
||||||
str, _ := Make(conf)
|
|
||||||
fmt.Println(str)
|
|
||||||
// Output: c3ab8ff13720e8ad9047dd39466b3c8974e592c2fa383d4a3960714caef0c4f2.txt
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -82,38 +82,3 @@ func TestUUIDFail(t *testing.T) {
|
||||||
_, err := UUID()(nil)
|
_, err := UUID()(nil)
|
||||||
assert.Equal(t, errors.New("sorry"), err)
|
assert.Equal(t, errors.New("sorry"), err)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestSlugMissingFilename(t *testing.T) {
|
|
||||||
conf := NewConfig(WithGenerator(Slug()))
|
|
||||||
st, err := conf.generator(&conf)
|
|
||||||
assert.Zero(t, st)
|
|
||||||
assert.ErrorIs(t, err, ErrMissingOriginal)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestSlugRemovesOriginal(t *testing.T) {
|
|
||||||
conf := NewConfig(WithGenerator(Slug()), WithOriginal("Hello, World"))
|
|
||||||
st, err := conf.generator(&conf)
|
|
||||||
assert.Zero(t, conf.original)
|
|
||||||
assert.Equal(t, "hello-world", st)
|
|
||||||
assert.NoError(t, err)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestHashBadHash(t *testing.T) {
|
|
||||||
conf := NewConfig(WithOriginal("foobar"), WithGenerator(Hash(0)))
|
|
||||||
st, err := conf.generator(&conf)
|
|
||||||
assert.Equal(t, "", st)
|
|
||||||
assert.ErrorIs(t, err, ErrInvalidHashType)
|
|
||||||
assert.ErrorContains(t, err, "invalid hash type: HashType(0)")
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestHashMissingOriginal(t *testing.T) {
|
|
||||||
conf := NewConfig(WithGenerator(Hash(MD5)))
|
|
||||||
st, err := conf.generator(&conf)
|
|
||||||
assert.Equal(t, "", st)
|
|
||||||
assert.ErrorIs(t, err, ErrMissingOriginal)
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestHashTypeStringer(t *testing.T) {
|
|
||||||
s := MD5.String()
|
|
||||||
assert.Equal(t, "MD5", s)
|
|
||||||
}
|
|
||||||
|
|
|
||||||
|
|
@ -1,4 +1,4 @@
|
||||||
// Code generated by "stringer -type=HashType"; DO NOT EDIT.
|
// Code generated by "stringer -type=HashType -trimprefix=Hash"; DO NOT EDIT.
|
||||||
|
|
||||||
package nomino
|
package nomino
|
||||||
|
|
||||||
|
|
@ -8,9 +8,9 @@ func _() {
|
||||||
// An "invalid array index" compiler error signifies that the constant values have changed.
|
// An "invalid array index" compiler error signifies that the constant values have changed.
|
||||||
// Re-run the stringer command to generate them again.
|
// Re-run the stringer command to generate them again.
|
||||||
var x [1]struct{}
|
var x [1]struct{}
|
||||||
_ = x[MD5-1]
|
_ = x[HashMD5-1]
|
||||||
_ = x[SHA1-2]
|
_ = x[HashSHA1-2]
|
||||||
_ = x[SHA256-3]
|
_ = x[HashSHA256-3]
|
||||||
}
|
}
|
||||||
|
|
||||||
const _HashType_name = "MD5SHA1SHA256"
|
const _HashType_name = "MD5SHA1SHA256"
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue