docker compose
This commit is contained in:
14
.env
14
.env
@@ -1,7 +1,7 @@
|
|||||||
TG_TOKEN=
|
# Used for bot AND docker compose
|
||||||
PREFIXES=/;!
|
PSQL_USER=kurumi_bot
|
||||||
DEBUG=true
|
PSQL_PASS=kurumi_bot
|
||||||
USE_REQ_LOG=true
|
PSQL_NAME=kurumi_bot
|
||||||
PSQL_USER=
|
MONGO_USER=kurumi_bot
|
||||||
PSQL_NAME=
|
MONGO_PASS=kurumi_bot
|
||||||
PSQL_PASS=
|
MONGO_NAME=kurumi_bot
|
||||||
5
.env.development
Normal file
5
.env.development
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
# User ONLY for bot. Rename to .env.production
|
||||||
|
TG_TOKEN=
|
||||||
|
PREFIXES=/;!
|
||||||
|
DEBUG=true
|
||||||
|
USE_REQ_LOG=true
|
||||||
3
.gitignore
vendored
3
.gitignore
vendored
@@ -1,3 +1,4 @@
|
|||||||
logs/
|
logs/
|
||||||
.idea/
|
.idea/
|
||||||
config.json
|
config.json
|
||||||
|
.env.production
|
||||||
@@ -3,5 +3,5 @@ WORKDIR /usr/src/kurumi
|
|||||||
COPY go.mod go.sum ./
|
COPY go.mod go.sum ./
|
||||||
RUN go mod download
|
RUN go mod download
|
||||||
COPY . .
|
COPY . .
|
||||||
RUN go build -v -o /usr/local/bin/kurumi ./
|
RUN --mount=type=cache,target=/go/pkg/mod go build -trimpath -o /usr/local/bin/kurumi ./
|
||||||
CMD ["kurumi"]
|
CMD ["kurumi"]
|
||||||
@@ -1,9 +1,7 @@
|
|||||||
package database
|
package database
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/json"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
|
||||||
"log"
|
"log"
|
||||||
"os"
|
"os"
|
||||||
|
|
||||||
@@ -19,33 +17,23 @@ type config struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
var Database *gorm.DB
|
var Database *gorm.DB
|
||||||
var conf *config
|
|
||||||
|
|
||||||
func loadConfig() {
|
|
||||||
file, err := os.Open("./config.json")
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalln(err)
|
|
||||||
}
|
|
||||||
data, err := io.ReadAll(file)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalln(err)
|
|
||||||
}
|
|
||||||
conf = new(config)
|
|
||||||
err = json.Unmarshal(data, conf)
|
|
||||||
if err != nil {
|
|
||||||
log.Fatalln(err)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func getDSN() string {
|
func getDSN() string {
|
||||||
return fmt.Sprintf("postgresql://%s:%s@%s/%s?sslmode=disable", conf.User, conf.Password, conf.Host, conf.Database)
|
user := os.Getenv("PSQL_USER")
|
||||||
|
password := os.Getenv("PSQL_PASS")
|
||||||
|
database := os.Getenv("PSQL_NAME")
|
||||||
|
log.Println("user:", user, "database:", database)
|
||||||
|
return fmt.Sprintf("postgresql://%s:%s@%s/%s?sslmode=disable", user, password, "postgres", database)
|
||||||
}
|
}
|
||||||
|
|
||||||
func Connect() {
|
func Connect() {
|
||||||
var err error
|
var err error
|
||||||
loadConfig()
|
|
||||||
Database, err = gorm.Open(postgres.Open(getDSN()), new(gorm.Config))
|
Database, err = gorm.Open(postgres.Open(getDSN()), new(gorm.Config))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalln(err)
|
log.Fatalln(err)
|
||||||
}
|
}
|
||||||
|
err = Database.AutoMigrate(&User{}, &Fraction{}, &Group{}, &ShopAuto{})
|
||||||
|
if err != nil {
|
||||||
|
log.Fatalln(err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
67
docker-compose.yml
Normal file
67
docker-compose.yml
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:alpine
|
||||||
|
networks:
|
||||||
|
- bot
|
||||||
|
restart: always
|
||||||
|
ports:
|
||||||
|
- "5432:5432"
|
||||||
|
environment:
|
||||||
|
POSTGRES_DB: ${PSQL_NAME}
|
||||||
|
POSTGRES_USER: ${PSQL_USER}
|
||||||
|
POSTGRES_PASSWORD: ${PSQL_PASS}
|
||||||
|
healthcheck:
|
||||||
|
test: ["CMD-SHELL", "pg_isready -U ${PSQL_USER} -d ${PSQL_NAME}"]
|
||||||
|
interval: 2s
|
||||||
|
retries: 5
|
||||||
|
timeout: 10s
|
||||||
|
volumes:
|
||||||
|
- ./scripts/postgres:/docker-entrypoint-initdb.d
|
||||||
|
- postgres_data:/var/lib/postgresql/data
|
||||||
|
mongo:
|
||||||
|
image: mongo:noble
|
||||||
|
networks:
|
||||||
|
- bot
|
||||||
|
restart: always
|
||||||
|
ports:
|
||||||
|
- "27017:27017"
|
||||||
|
environment:
|
||||||
|
MONGO_INITDB_ROOT_USERNAME: ${MONGO_USER}
|
||||||
|
MONGO_INITDB_ROOT_PASSWORD: ${MONGO_PASS}
|
||||||
|
MONGO_INIDB_DATABASE: ${MONGO_NAME}
|
||||||
|
volumes:
|
||||||
|
- ./scripts/mongo:/docker-entrypoint-initdb.d
|
||||||
|
- mongo_data:/data/db
|
||||||
|
|
||||||
|
redis:
|
||||||
|
image: redis:alpine
|
||||||
|
networks:
|
||||||
|
- bot
|
||||||
|
restart: always
|
||||||
|
ports:
|
||||||
|
- "6379:6379"
|
||||||
|
|
||||||
|
bot:
|
||||||
|
env_file:
|
||||||
|
- .env
|
||||||
|
- .env.production
|
||||||
|
build:
|
||||||
|
context: ./
|
||||||
|
dockerfile: ./Dockerfile
|
||||||
|
networks:
|
||||||
|
- bot
|
||||||
|
depends_on:
|
||||||
|
mongo:
|
||||||
|
condition: service_started
|
||||||
|
redis:
|
||||||
|
condition: service_started
|
||||||
|
postgres:
|
||||||
|
condition: service_healthy
|
||||||
|
restart: true
|
||||||
|
|
||||||
|
networks:
|
||||||
|
bot:
|
||||||
|
driver: bridge
|
||||||
|
volumes:
|
||||||
|
postgres_data:
|
||||||
|
mongo_data:
|
||||||
6
main.go
6
main.go
@@ -3,6 +3,8 @@ package main
|
|||||||
import (
|
import (
|
||||||
"kurumibot/database"
|
"kurumibot/database"
|
||||||
"kurumibot/plugins"
|
"kurumibot/plugins"
|
||||||
|
"log"
|
||||||
|
"os"
|
||||||
|
|
||||||
"kurumibot/laniakea"
|
"kurumibot/laniakea"
|
||||||
)
|
)
|
||||||
@@ -10,12 +12,14 @@ import (
|
|||||||
func main() {
|
func main() {
|
||||||
database.Connect()
|
database.Connect()
|
||||||
bot := laniakea.NewBot(&laniakea.BotSettings{
|
bot := laniakea.NewBot(&laniakea.BotSettings{
|
||||||
Token: "",
|
Token: os.Getenv("TG_TOKEN"),
|
||||||
Debug: true,
|
Debug: true,
|
||||||
Prefixes: laniakea.LoadPrefixesFromEnv(),
|
Prefixes: laniakea.LoadPrefixesFromEnv(),
|
||||||
UseRequestLogger: true,
|
UseRequestLogger: true,
|
||||||
LoggerBasePath: "./logs/",
|
LoggerBasePath: "./logs/",
|
||||||
})
|
})
|
||||||
|
log.Println(os.Getenv("PSQL_NAME"))
|
||||||
|
log.Println(os.Getenv("PREFIXES"))
|
||||||
bot = bot.ErrorTemplate("Во время выполнения команды произошла ошибка!\nСообщите об этом разработчику!\n\n%s")
|
bot = bot.ErrorTemplate("Во время выполнения команды произошла ошибка!\nСообщите об этом разработчику!\n\n%s")
|
||||||
plugins.RegisterEconomy(bot)
|
plugins.RegisterEconomy(bot)
|
||||||
plugins.RegisterWaifus(bot)
|
plugins.RegisterWaifus(bot)
|
||||||
|
|||||||
Reference in New Issue
Block a user