slat
This commit is contained in:
		@@ -4,12 +4,12 @@ ai 繪圖服務端(快速重構)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
TEST:
 | 
					TEST:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					- [ ] [/api/users](/api/users)
 | 
				
			||||||
- [ ] [/api/sessions](/api/sessions)
 | 
					- [ ] [/api/sessions](/api/sessions)
 | 
				
			||||||
- [ ] [/api/servers](/api/servers)
 | 
					- [ ] [/api/servers](/api/servers)
 | 
				
			||||||
- [ ] [/api/models](/api/models)
 | 
					- [ ] [/api/models](/api/models)
 | 
				
			||||||
- [ ] [/api/images](/api/images)
 | 
					- [ ] [/api/images](/api/images)
 | 
				
			||||||
- [ ] [/api/tasks](/api/tasks)
 | 
					- [ ] [/api/tasks](/api/tasks)
 | 
				
			||||||
- [ ] [/api/users](/api/users)
 | 
					 | 
				
			||||||
- [ ] [/api/tags](/api/tags)
 | 
					- [ ] [/api/tags](/api/tags)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 
 | 
				
			|||||||
							
								
								
									
										30
									
								
								main.go
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								main.go
									
									
									
									
									
								
							@@ -36,17 +36,29 @@ func main() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
	// 設定路由
 | 
						// 設定路由
 | 
				
			||||||
	r.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
 | 
						r.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
 | 
				
			||||||
		// 從本地讀取Markdown文件
 | 
					 | 
				
			||||||
		input, err := ioutil.ReadFile("./README.md")
 | 
							input, err := ioutil.ReadFile("./README.md")
 | 
				
			||||||
		if err != nil {
 | 
							if err != nil {
 | 
				
			||||||
			log.Println(err)
 | 
								log.Println(err)
 | 
				
			||||||
			return
 | 
								return
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		//output := blackfriday.MarkdownBasic(input)
 | 
					 | 
				
			||||||
		output := blackfriday.Markdown(input, blackfriday.HtmlRenderer(0, "", ""), blackfriday.EXTENSION_TABLES|blackfriday.EXTENSION_FENCED_CODE|blackfriday.EXTENSION_AUTOLINK)
 | 
							output := blackfriday.Markdown(input, blackfriday.HtmlRenderer(0, "", ""), blackfriday.EXTENSION_TABLES|blackfriday.EXTENSION_FENCED_CODE|blackfriday.EXTENSION_AUTOLINK)
 | 
				
			||||||
		w.Write(output)
 | 
							html := "<!DOCTYPE html><html><head><title>API Document</title></head><body>" + string(output) + "</body></html>"
 | 
				
			||||||
 | 
							w.Header().Set("Content-Type", "text/html; charset=utf-8")
 | 
				
			||||||
 | 
							w.Write([]byte(html))
 | 
				
			||||||
	})
 | 
						})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						r.HandleFunc("/api/users", routers.UsersGet).Methods("GET")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/users", routers.UsersPost).Methods("POST")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/users/{id}", routers.UsersItemGet).Methods("GET")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/users/{id}", routers.UsersItemPatch).Methods("PATCH")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/users/{id}", routers.UsersItemDelete).Methods("DELETE")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						r.HandleFunc("/api/sessions", routers.SessionsGet).Methods("GET")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/sessions", routers.SessionsPost).Methods("POST")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/sessions/{id}", routers.SessionsItemGet).Methods("GET")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/sessions/{id}", routers.SessionsItemPatch).Methods("PATCH")
 | 
				
			||||||
 | 
						r.HandleFunc("/api/sessions/{id}", routers.SessionsItemDelete).Methods("DELETE")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	r.HandleFunc("/api/models", routers.ModelsGet).Methods("GET")
 | 
						r.HandleFunc("/api/models", routers.ModelsGet).Methods("GET")
 | 
				
			||||||
	r.HandleFunc("/api/models", routers.ModelsPost).Methods("POST")
 | 
						r.HandleFunc("/api/models", routers.ModelsPost).Methods("POST")
 | 
				
			||||||
	r.HandleFunc("/api/models/{id}", routers.ModelItemGet).Methods("GET")
 | 
						r.HandleFunc("/api/models/{id}", routers.ModelItemGet).Methods("GET")
 | 
				
			||||||
@@ -65,18 +77,6 @@ func main() {
 | 
				
			|||||||
	r.HandleFunc("/api/tasks/{id}", routers.TasksItemPatch).Methods("PATCH")
 | 
						r.HandleFunc("/api/tasks/{id}", routers.TasksItemPatch).Methods("PATCH")
 | 
				
			||||||
	r.HandleFunc("/api/tasks/{id}", routers.TasksItemDelete).Methods("DELETE")
 | 
						r.HandleFunc("/api/tasks/{id}", routers.TasksItemDelete).Methods("DELETE")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	r.HandleFunc("/api/users", routers.UsersGet).Methods("GET")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/users", routers.UsersPost).Methods("POST")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/users/{id}", routers.UsersItemGet).Methods("GET")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/users/{id}", routers.UsersItemPatch).Methods("PATCH")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/users/{id}", routers.UsersItemDelete).Methods("DELETE")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/sessions", routers.SessionsGet).Methods("GET")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/sessions", routers.SessionsPost).Methods("POST")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/sessions/{id}", routers.SessionsItemGet).Methods("GET")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/sessions/{id}", routers.SessionsItemPatch).Methods("PATCH")
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/sessions/{id}", routers.SessionsItemDelete).Methods("DELETE")
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	r.HandleFunc("/api/servers", routers.ServersGet).Methods("GET")
 | 
						r.HandleFunc("/api/servers", routers.ServersGet).Methods("GET")
 | 
				
			||||||
	r.HandleFunc("/api/servers", routers.ServersPost).Methods("POST")
 | 
						r.HandleFunc("/api/servers", routers.ServersPost).Methods("POST")
 | 
				
			||||||
	r.HandleFunc("/api/servers/{id}", routers.ServersItemGet).Methods("GET")
 | 
						r.HandleFunc("/api/servers/{id}", routers.ServersItemGet).Methods("GET")
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,34 +1,51 @@
 | 
				
			|||||||
