| /* |
| |
| 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. |
| */ |
| |
| package client |
| |
| import ( |
| "encoding/json" |
| "errors" |
| "fmt" |
| "net" |
| "net/http" |
| "net/url" |
| "strconv" |
| |
| "github.com/apache/trafficcontrol/lib/go-tc" |
| ) |
| |
| const ( |
| API_REGIONS = apiBase + "/regions" |
| ) |
| |
| // CreateRegion creates a Region. |
| func (to *Session) CreateRegion(region tc.Region) (tc.Alerts, ReqInf, error) { |
| if region.Division == 0 && region.DivisionName != "" { |
| divisions, _, err := to.GetDivisionByName(region.DivisionName, nil) |
| if err != nil { |
| return tc.Alerts{}, ReqInf{}, err |
| } |
| if len(divisions) == 0 { |
| return tc.Alerts{}, ReqInf{}, errors.New("no division with name " + region.DivisionName) |
| } |
| region.Division = divisions[0].ID |
| } |
| |
| var remoteAddr net.Addr |
| reqBody, err := json.Marshal(region) |
| reqInf := ReqInf{CacheHitStatus: CacheHitStatusMiss, RemoteAddr: remoteAddr} |
| if err != nil { |
| return tc.Alerts{}, reqInf, err |
| } |
| resp, remoteAddr, err := to.request(http.MethodPost, API_REGIONS, reqBody, nil) |
| if err != nil { |
| return tc.Alerts{}, reqInf, err |
| } |
| defer resp.Body.Close() |
| var alerts tc.Alerts |
| err = json.NewDecoder(resp.Body).Decode(&alerts) |
| return alerts, reqInf, nil |
| } |
| |
| // UpdateRegionByID updates a Region by ID. |
| func (to *Session) UpdateRegionByID(id int, region tc.Region) (tc.Alerts, ReqInf, error) { |
| |
| var remoteAddr net.Addr |
| reqBody, err := json.Marshal(region) |
| reqInf := ReqInf{CacheHitStatus: CacheHitStatusMiss, RemoteAddr: remoteAddr} |
| if err != nil { |
| return tc.Alerts{}, reqInf, err |
| } |
| route := fmt.Sprintf("%s/%d", API_REGIONS, id) |
| resp, remoteAddr, err := to.request(http.MethodPut, route, reqBody, nil) |
| if err != nil { |
| return tc.Alerts{}, reqInf, err |
| } |
| defer resp.Body.Close() |
| var alerts tc.Alerts |
| err = json.NewDecoder(resp.Body).Decode(&alerts) |
| return alerts, reqInf, nil |
| } |
| |
| // GetRegions returns a list of regions. |
| func (to *Session) GetRegions(header http.Header) ([]tc.Region, ReqInf, error) { |
| resp, remoteAddr, err := to.request(http.MethodGet, API_REGIONS, nil, header) |
| reqInf := ReqInf{CacheHitStatus: CacheHitStatusMiss, RemoteAddr: remoteAddr} |
| if resp != nil { |
| reqInf.StatusCode = resp.StatusCode |
| if reqInf.StatusCode == http.StatusNotModified { |
| return []tc.Region{}, reqInf, nil |
| } |
| } |
| if err != nil { |
| return nil, reqInf, err |
| } |
| defer resp.Body.Close() |
| |
| var data tc.RegionsResponse |
| err = json.NewDecoder(resp.Body).Decode(&data) |
| return data.Response, reqInf, nil |
| } |
| |
| // GetRegionByID GETs a Region by the Region ID. |
| func (to *Session) GetRegionByID(id int, header http.Header) ([]tc.Region, ReqInf, error) { |
| route := fmt.Sprintf("%s?id=%d", API_REGIONS, id) |
| resp, remoteAddr, err := to.request(http.MethodGet, route, nil, header) |
| reqInf := ReqInf{CacheHitStatus: CacheHitStatusMiss, RemoteAddr: remoteAddr} |
| if resp != nil { |
| reqInf.StatusCode = resp.StatusCode |
| if reqInf.StatusCode == http.StatusNotModified { |
| return []tc.Region{}, reqInf, nil |
| } |
| } |
| if err != nil { |
| return nil, reqInf, err |
| } |
| defer resp.Body.Close() |
| |
| var data tc.RegionsResponse |
| if err := json.NewDecoder(resp.Body).Decode(&data); err != nil { |
| return nil, reqInf, err |
| } |
| |
| return data.Response, reqInf, nil |
| } |
| |
| // GetRegionByName GETs a Region by the Region name. |
| func (to *Session) GetRegionByName(name string, header http.Header) ([]tc.Region, ReqInf, error) { |
| url := fmt.Sprintf("%s?name=%s", API_REGIONS, url.QueryEscape(name)) |
| resp, remoteAddr, err := to.request(http.MethodGet, url, nil, header) |
| reqInf := ReqInf{CacheHitStatus: CacheHitStatusMiss, RemoteAddr: remoteAddr} |
| if resp != nil { |
| reqInf.StatusCode = resp.StatusCode |
| if reqInf.StatusCode == http.StatusNotModified { |
| return []tc.Region{}, reqInf, nil |
| } |
| } |
| if err != nil { |
| return nil, reqInf, err |
| } |
| defer resp.Body.Close() |
| |
| var data tc.RegionsResponse |
| if err := json.NewDecoder(resp.Body).Decode(&data); err != nil { |
| return nil, reqInf, err |
| } |
| |
| return data.Response, reqInf, nil |
| } |
| |
| // DeleteRegionByID DELETEs a Region by ID. |
| func (to *Session) DeleteRegionByID(id int) (tc.Alerts, ReqInf, error) { |
| route := fmt.Sprintf("%s?id=%d", API_REGIONS, id) |
| resp, remoteAddr, err := to.request(http.MethodDelete, route, nil, nil) |
| reqInf := ReqInf{CacheHitStatus: CacheHitStatusMiss, RemoteAddr: remoteAddr} |
| if err != nil { |
| return tc.Alerts{}, reqInf, err |
| } |
| defer resp.Body.Close() |
| var alerts tc.Alerts |
| err = json.NewDecoder(resp.Body).Decode(&alerts) |
| return alerts, reqInf, nil |
| } |
| |
| // DeleteRegion lets you DELETE a Region. Only 1 parameter is required, not both. |
| func (to *Session) DeleteRegion(id *int, name *string) (tc.Alerts, ReqInf, error) { |
| v := url.Values{} |
| if id != nil { |
| v.Add("id", strconv.Itoa(*id)) |
| } |
| if name != nil { |
| v.Add("name", *name) |
| } |
| URI := apiBase + "/regions" |
| if qStr := v.Encode(); len(qStr) > 0 { |
| URI = fmt.Sprintf("%s?%s", URI, qStr) |
| } |
| |
| resp, remoteAddr, err := to.request(http.MethodDelete, URI, nil, nil) |
| reqInf := ReqInf{CacheHitStatus: CacheHitStatusMiss, RemoteAddr: remoteAddr} |
| if err != nil { |
| return tc.Alerts{}, reqInf, err |
| } |
| defer resp.Body.Close() |
| var alerts tc.Alerts |
| err = json.NewDecoder(resp.Body).Decode(&alerts) |
| return alerts, reqInf, err |
| } |