Separate run command from main function

This commit is contained in:
2024-04-28 22:26:53 +07:00
parent 5ca6cdd129
commit e6344743d5
12 changed files with 74 additions and 79 deletions

48
app/app.go Normal file
View File

@ -0,0 +1,48 @@
package app
import (
"fmt"
"github.com/fossyy/filekeeper/db"
"github.com/fossyy/filekeeper/middleware"
"github.com/fossyy/filekeeper/routes"
"github.com/fossyy/filekeeper/utils"
"net/http"
)
type App struct {
http.Server
DB db.Database
}
var Server App
func NewServer(addr string, handler http.Handler, database db.Database) App {
return App{
Server: http.Server{
Addr: addr,
Handler: handler,
},
DB: database,
}
}
func Start() {
serverAddr := fmt.Sprintf("%s:%s", utils.Getenv("SERVER_HOST"), utils.Getenv("SERVER_PORT"))
dbUser := utils.Getenv("DB_USERNAME")
dbPass := utils.Getenv("DB_PASSWORD")
dbHost := utils.Getenv("DB_HOST")
dbPort := utils.Getenv("DB_PORT")
dbName := utils.Getenv("DB_NAME")
database := db.NewPostgresDB(dbUser, dbPass, dbHost, dbPort, dbName, db.DisableSSL)
db.DB = database
Server = NewServer(serverAddr, middleware.Handler(routes.SetupRoutes()), database)
fmt.Printf("Listening on http://%s\n", Server.Addr)
err := Server.ListenAndServe()
if err != nil {
panic(err)
return
}
}

View File