package models
 | 
					package models
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
 | 
						"crypto/md5"
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
	"log"
 | 
						"log"
 | 
				
			||||||
	"main/configs"
 | 
						"main/configs"
 | 
				
			||||||
 | 
						"main/utils"
 | 
				
			||||||
 | 
						"time"
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
type User struct {
 | 
					type User struct {
 | 
				
			||||||
	ID        int    `json:"id"`
 | 
						ID        int    `json:"id"`
 | 
				
			||||||
	Name      string `json:"name"`
 | 
						Name      string `json:"name"`
 | 
				
			||||||
	Email     string `json:"email"`
 | 
						Email     string `json:"email"`
 | 
				
			||||||
	Password  string `json:"password"`
 | 
					 | 
				
			||||||
	Slat      string `json:"slat"`
 | 
					 | 
				
			||||||
	CreatedAt string `json:"created_at"`
 | 
						CreatedAt string `json:"created_at"`
 | 
				
			||||||
	UpdatedAt string `json:"updated_at"`
 | 
						UpdatedAt string `json:"updated_at"`
 | 
				
			||||||
 | 
						password  string
 | 
				
			||||||
 | 
						slat      string
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
func (user *User) Create() error {
 | 
					func (user *User) Create(name, email, password string) error {
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if name == "" || email == "" || password == "" {
 | 
				
			||||||
 | 
							return fmt.Errorf("name, email and password can not be empty")
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						user.slat = utils.RandomString(16)
 | 
				
			||||||
 | 
						user.password = fmt.Sprintf("%x", md5.Sum([]byte(password+user.slat)))
 | 
				
			||||||
 | 
						user.Name = name
 | 
				
			||||||
 | 
						user.Email = email
 | 
				
			||||||
 | 
						user.CreatedAt = time.Now().Format("2006-01-02 15:04:05")
 | 
				
			||||||
 | 
						user.UpdatedAt = user.CreatedAt
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	db, err := configs.GetDB()
 | 
						db, err := configs.GetDB()
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		log.Println(err)
 | 
							log.Println(err)
 | 
				
			||||||
		return err
 | 
							return err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	defer db.Close()
 | 
						defer db.Close()
 | 
				
			||||||
	stmt, err := db.Prepare("INSERT INTO users(name, email, created_at, updated_at) values(?, ?, ?, ?)")
 | 
						fmt.Println(user)
 | 
				
			||||||
 | 
						stmt, err := db.Prepare("INSERT INTO users(name, email, password, slat, created_at, updated_at) values(?, ?, ?, ?, ?, ?)")
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		log.Println(err)
 | 
							log.Println(err)
 | 
				
			||||||
		return err
 | 
							return err
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
	defer stmt.Close()
 | 
						defer stmt.Close()
 | 
				
			||||||
	result, err := stmt.Exec(user.Name, user.Email, user.CreatedAt, user.UpdatedAt)
 | 
						result, err := stmt.Exec(user.Name, user.Email, user.password, user.slat, user.CreatedAt, user.UpdatedAt)
 | 
				
			||||||
	if err != nil {
 | 
						if err != nil {
 | 
				
			||||||
		log.Println(err)
 | 
							log.Println(err)
 | 
				
			||||||
		return err
 | 
							return err
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -1,6 +1,9 @@
 | 
				
			|||||||
package routers
 | 
					package routers
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import (
 | 
					import (
 | 
				
			||||||
 | 
						"encoding/json"
 | 
				
			||||||
 | 
						"fmt"
 | 
				
			||||||
 | 
						"io/ioutil"
 | 
				
			||||||
	"main/models"
 | 
						"main/models"
 | 
				
			||||||
	"main/utils"
 | 
						"main/utils"
 | 
				
			||||||
	"net/http"
 | 
						"net/http"
 | 
				
			||||||
@@ -22,8 +25,30 @@ func UsersGet(w http.ResponseWriter, r *http.Request) {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
// 創建用戶
 | 
					// 創建用戶
 | 
				
			||||||
func UsersPost(w http.ResponseWriter, r *http.Request) {
 | 
					func UsersPost(w http.ResponseWriter, r *http.Request) {
 | 
				
			||||||
 | 
						var form struct {
 | 
				
			||||||
 | 
							Name     string `json:"name"`
 | 
				
			||||||
 | 
							Email    string `json:"email"`
 | 
				
			||||||
 | 
							Password string `json:"password"`
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						body, err := ioutil.ReadAll(r.Body)
 | 
				
			||||||
 | 
						if err != nil {
 | 
				
			||||||
 | 
							fmt.Println(err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						defer r.Body.Close()
 | 
				
			||||||
 | 
						if err = json.Unmarshal(body, &form); err != nil {
 | 
				
			||||||
 | 
							fmt.Println(err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// 創建用戶
 | 
				
			||||||
	var user models.User
 | 
						var user models.User
 | 
				
			||||||
	user.Create()
 | 
						if err := user.Create(form.Name, form.Email, form.Password); err != nil {
 | 
				
			||||||
 | 
							fmt.Println(err)
 | 
				
			||||||
 | 
							return
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						// 返回信息
 | 
				
			||||||
	w.Header().Set("Content-Type", "application/json; charset=utf-8")
 | 
						w.Header().Set("Content-Type", "application/json; charset=utf-8")
 | 
				
			||||||
	w.Write(utils.ToJSON(user))
 | 
						w.Write(utils.ToJSON(user))
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -4,6 +4,7 @@ import (
 | 
				
			|||||||
	"encoding/json"
 | 
						"encoding/json"
 | 
				
			||||||
	"fmt"
 | 
						"fmt"
 | 
				
			||||||
	"log"
 | 
						"log"
 | 
				
			||||||
 | 
						"math/rand"
 | 
				
			||||||
	"net/http"
 | 
						"net/http"
 | 
				
			||||||
	"strconv"
 | 
						"strconv"
 | 
				
			||||||
	"time"
 | 
						"time"
 | 
				
			||||||
@@ -71,3 +72,18 @@ func LogComponent(startTime int64, r *http.Request) {
 | 
				
			|||||||
	url := fmt.Sprintf("\033[1;34m%s\033[0m", r.URL)       // 藍色加重
 | 
						url := fmt.Sprintf("\033[1;34m%s\033[0m", r.URL)       // 藍色加重
 | 
				
			||||||
	log.Println(method, url, endTime)
 | 
						log.Println(method, url, endTime)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 隨機字串
 | 
				
			||||||
 | 
					func RandomString(length int) string {
 | 
				
			||||||
 | 
						const charset = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
 | 
				
			||||||
 | 
						b := make([]byte, length)
 | 
				
			||||||
 | 
						for i := range b {
 | 
				
			||||||
 | 
							b[i] = charset[RandomInt(0, len(charset)-1)]
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return string(b)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// 隨機數字
 | 
				
			||||||
 | 
					func RandomInt(min, max int) int {
 | 
				
			||||||
 | 
						return min + rand.Intn(max-min+1)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user