Generating token using keycloak
[nonrtric/plt/sme.git] / capifcore / internal / config / config.go
1 // -
2 //   ========================LICENSE_START=================================
3 //   O-RAN-SC
4 //   %%
5 //   Copyright (C) 2023: Nordix Foundation
6 //   %%
7 //   Licensed under the Apache License, Version 2.0 (the "License");
8 //   you may not use this file except in compliance with the License.
9 //   You may obtain a copy of the License at
10 //
11 //        http://www.apache.org/licenses/LICENSE-2.0
12 //
13 //   Unless required by applicable law or agreed to in writing, software
14 //   distributed under the License is distributed on an "AS IS" BASIS,
15 //   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 //   See the License for the specific language governing permissions and
17 //   limitations under the License.
18 //   ========================LICENSE_END===================================
19 //
20
21 package config
22
23 import (
24         "os"
25         "path/filepath"
26
27         "gopkg.in/yaml.v2"
28 )
29
30 type AuthorizationServer struct {
31         Port   string            `yaml:"port"`
32         Host   string            `yaml:"host"`
33         Realms map[string]string `yaml:"realms"`
34 }
35
36 type Config struct {
37         AuthorizationServer AuthorizationServer `yaml:"authorizationServer"`
38 }
39
40 func ReadKeycloakConfigFile(configFolder string) (*Config, error) {
41
42         f, err := os.Open(filepath.Join(configFolder, "keycloak.yaml"))
43         if err != nil {
44                 return nil, err
45         }
46         defer f.Close()
47
48         var cfg *Config
49         decoder := yaml.NewDecoder(f)
50         err = decoder.Decode(&cfg)
51         if err != nil {
52                 return nil, err
53         }
54         return cfg, nil
55 }