| // |
| // Copyright 2019 AT&T Intellectual Property |
| // Copyright 2019 Nokia |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| // This source code is part of the near-RT RIC (RAN Intelligent Controller) |
| // platform project (RICP). |
| |
| package clients |
| |
| import ( |
| "bytes" |
| "e2mgr/configuration" |
| "e2mgr/e2managererrors" |
| "e2mgr/logger" |
| "e2mgr/models" |
| "encoding/json" |
| "net/http" |
| ) |
| |
| const ( |
| AddE2TInstanceApiSuffix = "e2t" |
| AssociateRanToE2TInstanceApiSuffix = "associate-ran-to-e2t" |
| DissociateRanE2TInstanceApiSuffix = "dissociate-ran" |
| ) |
| |
| type RoutingManagerClient struct { |
| logger *logger.Logger |
| config *configuration.Configuration |
| httpClient HttpClient |
| } |
| |
| type IRoutingManagerClient interface { |
| AddE2TInstance(e2tAddress string) error |
| AssociateRanToE2TInstance(e2tAddress string, ranName string) error |
| DissociateRanE2TInstance(e2tAddress string, ranName string) error |
| DissociateAllRans(e2tAddresses []string) error |
| DeleteE2TInstance(e2tAddress string, ransToBeDissociated []string, e2tToRansAssociations map[string][]string) error |
| } |
| |
| func NewRoutingManagerClient(logger *logger.Logger, config *configuration.Configuration, httpClient HttpClient) *RoutingManagerClient { |
| return &RoutingManagerClient{ |
| logger: logger, |
| config: config, |
| httpClient: httpClient, |
| } |
| } |
| |
| func (c *RoutingManagerClient) AddE2TInstance(e2tAddress string) error { |
| |
| data := models.NewRoutingManagerE2TData(e2tAddress) |
| url := c.config.RoutingManager.BaseUrl + AddE2TInstanceApiSuffix |
| |
| return c.PostMessage(data, url) |
| } |
| |
| func (c *RoutingManagerClient) AssociateRanToE2TInstance(e2tAddress string, ranName string) error { |
| |
| data := models.RoutingManagerE2TDataList{models.NewRoutingManagerE2TData(e2tAddress, ranName)} |
| url := c.config.RoutingManager.BaseUrl + AssociateRanToE2TInstanceApiSuffix |
| |
| return c.PostMessage(data, url) |
| } |
| |
| func (c *RoutingManagerClient) DissociateRanE2TInstance(e2tAddress string, ranName string) error { |
| |
| data := models.RoutingManagerE2TDataList{models.NewRoutingManagerE2TData(e2tAddress, ranName)} |
| url := c.config.RoutingManager.BaseUrl + DissociateRanE2TInstanceApiSuffix |
| |
| return c.PostMessage(data, url) |
| } |
| |
| func (c *RoutingManagerClient) DissociateAllRans(e2tAddresses []string) error { |
| |
| data := mapE2TAddressesToE2DataList(e2tAddresses) |
| url := c.config.RoutingManager.BaseUrl + DissociateRanE2TInstanceApiSuffix |
| |
| return c.PostMessage(data, url) |
| } |
| |
| func (c *RoutingManagerClient) DeleteE2TInstance(e2tAddress string, ransToBeDissociated []string, e2tToRansAssociations map[string][]string) error { |
| //TODO - here should be the call to routing-manager... |
| return nil |
| } |
| |
| func (c *RoutingManagerClient) PostMessage(data interface{}, url string) error { |
| marshaled, err := json.Marshal(data) |
| |
| if err != nil { |
| return e2managererrors.NewRoutingManagerError() |
| } |
| |
| body := bytes.NewBuffer(marshaled) |
| c.logger.Infof("[E2 Manager -> Routing Manager] #RoutingManagerClient.PostMessage - url: %s, request body: %+v", url, body) |
| |
| resp, err := c.httpClient.Post(url, "application/json", body) |
| |
| if err != nil { |
| c.logger.Errorf("#RoutingManagerClient.PostMessage - failed sending request. error: %s", err) |
| return e2managererrors.NewRoutingManagerError() |
| } |
| |
| defer resp.Body.Close() |
| |
| if resp.StatusCode >= http.StatusOK && resp.StatusCode < http.StatusMultipleChoices { |
| c.logger.Infof("[Routing Manager -> E2 Manager] #RoutingManagerClient.PostMessage - success. http status code: %d", resp.StatusCode) |
| return nil |
| } |
| |
| c.logger.Errorf("[Routing Manager -> E2 Manager] #RoutingManagerClient.PostMessage - failure. http status code: %d", resp.StatusCode) |
| return e2managererrors.NewRoutingManagerError() |
| } |
| |
| func mapE2TAddressesToE2DataList(e2tAddresses []string) models.RoutingManagerE2TDataList { |
| e2tDataList := make(models.RoutingManagerE2TDataList, len(e2tAddresses)) |
| |
| for i, v := range e2tAddresses { |
| e2tDataList[i] = models.NewRoutingManagerE2TData(v) |
| } |
| |
| return e2tDataList |
| } |