1
0
mirror of https://github.com/beego/bee.git synced 2024-11-22 15:10:54 +00:00
bee/rundocs.go

156 lines
3.7 KiB
Go
Raw Normal View History

2014-06-19 13:09:17 +00:00
// Copyright 2013 bee authors
//
// 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 main
import (
"archive/zip"
"fmt"
"io"
"net/http"
"os"
2016-08-19 15:45:18 +00:00
"strings"
2014-06-19 13:09:17 +00:00
)
var cmdRundocs = &Command{
UsageLine: "rundocs [-isDownload=true] [-docport=8888]",
Short: "rundocs will run the docs server,default is 8089",
Long: `
-d meaning will download the docs file from github
-p meaning server the Server on which port, default is 8089
`,
}
2016-08-16 16:52:57 +00:00
var (
swaggerVersion = "2"
swaggerlink = "https://github.com/beego/swagger/archive/v" + swaggerVersion + ".zip"
2014-06-19 13:09:17 +00:00
)
type docValue string
func (d *docValue) String() string {
return fmt.Sprint(*d)
}
func (d *docValue) Set(value string) error {
*d = docValue(value)
return nil
}
var isDownload docValue
var docport docValue
func init() {
cmdRundocs.Run = runDocs
cmdRundocs.PreRun = func(cmd *Command, args []string) { ShowShortVersionBanner() }
2014-06-19 13:09:17 +00:00
cmdRundocs.Flag.Var(&isDownload, "isDownload", "weather download the Swagger Docs")
cmdRundocs.Flag.Var(&docport, "docport", "doc server port")
}
2014-08-15 09:38:51 +00:00
func runDocs(cmd *Command, args []string) int {
2014-06-19 13:09:17 +00:00
if isDownload == "true" {
2016-07-22 23:05:01 +00:00
downloadFromURL(swaggerlink, "swagger.zip")
2016-08-16 16:52:57 +00:00
err := unzipAndDelete("swagger.zip")
2014-06-19 13:09:17 +00:00
if err != nil {
logger.Errorf("Error while unzipping 'swagger.zip' file: %s", err)
2014-06-19 13:09:17 +00:00
}
}
if docport == "" {
docport = "8089"
}
if _, err := os.Stat("swagger"); err != nil && os.IsNotExist(err) {
logger.Fatal("No Swagger dist found. Run: bee rundocs -isDownload=true")
}
logger.Infof("Starting the docs server on: http://127.0.0.1:%s", docport)
err := http.ListenAndServe(":"+string(docport), http.FileServer(http.Dir("swagger")))
if err != nil {
logger.Fatalf("%s", err)
}
2014-08-15 09:38:51 +00:00
return 0
2014-06-19 13:09:17 +00:00
}
2016-07-22 23:05:01 +00:00
func downloadFromURL(url, fileName string) {
2016-08-16 16:52:57 +00:00
var down bool
if fd, err := os.Stat(fileName); err != nil && os.IsNotExist(err) {
down = true
} else if fd.Size() == int64(0) {
down = true
} else {
logger.Infof("'%s' already exists", fileName)
2014-06-19 13:09:17 +00:00
return
}
2016-08-16 16:52:57 +00:00
if down {
logger.Infof("Downloading '%s' to '%s'...", url, fileName)
2016-08-16 16:52:57 +00:00
output, err := os.Create(fileName)
if err != nil {
logger.Errorf("Error while creating '%s': %s", fileName, err)
2016-08-16 16:52:57 +00:00
return
}
defer output.Close()
2014-06-19 13:09:17 +00:00
2016-08-16 16:52:57 +00:00
response, err := http.Get(url)
if err != nil {
logger.Errorf("Error while downloading '%s': %s", url, err)
2016-08-16 16:52:57 +00:00
return
}
defer response.Body.Close()
2014-06-19 13:09:17 +00:00
2016-08-16 16:52:57 +00:00
n, err := io.Copy(output, response.Body)
if err != nil {
logger.Errorf("Error while downloading '%s': %s", url, err)
2016-08-16 16:52:57 +00:00
return
}
logger.Successf("%d bytes downloaded!", n)
2014-06-19 13:09:17 +00:00
}
}
2016-08-16 16:52:57 +00:00
func unzipAndDelete(src string) error {
logger.Infof("Unzipping '%s'...", src)
2014-06-19 13:09:17 +00:00
r, err := zip.OpenReader(src)
if err != nil {
return err
}
defer r.Close()
2016-08-19 15:45:18 +00:00
rp := strings.NewReplacer("swagger-"+swaggerVersion, "swagger")
2014-06-19 13:09:17 +00:00
for _, f := range r.File {
rc, err := f.Open()
if err != nil {
return err
}
defer rc.Close()
2016-08-19 15:45:18 +00:00
fname := rp.Replace(f.Name)
2014-06-19 13:09:17 +00:00
if f.FileInfo().IsDir() {
2016-08-19 15:45:18 +00:00
os.MkdirAll(fname, f.Mode())
2014-06-19 13:09:17 +00:00
} else {
f, err := os.OpenFile(
2016-08-19 15:45:18 +00:00
fname, os.O_WRONLY|os.O_CREATE|os.O_TRUNC, f.Mode())
2014-06-19 13:09:17 +00:00
if err != nil {
return err
}
defer f.Close()
_, err = io.Copy(f, rc)
if err != nil {
return err
}
}
}
logger.Successf("Done! Deleting '%s'...", src)
2016-08-16 16:52:57 +00:00
return os.RemoveAll(src)
2014-06-19 13:09:17 +00:00
}