| /* |
| |
| 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" |
| |
| "github.com/apache/trafficcontrol/lib/go-tc" |
| "github.com/apache/trafficcontrol/traffic_ops/toclientlib" |
| ) |
| |
| const ( |
| // 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_PROFILE_PARAMETERS = apiBase + "/profileparameters" |
| ProfileIdQueryParam = "profileId" |
| ParameterIdQueryParam = "parameterId" |
| |
| APIProfileParameters = "/profileparameters" |
| ) |
| |
| // Create a ProfileParameter |
| func (to *Session) CreateProfileParameter(pp tc.ProfileParameter) (tc.Alerts, toclientlib.ReqInf, error) { |
| var alerts tc.Alerts |
| reqInf, err := to.post(APIProfileParameters, pp, nil, &alerts) |
| return alerts, reqInf, err |
| } |
| |
| // CreateMultipleProfileParameters creates multiple ProfileParameters at once. |
| func (to *Session) CreateMultipleProfileParameters(pps []tc.ProfileParameter) (tc.Alerts, toclientlib.ReqInf, error) { |
| var alerts tc.Alerts |
| reqInf, err := to.post(APIProfileParameters, pps, nil, &alerts) |
| return alerts, reqInf, err |
| } |
| |
| func (to *Session) GetProfileParametersWithHdr(header http.Header) ([]tc.ProfileParameter, toclientlib.ReqInf, error) { |
| return to.GetProfileParameterByQueryParamsWithHdr("", header) |
| } |
| |
| // Returns a list of Profile Parameters |
| // Deprecated: GetProfileParameters will be removed in 6.0. Use GetProfileParametersWithHdr. |
| func (to *Session) GetProfileParameters() ([]tc.ProfileParameter, toclientlib.ReqInf, error) { |
| return to.GetProfileParametersWithHdr(nil) |
| } |
| |
| func (to *Session) GetProfileParameterByQueryParamsWithHdr(queryParams string, header http.Header) ([]tc.ProfileParameter, toclientlib.ReqInf, error) { |
| uri := APIProfileParameters + queryParams |
| var data tc.ProfileParametersNullableResponse |
| reqInf, err := to.get(uri, header, &data) |
| if err != nil { |
| return nil, reqInf, err |
| } |
| ret := make([]tc.ProfileParameter, len(data.Response)) |
| for i, pp := range data.Response { |
| ret[i] = tc.ProfileParameter{} |
| if pp.Profile != nil { |
| ret[i].Profile = *pp.Profile |
| } |
| if pp.Parameter != nil { |
| ret[i].ParameterID = *pp.Parameter |
| } |
| } |
| return ret, reqInf, nil |
| } |
| |
| // GET a Profile Parameter by the Parameter |
| // Deprecated: GetProfileParameterByQueryParams will be removed in 6.0. Use GetProfileParameterByQueryParamsWithHdr. |
| func (to *Session) GetProfileParameterByQueryParams(queryParams string) ([]tc.ProfileParameter, toclientlib.ReqInf, error) { |
| return to.GetProfileParameterByQueryParamsWithHdr(queryParams, nil) |
| } |
| |
| // DELETE a Parameter by Parameter |
| func (to *Session) DeleteParameterByProfileParameter(profile int, parameter int) (tc.Alerts, toclientlib.ReqInf, error) { |
| uri := fmt.Sprintf("%s/%d/%d", APIProfileParameters, profile, parameter) |
| var alerts tc.Alerts |
| reqInf, err := to.del(uri, nil, &alerts) |
| return alerts, reqInf, err |
| } |