mirror of
https://github.com/opentofu/opentofu.git
synced 2025-01-04 13:17:43 -06:00
6fe2703665
* Remove `make updatedeps` from Travis build. We'll follow up with more specific plans around dependency updating in subsequent PRs. * Update all `make` targets to set `GO15VENDOREXPERIMENT=1` and to filter out `/vendor/` from `./...` where appropriate. * Temporarily remove `vet` from the `make test` target until we can figure out how to get it to not vet `vendor/`. (Initial experimentation failed to yield the proper incantation.) Everything is pinned to current master, with the exception of: * Azure/azure-sdk-for-go which is pinned before the breaking change today * aws/aws-sdk-go which is pinned to the most recent tag The documentation still needs to be updated, which we can do in a follow up PR. The goal here is to unblock release.
87 lines
1.6 KiB
Go
87 lines
1.6 KiB
Go
package godo
|
|
|
|
import (
|
|
"net/url"
|
|
"strconv"
|
|
)
|
|
|
|
// Links manages links that are returned along with a List
|
|
type Links struct {
|
|
Pages *Pages `json:"pages,omitempty"`
|
|
Actions []LinkAction `json:"actions,omitempty"`
|
|
}
|
|
|
|
// Pages are pages specified in Links
|
|
type Pages struct {
|
|
First string `json:"first,omitempty"`
|
|
Prev string `json:"prev,omitempty"`
|
|
Last string `json:"last,omitempty"`
|
|
Next string `json:"next,omitempty"`
|
|
}
|
|
|
|
// LinkAction is a pointer to an action
|
|
type LinkAction struct {
|
|
ID int `json:"id,omitempty"`
|
|
Rel string `json:"rel,omitempty"`
|
|
HREF string `json:"href,omitempty"`
|
|
}
|
|
|
|
// CurrentPage is current page of the list
|
|
func (l *Links) CurrentPage() (int, error) {
|
|
return l.Pages.current()
|
|
}
|
|
|
|
func (p *Pages) current() (int, error) {
|
|
switch {
|
|
case p == nil:
|
|
return 1, nil
|
|
case p.Prev == "" && p.Next != "":
|
|
return 1, nil
|
|
case p.Prev != "":
|
|
prevPage, err := pageForURL(p.Prev)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
return prevPage + 1, nil
|
|
}
|
|
|
|
return 0, nil
|
|
}
|
|
|
|
// IsLastPage returns true if the current page is the last
|
|
func (l *Links) IsLastPage() bool {
|
|
if l.Pages == nil {
|
|
return true
|
|
}
|
|
return l.Pages.isLast()
|
|
}
|
|
|
|
func (p *Pages) isLast() bool {
|
|
if p.Last == "" {
|
|
return true
|
|
}
|
|
|
|
return false
|
|
}
|
|
|
|
func pageForURL(urlText string) (int, error) {
|
|
u, err := url.ParseRequestURI(urlText)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
pageStr := u.Query().Get("page")
|
|
page, err := strconv.Atoi(pageStr)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
|
|
return page, nil
|
|
}
|
|
|
|
// Get a link action by id.
|
|
func (la *LinkAction) Get(client *Client) (*Action, *Response, error) {
|
|
return client.Actions.Get(la.ID)
|
|
}
|