adds api routes to documentation

This commit is contained in:
dhax 2017-09-28 21:58:25 +02:00
parent b36ccae974
commit fb668425de
14 changed files with 1457 additions and 2 deletions

72
cmd/gendoc.go Normal file
View file

@ -0,0 +1,72 @@
// Copyright © 2017 NAME HERE <EMAIL ADDRESS>
//
// 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 cmd
import (
"fmt"
"io/ioutil"
"github.com/dhax/go-base/api"
"github.com/go-chi/docgen"
"github.com/spf13/cobra"
)
var (
routes bool
)
// gendocCmd represents the gendoc command
var gendocCmd = &cobra.Command{
Use: "gendoc",
Short: "Generate project documentation",
Long: `A longer description that spans multiple lines and likely contains examples
and usage of using your command. For example:
Cobra is a CLI library for Go that empowers applications.
This application is a tool to generate the needed files
to quickly create a Cobra application.`,
Run: func(cmd *cobra.Command, args []string) {
if routes {
genRoutesDoc()
}
},
}
func init() {
RootCmd.AddCommand(gendocCmd)
// Here you will define your flags and configuration settings.
// Cobra supports Persistent Flags which will work for this command
// and all subcommands, e.g.:
// gendocCmd.PersistentFlags().String("foo", "", "A help for foo")
// Cobra supports local flags which will only run when this command
// is called directly, e.g.:
// gendocCmd.Flags().BoolP("toggle", "t", false, "Help message for toggle")
gendocCmd.Flags().BoolVarP(&routes, "routes", "r", false, "create api routes markdown file")
}
func genRoutesDoc() {
fmt.Println("generating routes markdown file")
api, _ := api.NewAPI()
md := docgen.MarkdownRoutesDoc(api, docgen.MarkdownOpts{
ProjectPath: "github.com/dhax/go-base",
Intro: "GoBase REST API.",
})
if err := ioutil.WriteFile("routes.md", []byte(md), 0644); err != nil {
fmt.Println(err)
}
}