Mantau is a golang library for transforming data. Mantau can be used for transforming struct, map and/or slice of struct by providing a schema of how the data will be transformed.
To start using mantau, first you need to install the library by running the following command:
go get -u github.com/dwadp/mantau
When creating a mantau instance, a default options will be passed for initialization. The default struct tag will be set as json
.
mantau.New()
You can override mantau default options by calling SetOpt
function and pass a mantau.Options
.
m := mantau.New()
// Override the default mantau options
m.SetOpt(&mantau.Options{
StructTag: "acustomstructtag"
})
When transforming a data, mantau will match the data with the provied schema. For examples:
package main
import "github.com/dwadp/mantau"
type AStruct struct {
FieldOne string `schema:"field_one"`
FieldTwo string `schema:"field_two"`
}
func main() {
m := mantau.New()
// Setting the struct tag to a custom tag 'schema'
m.SetOpt(&mantau.Options{
StructTag: "schema",
})
// Transforming a struct
m.Transform(AStruct{
FieldOne: "Struct value one",
FieldTwo: "Struct value two",
}, mantau.Schema{
"one": SchemaField{
// Key should match with the struct tag 'schema'
Key: "field_one"
},
"two": SchemaField{
// Key should match with the struct tag 'schema'
Key: "field_two"
},
})
// Transforming a map
m.Transform(map[string]interface{}{
"key_one": "Map value one",
"key_two": "Map value two",
}, mantau.Schema{
"one": mantau.SchemaField{
// Key should match with the 'map key'
Key: "key_one",
},
"two": mantau.SchemaField{
// Key should match with the 'map key'
Key: "key_two",
},
})
// Transforming nested data structure
m.Transform(map[string]interface{}{
"key_one": "Value one",
"key_two": "Value two",
"nested": AStruct{
FieldOne: "Struct value one",
FieldTwo: "Struct value two",
},
}, mantau.Schema{
"one": mantau.SchemaField{
// Key should match with the 'map key'
Key: "key_one",
},
"two": mantau.SchemaField{
// Key should match with the 'map key'
Key: "key_two",
},
"three": mantau.SchemaField{
// Key should match with the 'map key'
Key: "nested",
// Use 'Value' for a schema of a nested data structure
Value: mantau.Schema{
"one": mantau.SchemaField{
// Key should match with the 'map key'
Key: "key_one",
},
"two": mantau.SchemaField{
// Key should match with the 'map key'
Key: "key_two",
},
},
},
})
}
In mantau.SchemaField
you can leave the Value
field to nil or omit it if you are not dealing with a nested data structure.
Below are some examples on how to use this library.
Below are example transforming a struct
package main
import (
"fmt"
"github.com/dwadp/mantau"
)
type User struct {
Name string `json:"name"`
Email string `json:"email"`
Phone string `json:"phone"`
IsActive *bool `json:"is_active"`
}
func main() {
m := mantau.New()
isActive := true
result, _ := m.Transform(User{
Name: "John doe",
Email: "[email protected]",
Phone: "911",
IsActive: &isActive,
}, mantau.Schema{
"username": SchemaField{
Key: "name",
},
"useremail": SchemaField{
Key: "email",
},
"active": SchemaField{
Key: "is_active",
},
})
fmt.Println(result)
}
will result:
{
"username": "John doe",
"useremail": "[email protected]",
"active": false
}
Below are example transforming a slice
package main
import (
"fmt"
"github.com/dwadp/mantau"
)
type User struct {
Name string `json:"name"`
Email string `json:"email"`
Phone string `json:"phone"`
IsActive *bool `json:"is_active"`
}
func main() {
m := mantau.New()
active := true
inactive := false
result, _ := m.Transform([]User{
User{
Name: "John doe",
Email: "[email protected]",
Phone: "911",
IsActive: &inactive,
},
User{
Name: "Jane doe",
Email: "[email protected]",
Phone: "912",
IsActive: &active,
}
}, mantau.Schema{
"name": mantau.SchemaField{
Key: "name",
},
"email": mantau.SchemaField{
Key: "email",
},
"active": mantau.SchemaField{
Key: "is_active",
},
"phone": mantau.SchemaField{
Key: "phone",
},
})
fmt.Println(result)
}
will result:
[
{
"name": "John doe",
"email": "[email protected]",
"active": false,
"phone: "911"
},
{
"name": "Jane doe",
"email": "[email protected]",
"active": true,
"phone: "912"
}
]
- Write documentation