193 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			193 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package main
 | |
| 
 | |
| import (
 | |
| 	"log"
 | |
| 
 | |
| 	"github.com/jmoiron/sqlx"
 | |
| )
 | |
| 
 | |
| var schema = `
 | |
| create table if not exists chats
 | |
| (
 | |
| id INTEGER PRIMARY KEY,
 | |
| name TEXT NOT NULL,
 | |
| username TEXT DEFAULT '',
 | |
| topic INTEGER DEFAULT 0,
 | |
| active INTEGER DEFAULT 0
 | |
| );
 | |
| 
 | |
| create table if not exists activations
 | |
| (
 | |
| id INTEGER PRIMARY KEY AUTOINCREMENT,
 | |
| code TEXT NOT NULL
 | |
| );
 | |
| 
 | |
| create table if not exists messagesToDelete
 | |
| (
 | |
| id INTEGER PRIMARY KEY AUTOINCREMENT,
 | |
| message_id INTEGER NOT NULL,
 | |
| chat_id INTEGER NOT NULL,
 | |
| delete_date INTEGER NOT NULL,
 | |
| tries INTEGER DEFAULT 0
 | |
| );
 | |
| 
 | |
| create table if not exists users
 | |
| (
 | |
| id INTEGER PRIMARY KEY,
 | |
| name TEXT NOT NULL,
 | |
| username TEXT DEFAULT ''
 | |
| );
 | |
| 
 | |
| create table if not exists admins
 | |
| (
 | |
| id INTEGER PRIMARY KEY AUTOINCREMENT,
 | |
| user_id INTEGER NOT NULL,
 | |
| chat_id INTEGER NOT NULL,
 | |
| FOREIGN KEY (user_id) REFERENCES users (id) ON DELETE CASCADE,
 | |
| FOREIGN KEY (chat_id) REFERENCES chats (id) ON DELETE CASCADE
 | |
| );
 | |
| 
 | |
| create table if not exists bans
 | |
| (
 | |
| id INTEGER PRIMARY KEY AUTOINCREMENT,
 | |
| chat_id INTEGER NOT NULL,
 | |
| user_id INTEGER NOT NULL,
 | |
| text TEXT DEFAULT '',
 | |
| reason TEXT DEFAULT '',
 | |
| ban_date INTEGER NOT NULL,
 | |
| unban_date INTEGER DEFAULT 0,
 | |
| FOREIGN KEY (user_id) REFERENCES users (id) ON DELETE CASCADE,
 | |
| FOREIGN KEY (chat_id) REFERENCES chats (id) ON DELETE CASCADE
 | |
| );
 | |
| 
 | |
| create table if not exists captchas
 | |
| (
 | |
| id INTEGER PRIMARY KEY AUTOINCREMENT,
 | |
| user_id INTEGER,
 | |
| chat_id INTEGER,
 | |
| message_id INTEGER,
 | |
| correct_answer TEXT DEFAULT '',
 | |
| blocked_until INTEGER DEFAULT 0,
 | |
| FOREIGN KEY (user_id) REFERENCES users (id) ON DELETE CASCADE,
 | |
| FOREIGN KEY (chat_id) REFERENCES chats (id) ON DELETE CASCADE
 | |
| )
 | |
| `
 | |
| 
 | |
| type Chat struct {
 | |
| 	Id       int64  `json:"id" db:"id"`
 | |
| 	Name     string `json:"name" db:"name"`
 | |
| 	Username string `json:"username" db:"username"`
 | |
| 	Topic    int    `json:"topic" db:"topic"`
 | |
| 	Active   bool   `json:"active" db:"active"`
 | |
| }
 | |
| 
 | |
| type MessageToDelete struct {
 | |
| 	Id         int64 `db:"id"`
 | |
| 	MessageId  int   `db:"message_id"`
 | |
| 	ChatId     int64 `db:"chat_id"`
 | |
| 	DeleteDate int64 `db:"delete_date"`
 | |
| 	Tries      int   `db:"tries"`
 | |
| }
 | |
