Advertisement
Guest User

Untitled

a guest
Mar 31st, 2016
79
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.10 KB | None | 0 0
  1. package main
  2.  
  3. import (
  4. "net/http"
  5. db "./database_sql"
  6. router "./router"
  7. )
  8.  
  9. func main() {
  10.  
  11. db.Init_SQL();
  12.  
  13. router.Init_routes()
  14.  
  15. http.ListenAndServe(":8080", router.GetRouter())
  16.  
  17. }
  18.  
  19. package database_sql
  20.  
  21. import (
  22. "fmt"
  23. "database/sql"
  24. _ "github.com/go-sql-driver/mysql"
  25. )
  26.  
  27. var DB *sql.DB // global variable to share it between main and the HTTP handler
  28. //var dbi *databaseinfos
  29.  
  30. func Init_SQL() {
  31. dbi := databaseinfos{
  32. user: "root",
  33. password: "root",
  34. name: "captainsam",
  35. address: "localhost",
  36. port: "3306",
  37. url: ""}
  38. dbi.url = (dbi.user + ":" + dbi.password + "@tcp(" + dbi.address + ":" + dbi.port + ")/" + dbi.name)
  39.  
  40. db_init_var, err := sql.Open("mysql", dbi.url)
  41. if err != nil {
  42. fmt.Println("Error on initializing database connection: %s", err.Error())
  43. }
  44.  
  45. err = db_init_var.Ping()
  46. if err != nil {
  47. fmt.Println("Error on opening database connection: %s", err.Error())
  48. }
  49.  
  50. // Here, as you can test, my variable is initialized
  51. if err == nil {
  52. DB = db_init_var
  53. if DB == nil {
  54. fmt.Println("NIL DB !!")
  55. }
  56. if db_init_var == nil {
  57. fmt.Println("NIL db_init_var !!")
  58. }
  59. fmt.Println(dbi.url)
  60. }
  61. }
  62.  
  63. package database_sql
  64.  
  65. import (
  66. "encoding/json"
  67. "fmt"
  68. "net/http"
  69. m "models"
  70. )
  71.  
  72. func CanLogin(user m.User) (bool, m.User, m.StatusBack) {
  73.  
  74. // Prepare statement for reading data
  75. stmtOut, err := DB.Prepare("SELECT username, password, token FROM users WHERE username = ? AND password = ?")
  76. if err != nil {
  77. return false, user, m.StatusBack{ToString: err.Error(), IdStatus: http.StatusInternalServerError}
  78. }
  79. defer stmtOut.Close()
  80.  
  81. // Query the user
  82. err = stmtOut.QueryRow(user.Username, user.Password).Scan(&user.Username, &user.Password, &user.UUID) // WHERE user is registered
  83. if err != nil {
  84. return false, user, m.StatusBack{ToString: "User not found.", IdStatus: http.StatusNotFound}
  85. } else {
  86.  
  87. j, err := json.Marshal(user)
  88. if err == nil {
  89. return true, user, m.StatusBack{ToString: string(j), IdStatus: http.StatusOK}
  90. } else {
  91. return false, user, m.StatusBack{ToString: err.Error(), IdStatus: http.StatusInternalServerError}
  92. }
  93. }
  94.  
  95. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement