fix mongo, add workout and update help
continuous-integration/drone/push Build is passing Details

This commit is contained in:
Владимир Фёдоров 2023-03-15 02:09:08 +07:00
parent d6d2e06a72
commit ff9a9ca154
2 changed files with 50 additions and 80 deletions

114
db/db.go
View File

@ -11,32 +11,39 @@ import (
) )
type DB struct { type DB struct {
cfg *config.Config chatsColection *mongo.Collection
workoutsColection *mongo.Collection
caloriesColection *mongo.Collection
} }
func NewDB( func NewDB(
mongoURL string, mongoURL string,
dbName string, dbName string,
) *DB { ) (*DB, error) {
return &DB{ ctx := context.Background()
cfg: config.NewConfig(mongoURL, dbName), opt := options.Client().
ApplyURI(mongoURL).
SetMinPoolSize(10)
cfg := config.NewConfig(mongoURL, dbName)
client, err := mongo.Connect(ctx, opt)
if err != nil {
return nil, err
} }
return &DB{
chatsColection: client.Database(dbName).Collection(cfg.ChatsCollectionName),
workoutsColection: client.Database(dbName).Collection(cfg.WorkoutsCollectionName),
caloriesColection: client.Database(dbName).Collection(cfg.CaloriesCollectionName),
}, nil
} }
func (db *DB) AddChat(chatID int64) error { func (db *DB) AddChat(chatID int64) error {
ctx, cancel := context.WithTimeout(context.Background(), time.Second) ctx := context.Background()
defer cancel()
client, err := mongo.Connect(ctx, options.Client().ApplyURI(db.cfg.MongoURL)) result := db.chatsColection.FindOne(ctx, bson.M{"chat_id": chatID})
if err != nil {
return err
}
collection := client.Database(db.cfg.DBName).Collection(db.cfg.ChatsCollectionName)
result := collection.FindOne(ctx, bson.M{"chat_id": chatID})
if result.Err() == mongo.ErrNoDocuments { if result.Err() == mongo.ErrNoDocuments {
if _, err := collection.InsertOne(ctx, &Chat{ChatID: chatID}); err != nil { if _, err := db.chatsColection.InsertOne(ctx, &Chat{ChatID: chatID}); err != nil {
return err return err
} }
return nil return nil
@ -45,6 +52,8 @@ func (db *DB) AddChat(chatID int64) error {
} }
func (db *DB) AddWorkout(chatID int64, workout *Workout) error { func (db *DB) AddWorkout(chatID int64, workout *Workout) error {
ctx := context.Background()
if workout.Count <= 0 { if workout.Count <= 0 {
return nil return nil
} }
@ -53,16 +62,7 @@ func (db *DB) AddWorkout(chatID int64, workout *Workout) error {
} }
workout.ChatID = chatID workout.ChatID = chatID
ctx, cancel := context.WithTimeout(context.Background(), time.Second) _, err := db.workoutsColection.InsertOne(
defer cancel()
client, err := mongo.Connect(ctx, options.Client().ApplyURI(db.cfg.MongoURL))
if err != nil {
return err
}
collection := client.Database(db.cfg.DBName).Collection(db.cfg.WorkoutsCollectionName)
_, err = collection.InsertOne(
ctx, ctx,
workout, workout,
) )
@ -70,6 +70,8 @@ func (db *DB) AddWorkout(chatID int64, workout *Workout) error {
} }
func (db *DB) AddCalories(chatID int64, calories *Calories) error { func (db *DB) AddCalories(chatID int64, calories *Calories) error {
ctx := context.Background()
if calories.Count <= 0 { if calories.Count <= 0 {
return nil return nil
} }
@ -78,16 +80,7 @@ func (db *DB) AddCalories(chatID int64, calories *Calories) error {
} }
calories.ChatID = chatID calories.ChatID = chatID
ctx, cancel := context.WithTimeout(context.Background(), time.Second) _, err := db.caloriesColection.InsertOne(
defer cancel()
client, err := mongo.Connect(ctx, options.Client().ApplyURI(db.cfg.MongoURL))
if err != nil {
return err
}
collection := client.Database(db.cfg.DBName).Collection(db.cfg.CaloriesCollectionName)
_, err = collection.InsertOne(
ctx, ctx,
calories, calories,
) )
@ -95,36 +88,23 @@ func (db *DB) AddCalories(chatID int64, calories *Calories) error {
} }
func (db *DB) GetChatInfo(chatID int64) (*ChatInfo, error) { func (db *DB) GetChatInfo(chatID int64) (*ChatInfo, error) {
ctx := context.Background()
if err := db.AddChat(chatID); err != nil { if err := db.AddChat(chatID); err != nil {
return nil, err return nil, err
} }
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()
client, err := mongo.Connect(ctx, options.Client().ApplyURI(db.cfg.MongoURL))
if err != nil {
return nil, err
}
collection := client.Database(db.cfg.DBName).Collection(db.cfg.ChatsCollectionName)
chatInfoDTO := &ChatInfo{} chatInfoDTO := &ChatInfo{}
if err := collection.FindOne(ctx, bson.M{"chat_id": chatID}).Decode(chatInfoDTO); err != nil { if err := db.chatsColection.FindOne(ctx, bson.M{"chat_id": chatID}).Decode(chatInfoDTO); err != nil {
return nil, err return nil, err
} }
return chatInfoDTO, err return chatInfoDTO, nil
} }
func (db *DB) SetStatusToChat(chatID int64, status UserState) error { func (db *DB) SetStatusToChat(chatID int64, status UserState) error {
ctx, cancel := context.WithTimeout(context.Background(), time.Second) ctx := context.Background()
defer cancel()
client, err := mongo.Connect(ctx, options.Client().ApplyURI(db.cfg.MongoURL)) _, err := db.chatsColection.UpdateOne(
if err != nil {
return err
}
collection := client.Database(db.cfg.DBName).Collection(db.cfg.ChatsCollectionName)
_, err = collection.UpdateOne(
ctx, ctx,
bson.M{"chat_id": chatID}, bson.M{"chat_id": chatID},
bson.M{"$set": bson.M{"status": status}}, bson.M{"$set": bson.M{"status": status}},
@ -133,14 +113,9 @@ func (db *DB) SetStatusToChat(chatID int64, status UserState) error {
} }
func (db *DB) GetStat(chatID int64, cron bool) (map[string]int, error) { func (db *DB) GetStat(chatID int64, cron bool) (map[string]int, error) {
if err := db.AddChat(chatID); err != nil { ctx := context.Background()
return nil, err
}
ctx, cancel := context.WithTimeout(context.Background(), time.Second)
defer cancel()
client, err := mongo.Connect(ctx, options.Client().ApplyURI(db.cfg.MongoURL)) if err := db.AddChat(chatID); err != nil {
if err != nil {
return nil, err return nil, err
} }
@ -155,8 +130,7 @@ func (db *DB) GetStat(chatID int64, cron bool) (map[string]int, error) {
res := map[string]int{} res := map[string]int{}
collection := client.Database(db.cfg.DBName).Collection(db.cfg.WorkoutsCollectionName) cursor, err := db.workoutsColection.Find(
cursor, err := collection.Find(
ctx, ctx,
bson.M{ bson.M{
"chat_id": chatID, "chat_id": chatID,
@ -177,8 +151,7 @@ func (db *DB) GetStat(chatID int64, cron bool) (map[string]int, error) {
log.Fatal(err) log.Fatal(err)
} }
caloriesCollection := client.Database(db.cfg.DBName).Collection(db.cfg.CaloriesCollectionName) caloriesCursor, err := db.caloriesColection.Find(
caloriesCursor, err := caloriesCollection.Find(
ctx, ctx,
bson.M{ bson.M{
"chat_id": chatID, "chat_id": chatID,
@ -203,16 +176,9 @@ func (db *DB) GetStat(chatID int64, cron bool) (map[string]int, error) {
} }
func (db *DB) GetAllChats() ([]int64, error) { func (db *DB) GetAllChats() ([]int64, error) {
ctx, cancel := context.WithTimeout(context.Background(), time.Second) ctx := context.Background()
defer cancel()
client, err := mongo.Connect(ctx, options.Client().ApplyURI(db.cfg.MongoURL)) cursor, err := db.chatsColection.Find(ctx, bson.M{})
if err != nil {
return nil, err
}
collection := client.Database(db.cfg.DBName).Collection(db.cfg.ChatsCollectionName)
cursor, err := collection.Find(ctx, bson.M{})
if err != nil { if err != nil {
return nil, err return nil, err
} }

16
main.go
View File

@ -19,6 +19,7 @@ var (
workoutTypes = []string{ workoutTypes = []string{
"Отжимания", "Отжимания",
"Пресс", "Пресс",
"Подтягивания",
} }
caloriesMap = map[string]int{ caloriesMap = map[string]int{
"чай": 79, "чай": 79,
@ -27,7 +28,7 @@ var (
) )
const ( const (
version = "v1.4.0" version = "v1.5.0"
) )
type Opts struct { type Opts struct {
@ -88,10 +89,13 @@ func run() {
dbName = strings.ReplaceAll(dbName, "\n", "") dbName = strings.ReplaceAll(dbName, "\n", "")
fmt.Println(dbName) fmt.Println(dbName)
dataBase := db.NewDB( dataBase, err := db.NewDB(
mongoURL, mongoURL,
dbName, dbName,
) )
if err != nil {
panic(err)
}
u := tgbot.NewUpdate(0) u := tgbot.NewUpdate(0)
u.Timeout = 60 u.Timeout = 60
@ -230,7 +234,7 @@ func run() {
log.Println(err) log.Println(err)
} }
case commands.Help: case commands.Help:
_, _ = bot.Send(tgbot.NewMessage(chatID, "Вот что я умею:\n\n1) Предлагать размяться\n2) Показывать статистику\n3) Считать калории")) _, _ = bot.Send(tgbot.NewMessage(chatID, "Вот что я умею:\n\n1) Предлагать размяться\n - несколько видов упражнений 6 раз в день\n2) Показывать статистику за день\n3) Считать калории\n - введи одно число, я запишу калории\n - введи 2 числа через пробел одно количество грамм другое количество калорий в 100 граммах (порядок не важен), я посчитаю\n - введи название того что ты съел, я посчитаю (если знаю)"))
case commands.Ping: case commands.Ping:
_, _ = bot.Send(tgbot.NewMessage(chatID, "pong")) _, _ = bot.Send(tgbot.NewMessage(chatID, "pong"))
case commands.Go: case commands.Go:
@ -276,11 +280,11 @@ func calcCalories(text string) (int, error) {
func sendGoToChat(bot *tgbot.BotAPI, dataBase *db.DB, chatID int64) { func sendGoToChat(bot *tgbot.BotAPI, dataBase *db.DB, chatID int64) {
msg := tgbot.NewMessage(chatID, "Давай немного разомнемся, выбирай:") msg := tgbot.NewMessage(chatID, "Давай немного разомнемся, выбирай:")
row := tgbot.NewKeyboardButtonRow() rows := make([][]tgbot.KeyboardButton, 0, len(workoutTypes))
for _, workoutType := range workoutTypes { for _, workoutType := range workoutTypes {
row = append(row, tgbot.NewKeyboardButton(workoutType)) rows = append(rows, tgbot.NewKeyboardButtonRow(tgbot.NewKeyboardButton(workoutType)))
} }
msg.ReplyMarkup = tgbot.NewReplyKeyboard(row) msg.ReplyMarkup = tgbot.NewReplyKeyboard(rows...)
if _, err := bot.Send(msg); err == nil { if _, err := bot.Send(msg); err == nil {
if err := dataBase.SetStatusToChat(chatID, db.UserStateGo); err != nil { if err := dataBase.SetStatusToChat(chatID, db.UserStateGo); err != nil {
log.Println(err) log.Println(err)