@ -14,6 +14,7 @@ import (
) )
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
var DB Database
type mySQLdb struct { type mySQLdb struct {
*gorm.DB *gorm.DB
@ -23,6 +24,13 @@ type postgresDB struct {
*gorm.DB *gorm.DB
} }
type SSLMode string
const (
DisableSSL SSLMode = "disable"
EnableSSL SSLMode = "enable"
)
type Database interface { type Database interface {
IsUserRegistered(email string, username string) bool IsUserRegistered(email string, username string) bool
@ -79,9 +87,9 @@ func NewMYSQLdb(username, password, host, port, dbName string) Database {
return &mySQLdb{DB} return &mySQLdb{DB}
} }
func NewPostgresDB(username, password, host, port, dbName string) Database { func NewPostgresDB(username, password, host, port, dbName string, mode SSLMode) Database {
var err error var err error
connection := fmt.Sprintf("host=%s user=%s password=%s dbname=%s port=%s sslmode=%s TimeZone=Asia/Jakarta", host, username, password, dbName, port, "disable") connection := fmt.Sprintf("host=%s user=%s password=%s dbname=%s port=%s sslmode=%s TimeZone=Asia/Jakarta", host, username, password, dbName, port, mode)
DB, err := gorm.Open(postgres.New(postgres.Config{ DB, err := gorm.Open(postgres.New(postgres.Config{
DSN: connection, DSN: connection,
}), &gorm.Config{ }), &gorm.Config{

View File

@ -2,7 +2,6 @@ package user
import ( import (
"fmt" "fmt"
"github.com/fossyy/filekeeper/utils"
"sync" "sync"
"time" "time"
@ -27,12 +26,8 @@ type UserWithExpired struct {
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
var UserCache *Cache var UserCache *Cache
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
UserCache = &Cache{users: make(map[string]*UserWithExpired)} UserCache = &Cache{users: make(map[string]*UserWithExpired)}
ticker := time.NewTicker(time.Hour * 8) ticker := time.NewTicker(time.Hour * 8)
@ -66,7 +61,7 @@ func Get(email string) (*UserWithExpired, error) {
return user, nil return user, nil
} }
userData, err := database.GetUser(email) userData, err := db.DB.GetUser(email)
if err != nil { if err != nil {
return nil, err return nil, err
} }

View File

@ -15,13 +15,8 @@ import (
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
} }
func GET(w http.ResponseWriter, r *http.Request) { func GET(w http.ResponseWriter, r *http.Request) {
@ -45,7 +40,7 @@ func GET(w http.ResponseWriter, r *http.Request) {
} }
userSession := middleware.GetUser(storeSession) userSession := middleware.GetUser(storeSession)
files, err := database.GetFiles(userSession.UserID.String()) files, err := db.DB.GetFiles(userSession.UserID.String())
if err != nil { if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError) http.Error(w, err.Error(), http.StatusInternalServerError)
return return

View File

@ -1,7 +1,6 @@
package downloadFileHandler package downloadFileHandler
import ( import (
"github.com/fossyy/filekeeper/utils"
"net/http" "net/http"
"os" "os"
"path/filepath" "path/filepath"
@ -12,18 +11,13 @@ import (
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
} }
func GET(w http.ResponseWriter, r *http.Request) { func GET(w http.ResponseWriter, r *http.Request) {
fileID := r.PathValue("id") fileID := r.PathValue("id")
file, err := database.GetFile(fileID) file, err := db.DB.GetFile(fileID)
if err != nil { if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError) http.Error(w, err.Error(), http.StatusInternalServerError)
log.Error(err.Error()) log.Error(err.Error())

View File

@ -33,9 +33,6 @@ var mailServer *email.SmtpServer
var ListForgotPassword map[string]*ForgotPassword var ListForgotPassword map[string]*ForgotPassword
var UserForgotPassword = make(map[string]string) var UserForgotPassword = make(map[string]string)
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
ListForgotPassword = make(map[string]*ForgotPassword) ListForgotPassword = make(map[string]*ForgotPassword)
@ -43,7 +40,6 @@ func init() {
mailServer = email.NewSmtpServer(utils.Getenv("SMTP_HOST"), smtpPort, utils.Getenv("SMTP_USER"), utils.Getenv("SMTP_PASSWORD")) mailServer = email.NewSmtpServer(utils.Getenv("SMTP_HOST"), smtpPort, utils.Getenv("SMTP_USER"), utils.Getenv("SMTP_PASSWORD"))
ticker := time.NewTicker(time.Minute) ticker := time.NewTicker(time.Minute)
//TESTING //TESTING
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
go func() { go func() {
for { for {
<-ticker.C <-ticker.C
@ -89,7 +85,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
emailForm := r.Form.Get("email") emailForm := r.Form.Get("email")
user, err := database.GetUser(emailForm) user, err := db.DB.GetUser(emailForm)
if errors.Is(err, gorm.ErrRecordNotFound) { if errors.Is(err, gorm.ErrRecordNotFound) {
component := forgotPasswordView.Main(fmt.Sprintf("Account with this email address %s is not found", emailForm), types.Message{ component := forgotPasswordView.Main(fmt.Sprintf("Account with this email address %s is not found", emailForm), types.Message{
Code: 0, Code: 0,

View File

@ -16,13 +16,9 @@ import (
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
//TESTING //TESTING
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
} }
@ -90,7 +86,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
return return
} }
err = database.UpdateUserPassword(data.User.Email, hashedPassword) err = db.DB.UpdateUserPassword(data.User.Email, hashedPassword)
if err != nil { if err != nil {
http.Error(w, err.Error(), http.StatusInternalServerError) http.Error(w, err.Error(), http.StatusInternalServerError)
log.Error(err.Error()) log.Error(err.Error())

View File

@ -32,16 +32,12 @@ var mailServer *email.SmtpServer
var VerifyUser map[string]*UnverifiedUser var VerifyUser map[string]*UnverifiedUser
var VerifyEmail map[string]string var VerifyEmail map[string]string
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
smtpPort, _ := strconv.Atoi(utils.Getenv("SMTP_PORT")) smtpPort, _ := strconv.Atoi(utils.Getenv("SMTP_PORT"))
mailServer = email.NewSmtpServer(utils.Getenv("SMTP_HOST"), smtpPort, utils.Getenv("SMTP_USER"), utils.Getenv("SMTP_PASSWORD")) mailServer = email.NewSmtpServer(utils.Getenv("SMTP_HOST"), smtpPort, utils.Getenv("SMTP_USER"), utils.Getenv("SMTP_PASSWORD"))
VerifyUser = make(map[string]*UnverifiedUser) VerifyUser = make(map[string]*UnverifiedUser)
VerifyEmail = make(map[string]string) VerifyEmail = make(map[string]string)
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
ticker := time.NewTicker(time.Minute) ticker := time.NewTicker(time.Minute)
go func() { go func() {
@ -112,7 +108,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
Password: hashedPassword, Password: hashedPassword,
} }
if registered := database.IsUserRegistered(userEmail, username); registered { if registered := db.DB.IsUserRegistered(userEmail, username); registered {
component := signupView.Main("Sign up Page", types.Message{ component := signupView.Main("Sign up Page", types.Message{
Code: 0, Code: 0,
Message: "Email or Username has been registered", Message: "Email or Username has been registered",

View File

@ -1,7 +1,6 @@
package signupVerifyHandler package signupVerifyHandler
import ( import (
"github.com/fossyy/filekeeper/utils"
"net/http" "net/http"
"github.com/fossyy/filekeeper/db" "github.com/fossyy/filekeeper/db"
@ -13,13 +12,8 @@ import (
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
} }
func GET(w http.ResponseWriter, r *http.Request) { func GET(w http.ResponseWriter, r *http.Request) {
@ -31,7 +25,7 @@ func GET(w http.ResponseWriter, r *http.Request) {
return return
} }
err := database.CreateUser(data.User) err := db.DB.CreateUser(data.User)
if err != nil { if err != nil {
component := signupView.Main("Sign up Page", types.Message{ component := signupView.Main("Sign up Page", types.Message{
Code: 0, Code: 0,

View File

@ -3,7 +3,6 @@ package initialisation
import ( import (
"encoding/json" "encoding/json"
"errors" "errors"
"github.com/fossyy/filekeeper/utils"
"io" "io"
"net/http" "net/http"
"os" "os"
@ -21,13 +20,8 @@ import (
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
} }
func POST(w http.ResponseWriter, r *http.Request) { func POST(w http.ResponseWriter, r *http.Request) {
@ -59,7 +53,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
return return
} }
fileData, err := database.GetUserFile(fileInfo.Name, userSession.UserID.String()) fileData, err := db.DB.GetUserFile(fileInfo.Name, userSession.UserID.String())
if err != nil { if err != nil {
if errors.Is(err, gorm.ErrRecordNotFound) { if errors.Is(err, gorm.ErrRecordNotFound) {
upload, err := handleNewUpload(userSession, fileInfo) upload, err := handleNewUpload(userSession, fileInfo)
@ -74,7 +68,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
return return
} }
info, err := database.GetUploadInfo(fileData.ID.String()) info, err := db.DB.GetUploadInfo(fileData.ID.String())
if err != nil { if err != nil {
log.Error(err.Error()) log.Error(err.Error())
return return
@ -122,7 +116,7 @@ func handleNewUpload(user types.User, file types.FileInfo) (models.FilesUploaded
Downloaded: 0, Downloaded: 0,
} }
err = database.CreateFile(&newFile) err = db.DB.CreateFile(&newFile)
if err != nil { if err != nil {
log.Error(err.Error()) log.Error(err.Error())
return models.FilesUploaded{}, err return models.FilesUploaded{}, err
@ -138,7 +132,7 @@ func handleNewUpload(user types.User, file types.FileInfo) (models.FilesUploaded
Done: false, Done: false,
} }
err = database.CreateUploadInfo(filesUploaded) err = db.DB.CreateUploadInfo(filesUploaded)
if err != nil { if err != nil {
log.Error(err.Error()) log.Error(err.Error())
return models.FilesUploaded{}, err return models.FilesUploaded{}, err

View File

@ -3,7 +3,6 @@ package uploadHandler
import ( import (
"errors" "errors"
"github.com/fossyy/filekeeper/db" "github.com/fossyy/filekeeper/db"
"github.com/fossyy/filekeeper/utils"
"io" "io"
"net/http" "net/http"
"os" "os"
@ -20,13 +19,8 @@ import (
var log *logger.AggregatedLogger var log *logger.AggregatedLogger
var mu sync.Mutex var mu sync.Mutex
// TESTTING VAR
var database db.Database
func init() { func init() {
log = logger.Logger() log = logger.Logger()
database = db.NewPostgresDB(utils.Getenv("DB_USERNAME"), utils.Getenv("DB_PASSWORD"), utils.Getenv("DB_HOST"), utils.Getenv("DB_PORT"), utils.Getenv("DB_NAME"))
} }
func GET(w http.ResponseWriter, r *http.Request) { func GET(w http.ResponseWriter, r *http.Request) {
@ -62,7 +56,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
userSession := middleware.GetUser(storeSession) userSession := middleware.GetUser(storeSession)
if r.FormValue("done") == "true" { if r.FormValue("done") == "true" {
database.FinalizeFileUpload(fileID) db.DB.FinalizeFileUpload(fileID)
return return
} }
@ -72,7 +66,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
return return
} }
file, err := database.GetUploadInfo(fileID) file, err := db.DB.GetUploadInfo(fileID)
if err != nil { if err != nil {
log.Error("error getting upload info: " + err.Error()) log.Error("error getting upload info: " + err.Error())
return return
@ -110,7 +104,7 @@ func POST(w http.ResponseWriter, r *http.Request) {
if err != nil { if err != nil {
return return
} }
database.UpdateUpdateIndex(index, fileID) db.DB.UpdateUpdateIndex(index, fileID)
} }
func createUploadDirectory(uploadDir string) error { func createUploadDirectory(uploadDir string) error {

19
main.go
View File

@ -1,24 +1,9 @@
package main package main
import ( import (
"fmt" "github.com/fossyy/filekeeper/app"
"net/http"
"github.com/fossyy/filekeeper/middleware"
"github.com/fossyy/filekeeper/routes"
"github.com/fossyy/filekeeper/utils"
) )
func main() { func main() {
serverAddr := fmt.Sprintf("%s:%s", utils.Getenv("SERVER_HOST"), utils.Getenv("SERVER_PORT")) app.Start()
server := http.Server{
Addr: serverAddr,
Handler: middleware.Handler(routes.SetupRoutes()),
}
fmt.Printf("Listening on http://%s\n", serverAddr)
err := server.ListenAndServe()
if err != nil {
return
}
} }