go-ipify

The official client library for ipify: A Simple IP Address API.

  • 所有者: rdegges/go-ipify
  • 平台:
  • 許可證: The Unlicense
  • 分類:
  • 主題:
  • 喜歡:
    0
      比較:

Github星跟蹤圖

go-ipify

The official client library for ipify: A Simple IP Address API.

GitHub License
GitHub Stars
GoDoc
Build Status

Meta

Purpose

ipify is the best IP address lookup service on the internet. It's fast,
simple, scalable, open source, and well-funded (by me!).

In short: if you need a way to pragmatically get your public IP address, ipify
is the best possible choice!

This library will retrieve your public IP address from ipify's API service, and
return it as a string. It can't get any simpler than that.

This library also has some other nice features you might care about:

  • If a request fails for any reason, it is re-attempted 3 times using an
    exponential backoff algorithm for maximum effectiveness.
  • This library handles errors properly, and usage examples below show you
    how to deal with errors in a foolproof way.
  • This library only makes API requests over HTTPS.

Installation

To install ipify, simply run:

$ go get github.com/rdegges/go-ipify

This will install the latest version of the library automatically.

Usage

Using this library is very simple. Here's a simple example:

package main

import (
    "fmt"
    "github.com/rdegges/go-ipify"
)

func main() {
    ip, err := ipify.GetIp()
    if err != nil {
        fmt.Println("Couldn't get my IP address:", err)
    } else {
        fmt.Println("My IP address is:", ip)
    }
}

Now, in regards to error handling, there are several ways this can fail:

  • The ipify service is down (not likely), or:
  • Your machine is unable to get the request to ipify because of a network error
    of some sort (DNS, no internet, etc.).

The library will output an informative error message in the event anything
fails.

One thing to keep in mind: regardless of how you decide to handle errors, the
ipify library will retry any failed requests 3 times before ever failing -- so
if you do need to handle errors, just remember that retry logic has already
been attempted.

Contributing

This project is only possible due to the amazing contributors who work on it!

If you'd like to improve this library, please send me a pull request! I'm
happy to review and merge pull requests.

The standard contribution workflow should look something like this:

  • Fork this project on Github.
  • Make some changes in the master branch (this project is simple, so no need to
    complicate things
    ).
  • Send a pull request when ready.

Also, if you're making changes, please write tests for your changes -- this
project has a full test suite you can easily modify / test.

To run the test suite, you can use the go test command after forking this
repository.

主要指標

概覽
名稱與所有者rdegges/go-ipify
主編程語言Go
編程語言Go (語言數: 1)
平台
許可證The Unlicense
所有者活动
創建於2015-05-24 23:26:32
推送於2021-03-16 20:38:13
最后一次提交2015-05-25 20:55:02
發布數0
用户参与
星數126
關注者數6
派生數24
提交數19
已啟用問題?
問題數0
打開的問題數0
拉請求數0
打開的拉請求數2
關閉的拉請求數2
项目设置
已啟用Wiki?
已存檔?
是復刻?
已鎖定?
是鏡像?
是私有?