-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #439 from essentialkaos/develop
Version 12.104.0
- Loading branch information
Showing
13 changed files
with
466 additions
and
90 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,199 @@ | ||
package united | ||
|
||
// ////////////////////////////////////////////////////////////////////////////////// // | ||
// // | ||
// Copyright (c) 2024 ESSENTIAL KAOS // | ||
// Apache License, Version 2.0 <https://www.apache.org/licenses/LICENSE-2.0> // | ||
// // | ||
// ////////////////////////////////////////////////////////////////////////////////// // | ||
|
||
import ( | ||
"fmt" | ||
|
||
"github.com/essentialkaos/ek/v12/knf" | ||
"github.com/essentialkaos/ek/v12/options" | ||
) | ||
|
||
// ////////////////////////////////////////////////////////////////////////////////// // | ||
|
||
func ExampleCombine() { | ||
// Load global KNF config | ||
err := knf.Global("/path/to/your/config.knf") | ||
|
||
if err != nil { | ||
fmt.Printf("Error: %v\n", err) | ||
return | ||
} | ||
|
||
optMap := options.Map{ | ||
"O:option-one": {}, | ||
"k:option-two": {}, | ||
} | ||
|
||
// Parse command-line options | ||
_, errs := options.Parse(optMap) | ||
|
||
if len(errs) != 0 { | ||
for _, err := range errs { | ||
fmt.Printf("Error: %v\n", err) | ||
} | ||
|
||
return | ||
} | ||
|
||
// Combine combine KNF configuration, options and environment variables | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
// Read string value | ||
GetS("section:string") | ||
|
||
// Read integer value | ||
GetI("section:int") | ||
|
||
// Read float value | ||
GetF("section:float") | ||
|
||
// Read boolean value | ||
GetB("section:boolean") | ||
|
||
// Read file mode value | ||
GetM("section:file-mode") | ||
|
||
// Read duration as seconds | ||
GetD("section:duration", Second) | ||
|
||
// Read duration as minutes | ||
GetD("section:duration", Minute) | ||
|
||
// Read time duration | ||
GetTD("section:time-duration") | ||
|
||
// Read timestamp | ||
GetTS("section:timestamp") | ||
|
||
// Read timezone | ||
GetTZ("section:timezone") | ||
|
||
// Read list | ||
GetL("section:list") | ||
} | ||
|
||
func ExampleGetS() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %s\n", GetS("user:name")) | ||
} | ||
|
||
func ExampleGetB() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %t\n", GetB("user:is-admin")) | ||
} | ||
|
||
func ExampleGetI() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %d\n", GetI("user:uid")) | ||
} | ||
|
||
func ExampleGetI64() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %d\n", GetI64("user:uid")) | ||
} | ||
|
||
func ExampleGetU() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %d\n", GetU("user:uid")) | ||
} | ||
|
||
func ExampleGetU64() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %d\n", GetU64("user:uid")) | ||
} | ||
|
||
func ExampleGetF() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %g\n", GetF("user:priority")) | ||
} | ||
|
||
func ExampleGetM() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %v\n", GetF("user:default-mode")) | ||
} | ||
|
||
func ExampleGetD() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %v\n", GetD("user:timeout", Minute)) | ||
} | ||
|
||
func ExampleGetTD() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %v\n", GetTD("user:timeout")) | ||
} | ||
|
||
func ExampleGetTS() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %v\n", GetTS("user:created")) | ||
} | ||
|
||
func ExampleGetTZ() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %v\n", GetTZ("service:timezone")) | ||
} | ||
|
||
func ExampleGetL() { | ||
Combine( | ||
Mapping{"test:option-one", "O:option-one", "TEST_OPTION_ONE"}, | ||
Mapping{"test:option-two", "k:option-two", "TEST_OPTION_TWO"}, | ||
) | ||
|
||
fmt.Printf("Value from config: %v\n", GetL("issue:labels")) | ||
} |
Oops, something went wrong.