You may use time.FixedZone() to construct a time.Location with a fixed offset.
Example:
loc := time.FixedZone("myzone", -8*3600)
nativeDate := time.Date(2019, 2, 6, 0, 0, 0, 0, loc)
fmt.Println(nativeDate)
Output (try it on the Go Playground):
2019-02-06 00:00:00 -0800 myzone
If you have the zone offset as a string, you may use time.Parse() to parse it. Use a layout string that only contains the reference zone offset:
t, err := time.Parse("-0700", "-0800")
fmt.Println(t, err)
This outputs (try it on the Go Playground):
0000-01-01 00:00:00 -0800 -0800 <nil>
As you can see, the result time.Time has a zone offset of -0800 hours.
So our original example can also be written as:
t, err := time.Parse("-0700", "-0800")
if err != nil {
panic(err)
}
nativeDate := time.Date(2019, 2, 6, 0, 0, 0, 0, t.Location())
fmt.Println(nativeDate)
Output (try it on the Go Playground):
2019-02-06 00:00:00 -0800 -0800