| /* |
| |
| 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 ( |
| "fmt" |
| "net/http" |
| "net/url" |
| "strconv" |
| |
| "github.com/apache/trafficcontrol/lib/go-tc" |
| "github.com/apache/trafficcontrol/traffic_ops/toclientlib" |
| ) |
| |
| const ( |
| // API_SERVER_SERVER_CAPABILITIES is Deprecated: will be removed in the next major version. Be aware this may not be the URI being requested, for clients created with Login and ClientOps.ForceLatestAPI false. |
| API_SERVER_SERVER_CAPABILITIES = apiBase + "/server_server_capabilities" |
| |
| APIServerServerCapabilities = "/server_server_capabilities" |
| ) |
| |
| // CreateServerServerCapability assigns a Server Capability to a Server |
| func (to *Session) CreateServerServerCapability(ssc tc.ServerServerCapability) (tc.Alerts, toclientlib.ReqInf, error) { |
| var alerts tc.Alerts |
| reqInf, err := to.post(APIServerServerCapabilities, ssc, nil, &alerts) |
| return alerts, reqInf, err |
| } |
| |
| // DeleteServerServerCapability unassigns a Server Capability from a Server |
| func (to *Session) DeleteServerServerCapability(serverID int, serverCapability string) (tc.Alerts, toclientlib.ReqInf, error) { |
| var alerts tc.Alerts |
| v := url.Values{} |
| v.Add("serverId", strconv.Itoa(serverID)) |
| v.Add("serverCapability", serverCapability) |
| qStr := v.Encode() |
| queryURL := fmt.Sprintf("%s?%s", APIServerServerCapabilities, qStr) |
| reqInf, err := to.del(queryURL, nil, &alerts) |
| return alerts, reqInf, err |
| } |
| |
| func (to *Session) GetServerServerCapabilitiesWithHdr(serverID *int, serverHostName, serverCapability *string, header http.Header) ([]tc.ServerServerCapability, toclientlib.ReqInf, error) { |
| v := url.Values{} |
| if serverID != nil { |
| v.Add("serverId", strconv.Itoa(*serverID)) |
| } |
| if serverHostName != nil { |
| v.Add("serverHostName", *serverHostName) |
| } |
| if serverCapability != nil { |
| v.Add("serverCapability", *serverCapability) |
| } |
| queryURL := APIServerServerCapabilities |
| if qStr := v.Encode(); len(qStr) > 0 { |
| queryURL = fmt.Sprintf("%s?%s", queryURL, qStr) |
| } |
| |
| resp := struct { |
| Response []tc.ServerServerCapability `json:"response"` |
| }{} |
| reqInf, err := to.get(queryURL, header, &resp) |
| return resp.Response, reqInf, err |
| } |
| |
| // GetServerServerCapabilities retrieves a list of Server Capabilities that are assigned to a Server |
| // Callers can filter the results by server id, server host name and/or server capability via the optional parameters |
| // Deprecated: GetServerServerCapabilities will be removed in 6.0. Use GetServerServerCapabilitiesWithHdr. |
| func (to *Session) GetServerServerCapabilities(serverID *int, serverHostName, serverCapability *string) ([]tc.ServerServerCapability, toclientlib.ReqInf, error) { |
| return to.GetServerServerCapabilitiesWithHdr(serverID, serverHostName, serverCapability, nil) |
| } |