Documentation
¶
Index ¶
- Constants
- type APIClient
- func (api *APIClient) AddAuthIP(ip net.IP, packageID int) (AddAuthIPResponse, error)
- func (api *APIClient) AddCurrentIPtoAllPackages() (success int)
- func (api *APIClient) DeleteAllAuthIPs() (int, error)
- func (api *APIClient) DeleteAuthIPByID(ipID int) (ok bool)
- func (api *APIClient) DeleteAuthIPByIP(ipa net.IP) (err error)
- func (api *APIClient) DeleteOtherAuthIPs() ([]int, error)
- func (api *APIClient) GetAllSOCKSIPsAndPorts() ([]string, error)
- func (api *APIClient) GetAuthIPs() ([]AuthIP, error)
- func (api *APIClient) GetPackageSOCKS(packageid int) ([]string, error)
- func (api *APIClient) GetProxyPackages() ([]UserPackage, error)
- type AddAuthIPResponse
- type AuthIP
- type AuthIPResponse
- type DelAuthIPResponse
- type Package
- type PackageDetails
- type PackageResponse
- type PackageStatistics
- type UserPackage
Constants ¶
const (
APIBaseURL = "https://proxybonanza.com/api/v1/"
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type APIClient ¶
type APIClient struct { Key string KnownPackages map[int]PackageDetails Debug bool // contains filtered or unexported fields }
APIClient is a client for ProxyBonanza.com.
func NewAPIClient ¶
NewAPIClient instantiates a proxybonanza.com API client with the given key using golang's default http client.
func NewCustomClient ¶
NewCustomClient insantiates a proxybonanza API client with the given key and the given http.Client.
func (*APIClient) AddAuthIP ¶
AddAuthIP adds a new IP to the corresponding/provided proxy package ID.
func (*APIClient) AddCurrentIPtoAllPackages ¶
AddCurrentIPtoAllPackages adds your current WAN IP to all packages on your account. It returns the amount of successful packages that it was applied to. It will skip packages that are already using the current IP.
func (*APIClient) DeleteAllAuthIPs ¶
DeleteAllAuthIPs deletes all authenticaiton IPs from your account.
func (*APIClient) DeleteAuthIPByID ¶
DeleteAuthIPByID deletes an authentication IP with the matching ID provided
func (*APIClient) DeleteAuthIPByIP ¶
DeleteAuthIPByIP will iterate through all the authips on your account and delete one that matches the given IP.
func (*APIClient) DeleteOtherAuthIPs ¶
DeleteOtherAuthIPs deletes all authenticaiton IPs from your account's packages that do not match your current IP address. Returns a slice of authentication IP IDs that were deleted and any errors that occurred.
func (*APIClient) GetAllSOCKSIPsAndPorts ¶
GetAllSOCKSIPsAndPorts will return a slice of IP:Port formatted proxy strings
func (*APIClient) GetAuthIPs ¶
GetAuthIPs gets all authentication IPs active on your account.
func (*APIClient) GetPackageSOCKS ¶
GetPackageSOCKS returns a specified packages SOCKS5 proxies in host:port format.
func (*APIClient) GetProxyPackages ¶
func (api *APIClient) GetProxyPackages() ([]UserPackage, error)
GetProxyPackages gets current proxy packages from your account.
type AddAuthIPResponse ¶
type AddAuthIPResponse struct { Success bool `json:"success"` Message string `json:"message"` Data struct { ID int `json:"id"` } `json:"data"` }
AddAuthIPResponse represents an API response from proxybonanza.com.
type AuthIP ¶
type AuthIP struct { UserpackageID int `json:"userpackage_id"` ID interface{} `json:"id"` IP string `json:"ip"` }
AuthIP is an IP address authorized to use the proxies in the related package.
type AuthIPResponse ¶
type AuthIPResponse struct { Success bool `json:"success"` Message string `json:"message"` AuthIPData []AuthIP `json:"data"` Pages pagination `json:"pagination"` }
AuthIPResponse represents an API response from proxybonanza.com.
type DelAuthIPResponse ¶
type DelAuthIPResponse struct {
Success bool `json:"success"`
}
DelAuthIPResponse represents an API response from proxybonanza.com.
type Package ¶
type Package struct { ID int AuthIPs []AuthIP AllTimeStats PackageStatistics HourlyStats map[time.Time]PackageStatistics }
Package contains what we know about a particular proxybonanza package.
type PackageDetails ¶
type PackageDetails struct { Name string `json:"name"` Bandwidth int64 `json:"bandwidth"` Price interface{} `json:"price"` HowmanyIPs int `json:"howmany_ips"` PricePerGig interface{} `json:"price_per_gig"` PackageType string `json:"package_type"` HowmanyAuthips int `json:"howmany_authips"` IPType int `json:"ip_type"` PriceUserFormatted string `json:"price_user_formatted"` }
PackageDetails represents an API response from proxybonanza.com containing proxy package information.
type PackageResponse ¶
type PackageResponse struct { Success bool `json:"success"` Message string `json:"message"` PackageData []UserPackage `json:"data"` Pages pagination `json:"pagination"` }
PackageResponse represents an API response from proxybonanza.com containing proxy package information.
type PackageStatistics ¶
type PackageStatistics struct { UserpackageID int `json:"userpackage_id"` Date string `json:"date"` BndHTTP int `json:"bnd_http"` ConnHTTP int `json:"conn_http"` BndSocks int `json:"bnd_socks"` ConnSocks int `json:"conn_socks"` BndTotal int `json:"bnd_total"` ConnTotal int `json:"conn_total"` }
PackageStatistics represents the statistics for the related proxy package.
type UserPackage ¶
type UserPackage struct { ID int `json:"id"` CustomName interface{} `json:"custom_name"` Login string `json:"login"` Password string `json:"password"` Expires time.Time `json:"expires"` Bandwidth int64 `json:"bandwidth"` LowBanwidthNotificationPercent int `json:"low_banwidth_notification_percent"` Package PackageDetails `json:"package"` BandwidthGb float64 `json:"bandwidth_gb"` AdditionalBandwidthGb float64 `json:"additional_bandwidth_gb"` BandwidthPercentLeftHuman string `json:"bandwidth_percent_left_human"` ExpirationDateHuman string `json:"expiration_date_human"` Name string `json:"name"` }
UserPackage represents a proxy package purchased from proxybonanza.com.