Last active
September 15, 2019 15:06
-
-
Save anta40/32325cf0a6df2187904213a56c42ab8a to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package main | |
import ( | |
"database/sql" | |
"encoding/json" | |
"fmt" | |
"log" | |
"github.com/gorilla/mux" | |
"net/http" | |
_ "github.com/lib/pq" | |
) | |
const ( | |
host = "localhost" | |
port = 2019 | |
user = "postgres" | |
password = "testdb12345" | |
dbname = "db-dev-01" | |
) | |
type User struct { | |
UserId string `form:"userid" json:"userid"` | |
UserName string `form:"username" json:"username"` | |
UserEmail string `form:"email" json:"email"` | |
UserPhone string `form:"phone" json:"phone"` | |
} | |
type Response struct { | |
Status int `json:"status"` | |
Message string `json:"message"` | |
Data []User | |
} | |
type Response2 struct { | |
Status int `json:"status"` | |
Message string `json:"message"` | |
} | |
func main() { | |
router := mux.NewRouter() | |
router.HandleFunc("/users", returnAllUsers).Methods("GET") | |
router.HandleFunc("/login", login).Methods("POST") | |
http.Handle("/", router) | |
fmt.Println("Connected to port 1234") | |
log.Fatal(http.ListenAndServe(":1234", router)) | |
} | |
func DB_connect() *sql.DB { | |
psqlInfo := fmt.Sprintf("host=%s port=%d user=%s "+ | |
"password=%s dbname=%s sslmode=disable", | |
host, port, user, password, dbname) | |
db, err := sql.Open("postgres", psqlInfo) | |
if err != nil { | |
log.Fatal(err) | |
} | |
return db | |
} | |
func returnAllUsers(w http.ResponseWriter, r *http.Request) { | |
var user User | |
var arr_user []User | |
var response Response | |
db := DB_connect() | |
defer db.Close() | |
rows, err := db.Query("SELECT userid,username,email,phone FROM oc_user") | |
if err != nil { | |
log.Print(err) | |
} | |
for rows.Next() { | |
if err := rows.Scan(&user.UserId, &user.UserName, &user.UserEmail, &user.UserPhone); err != nil { | |
log.Fatal(err.Error()) | |
} else { | |
arr_user = append(arr_user, user) | |
} | |
} | |
response.Status = 1 | |
response.Message = "Success" | |
response.Data = arr_user | |
w.Header().Set("Content-Type", "application/json") | |
json.NewEncoder(w).Encode(response) | |
} | |
func login(w http.ResponseWriter, r *http.Request) { | |
var response Response2 | |
r.ParseForm() | |
username := r.Form.Get("username") | |
password := r.Form.Get("password") | |
if (username == "Edward") && (password == "hello123") { | |
response.Status = 1 | |
response.Message = "Hello "+username | |
} else { | |
response.Status = 0 | |
response.Message = "Invalid login" | |
} | |
w.Header().Set("Content-Type", "application/json") | |
json.NewEncoder(w).Encode(response) | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment