[[toc]]
path.App() | path.Base() | path.Config() |
path.Database() | path.Storage() | path.Public() |
debug.Dump() | debug.SDump() | debug.FDump() |
maps.Add() | maps.Exists() | maps.Forget() |
maps.Get() | maps.Has() | maps.HasAny() |
maps.Only() | maps.Pull() | maps.Set() |
maps.Where() |
convert.Tap() | convert.With() | convert.Transform() |
convert.Default() | convert.Pointer() |
The path.App()
function returns the path to your application's app directory. You may also use the path.App()
function to generate a path to a file relative to the application directory:
import "github.com/goravel/framework/support/path"
path := path.App()
path := path.App("http/controllers/controller.go")
The path.Base()
function returns the path to your application's root directory. You may also use the path.Base()
function to generate a path to a given file relative to the project root directory:
path := path.Base()
path := path.Base("vendor/bin")
The path.Config()
function returns the path to your application's config directory. You may also use the path.Config()
function to generate a path to a given file within the application's configuration directory:
path := path.Config()
path := path.Config("app.go")
The path.Database()
function returns the path to your application's database directory. You may also use the path.Database()
function to generate a path to a given file within the database
directory:
path := path.Database()
path := path.Database("factories/user_factory.go")
The path.Storage()
function returns the path to your application's storage directory. You may also use the path.Storage()
function to generate a path to a given file within the storage
directory:
path := path.Storage()
path := path.Storage("app/file.txt")
The path.Public()
function returns the path to your application's public directory. You may also use the path.Public()
function to generate a path to a given file within the public
directory:
path := path.Public()
path := path.Public("css/app.css")
The path.Lang()
function returns the path to the lang
directory. You may also use the path.Lang()
function to generate a path to a given file within the lang
directory:
path := path.Lang()
path := path.Lang("en.json")
The carbon
module of Goravel is an expansion by golang-module/carbon, the main feature is the realization of time backtracking, please refer to the official documentation for details.
Get current time:
import "github.com/goravel/framework/support/carbon"
carbon.Now()
Set timezone:
carbon.SetTimezone(carbon.UTC)
Get Carbon
object by String:
carbon.Parse("2020-08-05 13:14:15")
Get Carbon
Object by timestamp:
carbon.FromTimestamp(1577836800)
Get Carbon
Object by date time:
carbon.FromDateTime(2020, 1, 1, 0, 0, 0)
Get Carbon
Object by date:
carbon.FromDate(2020, 1, 1)
Get Carbon
Object by time:
carbon.FromTime(0, 0, 0)
Get Carbon
Object by time.Time
:
carbon.FromStdTime(time.Now())
Determine whether the time is a test value:
carbon.IsTestNow()
Set the time to a test value:
carbon.SetTestNow(carbon.Now())
Restore the time to a normal value:
carbon.UnsetTestNow()
debug.Dump()
can print any variable:
import "github.com/goravel/framework/support/debug"
debug.Dump(myVar1, myVar2, ...)
debug.FDump()
can print any variable to io.Writer
:
import "github.com/goravel/framework/support/debug"
debug.FDump(someWriter, myVar1, myVar2, ...)
debug.SDump()
can print any variable to string
:
import "github.com/goravel/framework/support/debug"
debug.SDump(myVar1, myVar2, ...)
The maps.Add()
function adds a new key-value pair to the given map if the key does not already exist in the map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Krishan"}
maps.Add(mp, "age", 22)
// map[string]any{"name": "Krishan", "age": 22}
mp2 := map[string]string{}
maps.Add(mp2, "name", "Bowen")
maps.Add(mp2, "name", "Krishan")
// map[string]string{"name": "Bowen"}
The maps.Exists()
function determines if the given key exists in the provided map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Krishan", "age": 22}
exists := maps.Exists(mp, "name") // true
exists = maps.Exists(mp, "email") // false
The maps.Forget()
function removes the given key(s) from the provided map:
import "github.com/goravel/framework/support/maps"
mp := map[string]string{"name": "Krishan", "age": "22"}
maps.Forget(mp, "name", "age")
// map[string]string{}
The maps.Get()
function retrieves the value of the given key from the provided map. If the key does not exist, the default value will be returned:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Bowen"}
value := maps.Get(mp, "name", "Krishan")
// Bowen
value = maps.Get(mp, "age", 22)
// 22
The maps.Has()
function determines if the given key(s) exists in the provided map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Goravel", "language": "Go"}
exists := maps.Has(mp, "name", "language")
// true
exists = maps.Has(mp, "name", "age")
// false
The maps.HasAny()
function determines if any of the given key(s) exists in the provided map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Goravel", "language": "Go"}
exists := maps.HasAny(mp, "name", "age")
// true
exists = maps.HasAny(mp, "age", "email")
// false
The maps.Only()
function retrieves only the given key(s) from the provided map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Goravel", "language": "Go"}
newMap := maps.Only(mp, "name")
// map[string]any{"name": "Goravel"}
newMap = maps.Only(mp, "name", "age")
// map[string]any{"name": "Goravel"}
The maps.Pull()
function retrieves and removes the given key from the provided map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Goravel", "language": "Go"}
name := maps.Pull(mp, "name")
// name = "Goravel"
// mp = map[string]any{"language": "Go"}
A default value can be provided as the third argument to the maps.Pull()
function. This value will be returned if the key does not exist in the map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Goravel", "language": "Go"}
name := maps.Pull(mp, "age", "default")
// name = "default"
// mp = map[string]any{"name": "Goravel", "language": "Go"}
The maps.Set()
function sets the given key and value in the provided map:
import "github.com/goravel/framework/support/maps"
mp := map[string]any{"name": "Goravel"}
maps.Set(mp, "language", "Go")
// map[string]any{"name": "Goravel", "language": "Go"}
The maps.Where()
function filters the provided map using the given callback:
import "github.com/goravel/framework/support/maps"
mp := map[string]string{"name": "Goravel", "language": "Go"}
newMap := maps.Where(mp, func(key string, value string) bool {
return key == "name"
})
// map[string]string{"name": "Goravel"}
The convert.Tap()
function passes the given value to the provided callback and returns the value:
import "github.com/goravel/framework/support/convert"
value := convert.Tap("Goravel", func(value string) {
fmt.Println(value + " Framework")
})
// Goravel
mp := map[string]string{"name": "Goravel"}
val := convert.Tap(mp, func(value map[string]string) {
mp["language"] = "Go"
})
// map[string]string{"name": "Goravel", "language": "Go"}
The convert.Transform()
transforms the given value using the provided callback and returns the result:
import "github.com/goravel/framework/support/convert"
value := convert.Transform(1, strconv.Itoa)
// "1"
val := convert.Transform("foo", func(s string) *foo {
return &foo{Name: s}
})
// &foo{Name: "foo"}
The convert.With()
executes the given callback with the provided value and returns the result of the callback:
import "github.com/goravel/framework/support/convert"
value := convert.With("Goravel", func(value string) string {
return value + " Framework"
})
// Goravel Framework
The convert.Default()
method returns first non-zero value. If all values are zero, it returns zero value.
import "github.com/goravel/framework/support/convert"
value := convert.Default("", "foo")
// foo
value = convert.Default("bar", "foo")
// bar
value = convert.Default(0, 1)
// 1
The convert.Pointer()
method returns the pointer of the given value.
import "github.com/goravel/framework/support/convert"
convert.Pointer("foo") // *string("foo")
convert.Pointer(1) // *int(1)
The collect.Count()
function returns the number of items in the given collection:
import "github.com/goravel/framework/support/collect"
collect.Count([]string{"Goravel", "Framework"})
// 2
The collect.CountBy()
function counts the occurrences for which the predicate is true:
import "github.com/goravel/framework/support/collect"
collect.CountBy([]string{"Goravel", "Framework"}, func(value string) bool {
return strings.Contains(value, "Goravel")
})
// 1
The collect.Each()
function iterates over the items in the given collection and passes each item to the given callback:
import "github.com/goravel/framework/support/collect"
collect.Each([]string{"Goravel", "Framework"}, func(value string, index int) {
fmt.Println(index + 1, value)
})
// 1 Goravel
// 2 Framework
The collect.Filter()
function filters the items in the collection using the given callback:
import "github.com/goravel/framework/support/collect"
newCollection := collect.Filter([]string{"Goravel", "Framework"}, func(value string) bool {
return strings.Contains(value, "Goravel")
})
// []string{"Goravel"}
The collect.GroupBy()
function groups the items in the collection by the result of the given callback:
import "github.com/goravel/framework/support/collect"
// use example of complex map slice (use different example)
newCollection := collect.GroupBy([]map[string]string{
{"class": "1", "Name": "Rohan"},
{"class": "2", "Name": "Bowen"},
{"class": "2", "Name": "Krishan"},
}, func(value map[string]string) string {
return value["class"]
})
// map[string][]map[string]string{
// "1": []map[string]string{{"class": "1", "Name": "Rohan"}},
// "2": []map[string]string{{"class": "2", "Name": "Bowen"}, {"class": "2", "Name": "Krishan"}},
// }
The collect.Keys()
function returns all the keys for the items in the collection:
import "github.com/goravel/framework/support/collect"
keys := collect.Keys(map[string]string{"name": "Goravel", "language": "Go"})
// []string{"name", "language"}
The collect.Map()
function converts one type of collection into another using the given iteratee:
import "github.com/goravel/framework/support/collect"
newCollection := collect.Map([]string{"Goravel", "Framework"}, func(value string, _ int) string {
return strings.ToUpper(value)
})
// []string{"GORAVEL", "FRAMEWORK"}
The collect.Max()
function returns the maximum value of the given collection:
import "github.com/goravel/framework/support/collect"
max := collect.Max([]int{1, 2, 3, 4, 5})
// 5
The collect.Merge()
function merges the given maps into a single map:
import "github.com/goravel/framework/support/collect"
newMap := collect.Merge(map[string]string{"name": "Goravel"}, map[string]string{"language": "Go"})
// map[string]string{"name": "Goravel", "language": "Go"}
newMap = collect.Merge(map[string]string{"name": "Goravel"}, map[string]string{"name": "Framework"})
// map[string]string{"name": "Framework"}
The collect.Min()
function returns the minimum value of the given collection:
import "github.com/goravel/framework/support/collect"
min := collect.Min([]int{1, 2, 3, 4, 5})
// 1
The collect.Reverse()
function reverses the items in the collection:
import "github.com/goravel/framework/support/collect"
newCollection := collect.Reverse([]string{"Goravel", "Framework"})
// []string{"Framework", "Goravel"}
The collect.Shuffle()
function shuffles the items in the collection:
import "github.com/goravel/framework/support/collect"
newCollection := collect.Shuffle([]int{1, 2, 3, 4, 5})
// []int{3, 1, 5, 2, 4}(example)
The collect.Split()
function splits a collection into the groups of the given length. If the collection can't be split evenly, the final chunk will contain the remaining items:
import "github.com/goravel/framework/support/collect"
newCollection := collect.Split([]int{1, 2, 3, 4, 5}, 2)
// [][]int{{1, 2}, {3, 4}, {5}}
The collect.Sum()
function returns the sum of all items in the collection:
import "github.com/goravel/framework/support/collect"
sum := collect.Sum([]int{1, 2, 3, 4, 5})
// 15
The collect.Unique()
method returns the duplicate-free collection where in case of duplicate values, only the first occurrence will be kept:
import "github.com/goravel/framework/support/collect"
newCollection := collect.Unique([]string{"Goravel", "Framework", "Goravel"})
// []string{"Goravel", "Framework"}
The collect.Values()
function returns all the values of the given collection:
import "github.com/goravel/framework/support/collect"
values := collect.Values(map[string]string{"name": "Goravel", "language": "Go"})
// []string{"Goravel", "Go"}