はじめに
Go言語を勉強しなければという使命感にかられ、遊んでみることにしました。
golang + Qiita API
環境
・ go version go1.13 darwin/amd64
URIと機能
Path | HTTPメソッド | 機能 |
---|---|---|
/qiita/api/v1/user-info | GET | 指定されたユーザの記事一覧を、作成日時の降順で返します。 |
使用パッケージ
・ gin
ginは、go製のWebフレームワークです。jsonレスポンス処理機能も持っている優れものです。
go get github.com/gin-gonic/gin
ファイル構成
❯ tree .
.
├── main.go
└── src
└── controller
└── controller.go
2 directories, 2 files
controller
mainから呼び出すタスク処理をまとめています。
controller.go
package controller
import (
"encoding/json"
"io/ioutil"
"log"
"net/http"
"time"
"github.com/gin-gonic/gin"
)
type Item struct {
Title string `json:"title"`
CreatedAt time.Time `json:"created_at"`
}
// Qiita APIを叩く
func QiitaGET(c *gin.Context) {
resp, err := http.Get("http://qiita.com/api/v2/users/{自身のアカウント名}/items?page=1&per_page=10")
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
body, err := ioutil.ReadAll(resp.Body)
if err != nil {
log.Fatal(err)
}
var data []Item
if err := json.Unmarshal(body, &data); err != nil {
log.Fatal(err)
}
c.JSON(http.StatusOK, gin.H{"item": data})
}
main
メイン処理を記述しました。
main.go
package main
import (
"./src/controller"
"github.com/gin-gonic/gin"
)
func main() {
router := gin.Default()
v1 := router.Group("/qiita/api/v1")
{
v1.GET("/user-info", controller.QiitaGET)
}
router.Run(":9000")
}
実行
❯ go run main.go
[GIN-debug] [WARNING] Creating an Engine instance with the Logger and Recovery middleware already attached.
[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.
- using env: export GIN_MODE=release
- using code: gin.SetMode(gin.ReleaseMode)
[GIN-debug] GET /qiita/api/v1/user-info --> _/Users/********/Desktop/Qiita_PoC_API/src/controller.QiitaGET (3 handlers)
[GIN-debug] Listening and serving HTTP on :9000