| 
 | |
| type User struct {
 | |
| 	Id       int64  `db:"id"`
 | |
| 	Name     string `db:"name"`
 | |
| 	Username string `db:"username"`
 | |
| }
 | |
| 
 | |
| type Captcha struct {
 | |
| 	Id            int64  `db:"id"`
 | |
| 	UserID        int64  `db:"user_id"`
 | |
| 	ChatID        int64  `db:"chat_id"`
 | |
| 	MessageID     int    `db:"message_id"`
 | |
| 	CorrectAnswer string `db:"correct_answer"`
 | |
| 	BlockedUntil  int64  `db:"blocked_until"`
 | |
| }
 | |
| 
 | |
| var db *sqlx.DB
 | |
| 
 | |
| func InitDb() error {
 | |
| 	newdb, err := sqlx.Connect("sqlite", "./bot.db?_time_format=sqlite")
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	db = newdb
 | |
| 	return nil
 | |
| }
 | |
| 
 | |
| func NewChat(chat Chat) error {
 | |
| 	_, err := db.NamedExec(`insert into chats (id, name, username, topic, active) values (:id, :name, :username, :topic, :active)`, chat)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func IsChatExists(id int64) bool {
 | |
| 	var exists bool
 | |
| 	err := db.Get(&exists, `SELECT exists(SELECT 1 FROM chats WHERE id = $1);`, id)
 | |
| 	if err != nil {
 | |
| 		log.Println("Can't check existing of chat", id, err)
 | |
| 		return false
 | |
| 	}
 | |
| 	return exists
 | |
| }
 | |
| 
 | |
| func IsChatActive(id int64) bool {
 | |
| 	var active bool
 | |
| 	err := db.Get(&active, `SELECT active from chats where id = $1`, id)
 | |
| 	if err != nil {
 | |
| 		return false
 | |
| 	}
 | |
| 	return active
 | |
| }
 | |
| 
 | |
| func GetChatById(id int64) (Chat, error) {
 | |
| 	c := Chat{}
 | |
| 	err := db.Get(&c, `select * from chats where id = $1`, id)
 | |
| 	return c, err
 | |
| }
 | |
| 
 | |
| func NewActivation(code string) error {
 | |
| 	_, err := db.Exec(`insert into activations (code) values ($1)`, code)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func UseActivation(code string) bool {
 | |
| 	exists := false
 | |
| 	err := db.Get(&exists, `SELECT exists(SELECT 1 FROM activations WHERE code = $1);`, code)
 | |
| 	if err != nil || !exists {
 | |
| 		return false
 | |
| 	}
 | |
| 	_, err = db.Exec(`delete from activations where code = $1`, code)
 | |
| 	return err == nil
 | |
| }
 | |
| 
 | |
| func ActivateChat(id int64, thread int) error {
 | |
| 	_, err := db.Exec(`update chats set active = 1, topic = $2 where id = $1`, id, thread)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func AddMessageToDelete(msg MessageToDelete) error {
 | |
| 	_, err := db.NamedExec(`insert into messagesToDelete (message_id, chat_id, delete_date, tries) values (:message_id, :chat_id, :delete_date, 0)`, msg)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func NewUser(user User) error {
 | |
| 	_, err := db.NamedExec(`insert into users (id, name, username) values (:id, :name, :username)`, user)
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func IsUserExists(id int64) bool {
 | |
| 	var exists bool
 | |
| 	err := db.Get(&exists, `SELECT exists(SELECT 1 FROM users WHERE id = $1);`, id)
 | |
| 	if err != nil {
 | |
| 		log.Println("Can't check existing of chat", id, err)
 | |
| 		return false
 | |
| 	}
 | |
| 	return exists
 | |
| }
 | |
| 
 | |
| func GetUserById(id int64) (User, error) {
 | |
| 	c := User{}
 | |
| 	err := db.Get(&c, `select * from users where id = $1`, id)
 | |
| 	return c, err
 | |
| }
 |