This repository has been archived on 2024-10-31. You can view files and clone it, but cannot push or open issues or pull requests.
feedpanel/main.go

63 lines
1.3 KiB
Go
Raw Normal View History

2018-09-26 15:59:50 +02:00
package main
import (
"fmt"
2018-09-26 16:53:06 +02:00
"os"
2018-09-26 15:59:50 +02:00
"github.com/go-pg/pg"
"github.com/pkg/errors"
)
type DB struct {
PgDB *pg.DB
Schema string
}
2018-09-26 16:53:06 +02:00
func (db *DB) Setup() error {
2018-09-26 15:59:50 +02:00
_, err := db.PgDB.Exec(`CREATE SCHEMA IF NOT EXISTS users`)
if err != nil {
return errors.Wrap(err, "Error creating schema")
}
2018-09-26 16:53:06 +02:00
fmt.Println("schema created")
2018-09-26 15:59:50 +02:00
_, err = db.PgDB.Exec(`CREATE TABLE IF NOT EXISTS users.users (
uid UUID PRIMARY KEY DEFAULT uuid_generate_v4(),
username varchar(64) UNIQUE NOT NULL,
email varchar(100) UNIQUE NOT NULL,
password varchar(256) NOT NULL
)`)
if err != nil {
return errors.Wrap(err, "Error creating users table")
}
2018-09-26 16:53:06 +02:00
fmt.Println("table created")
2018-09-26 15:59:50 +02:00
return nil
}
2018-09-26 16:53:06 +02:00
func (db *DB) UserAdd(username, email, pwhash string) error {
2018-09-26 15:59:50 +02:00
stmt, err := db.PgDB.Prepare("INSERT INTO users.users VALUES ($1, $2, $3)")
if err != nil {
panic("Bad statement in UserAdd")
}
_, err = stmt.Exec(username, email, pwhash)
if err != nil {
return errors.Wrapf(err, "Error adding user `%s`", email)
}
return nil
}
func main() {
2018-09-26 16:53:06 +02:00
pgdb := pg.Connect(&pg.Options{
2018-09-26 15:59:50 +02:00
User: "panel",
2018-09-26 16:53:06 +02:00
Password: "panelpass",
2018-09-26 15:59:50 +02:00
Database: "feeds",
})
2018-09-26 16:53:06 +02:00
db := DB{PgDB: pgdb}
err := db.Setup()
2018-09-26 15:59:50 +02:00
if err != nil {
2018-09-26 16:53:06 +02:00
fmt.Fprintln(os.Stderr, err)
2018-09-26 15:59:50 +02:00
os.Exit(1)
}
2018-09-26 16:53:06 +02:00
fmt.Println("All done")
os.Exit(0)
2018-09-26 15:59:50 +02:00
}