Merge R4 branch to master
[ric-plt/e2mgr.git] / E2Manager / clients / routing_manager_client.go
index d4c9bbe..2625612 100644 (file)
@@ -33,12 +33,13 @@ const (
        AddE2TInstanceApiSuffix            = "e2t"
        AssociateRanToE2TInstanceApiSuffix = "associate-ran-to-e2t"
        DissociateRanE2TInstanceApiSuffix  = "dissociate-ran"
+       DeleteE2TInstanceApiSuffix         = "e2t"
 )
 
 type RoutingManagerClient struct {
        logger     *logger.Logger
        config     *configuration.Configuration
-       httpClient HttpClient
+       httpClient IHttpClient
 }
 
 type IRoutingManagerClient interface {
@@ -46,9 +47,10 @@ type IRoutingManagerClient interface {
        AssociateRanToE2TInstance(e2tAddress string, ranName string) error
        DissociateRanE2TInstance(e2tAddress string, ranName string) error
        DissociateAllRans(e2tAddresses []string) error
+       DeleteE2TInstance(e2tAddress string, ransToBeDissociated []string) error
 }
 
-func NewRoutingManagerClient(logger *logger.Logger, config *configuration.Configuration, httpClient HttpClient) *RoutingManagerClient {
+func NewRoutingManagerClient(logger *logger.Logger, config *configuration.Configuration, httpClient IHttpClient) *RoutingManagerClient {
        return &RoutingManagerClient{
                logger:     logger,
                config:     config,
@@ -61,7 +63,7 @@ func (c *RoutingManagerClient) AddE2TInstance(e2tAddress string) error {
        data := models.NewRoutingManagerE2TData(e2tAddress)
        url := c.config.RoutingManager.BaseUrl + AddE2TInstanceApiSuffix
 
-       return c.PostMessage(data, url)
+       return c.PostMessage(url, data)
 }
 
 func (c *RoutingManagerClient) AssociateRanToE2TInstance(e2tAddress string, ranName string) error {
@@ -69,7 +71,7 @@ func (c *RoutingManagerClient) AssociateRanToE2TInstance(e2tAddress string, ranN
        data := models.RoutingManagerE2TDataList{models.NewRoutingManagerE2TData(e2tAddress, ranName)}
        url := c.config.RoutingManager.BaseUrl + AssociateRanToE2TInstanceApiSuffix
 
-       return c.PostMessage(data, url)
+       return c.PostMessage(url, data)
 }
 
 func (c *RoutingManagerClient) DissociateRanE2TInstance(e2tAddress string, ranName string) error {
@@ -77,7 +79,7 @@ func (c *RoutingManagerClient) DissociateRanE2TInstance(e2tAddress string, ranNa
        data := models.RoutingManagerE2TDataList{models.NewRoutingManagerE2TData(e2tAddress, ranName)}
        url := c.config.RoutingManager.BaseUrl + DissociateRanE2TInstanceApiSuffix
 
-       return c.PostMessage(data, url)
+       return c.PostMessage(url, data)
 }
 
 func (c *RoutingManagerClient) DissociateAllRans(e2tAddresses []string) error {
@@ -85,10 +87,16 @@ func (c *RoutingManagerClient) DissociateAllRans(e2tAddresses []string) error {
        data := mapE2TAddressesToE2DataList(e2tAddresses)
        url := c.config.RoutingManager.BaseUrl + DissociateRanE2TInstanceApiSuffix
 
-       return c.PostMessage(data, url)
+       return c.PostMessage(url, data)
 }
 
-func (c *RoutingManagerClient) PostMessage(data interface{}, url string) error {
+func (c *RoutingManagerClient) DeleteE2TInstance(e2tAddress string, ransTobeDissociated []string) error {
+       data := models.NewRoutingManagerDeleteRequestModel(e2tAddress, ransTobeDissociated, nil)
+       url := c.config.RoutingManager.BaseUrl + DeleteE2TInstanceApiSuffix
+       return c.DeleteMessage(url, data)
+}
+
+func (c *RoutingManagerClient) sendMessage(method string, url string, data interface{}) error {
        marshaled, err := json.Marshal(data)
 
        if err != nil {
@@ -96,26 +104,40 @@ func (c *RoutingManagerClient) PostMessage(data interface{}, url string) error {
        }
 
        body := bytes.NewBuffer(marshaled)
-       c.logger.Infof("[E2 Manager -> Routing Manager] #RoutingManagerClient.PostMessage - url: %s, request body: %+v", url, body)
+       c.logger.Infof("[E2 Manager -> Routing Manager] #RoutingManagerClient.sendMessage - %s url: %s, request body: %+v", method, url, body)
 
-       resp, err := c.httpClient.Post(url, "application/json", body)
+       var resp *http.Response
+
+       if method == http.MethodPost {
+               resp, err = c.httpClient.Post(url, "application/json", body)
+       } else if method == http.MethodDelete {
+               resp, err = c.httpClient.Delete(url, "application/json", body)
+       }
 
        if err != nil {
-               c.logger.Errorf("#RoutingManagerClient.PostMessage - failed sending request. error: %s", err)
+               c.logger.Errorf("#RoutingManagerClient.sendMessage - 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)
+               c.logger.Infof("[Routing Manager -> E2 Manager] #RoutingManagerClient.sendMessage - 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)
+       c.logger.Errorf("[Routing Manager -> E2 Manager] #RoutingManagerClient.sendMessage - failure. http status code: %d", resp.StatusCode)
        return e2managererrors.NewRoutingManagerError()
 }
 
+func (c *RoutingManagerClient) DeleteMessage(url string, data interface{}) error {
+       return c.sendMessage(http.MethodDelete, url, data)
+}
+
+func (c *RoutingManagerClient) PostMessage(url string, data interface{}) error {
+       return c.sendMessage(http.MethodPost, url, data)
+}
+
 func mapE2TAddressesToE2DataList(e2tAddresses []string) models.RoutingManagerE2TDataList {
        e2tDataList := make(models.RoutingManagerE2TDataList, len(e2tAddresses))
 
@@ -125,3 +147,14 @@ func mapE2TAddressesToE2DataList(e2tAddresses []string) models.RoutingManagerE2T
 
        return e2tDataList
 }
+
+func convertE2TToRansAssociationsMapToE2TDataList(e2tToRansAssociations map[string][]string) models.RoutingManagerE2TDataList {
+       e2tDataList := make(models.RoutingManagerE2TDataList, len(e2tToRansAssociations))
+       i := 0
+       for k, v := range e2tToRansAssociations {
+               e2tDataList[i] = models.NewRoutingManagerE2TData(k, v...)
+               i++
+       }
+
+       return e2tDataList
+}