added journal command
This commit is contained in:
		| @@ -1,6 +1,6 @@ | ||||
| import datetime | ||||
|  | ||||
| from telegram.ext import ConversationHandler, CommandHandler, MessageHandler, filters, CallbackQueryHandler, CallbackContext | ||||
| import os | ||||
| from telegram.ext import ConversationHandler, CommandHandler, MessageHandler, filters, CallbackQueryHandler | ||||
| from telegram import InlineKeyboardButton, InlineKeyboardMarkup | ||||
| DATE_CHOICE, DATE_ENTRY, CONTENT = range(3) | ||||
|  | ||||
| @@ -28,8 +28,15 @@ class JournalHandler: | ||||
|  | ||||
|         self.current_model = None | ||||
|  | ||||
|  | ||||
|     async def start(self, update, context): | ||||
|         """Send a message when the command /start is issued.""" | ||||
|         if os.getenv("DOCKERIZED", "false") == "true" and os.getenv("CHAT_ID") != str(update.message.chat_id): | ||||
|             await update.message.reply_text("You are not authorized to use this bot") | ||||
|             return ConversationHandler.END | ||||
|  | ||||
|         print(f"User: {update.message.from_user.id}") | ||||
|         print(f"Chat: {update.message.chat_id}") | ||||
|  | ||||
|         options = [ | ||||
|             InlineKeyboardButton("Today", callback_data="today"), | ||||
| @@ -40,28 +47,36 @@ class JournalHandler: | ||||
|         await update.message.reply_text("Please choose an option for the entry:", reply_markup=keyboard) | ||||
|         return DATE_CHOICE | ||||
|  | ||||
|  | ||||
|     async def date_choice(self, update, context): | ||||
|         query = update.callback_query | ||||
|         query.answer() | ||||
|         await query.answer() | ||||
|         if query.data == "today" or query.data == "yesterday": | ||||
|             date = datetime.datetime.now().date() if query.data == "today" else datetime.datetime.now().date() - datetime.timedelta(days=1) | ||||
|             self.current_model = self.models.JournalEntry( | ||||
|             self.current_model, new = self.models.JournalEntry.get_or_create( | ||||
|                 date = date | ||||
|             ) | ||||
|             if not new: | ||||
|                 await query.edit_message_text(text="An entry already exists for this date") | ||||
|                 return ConversationHandler.END | ||||
|             await query.edit_message_text( | ||||
|                 text="Please enter the content for the entry" | ||||
|             ) | ||||
|             return CONTENT | ||||
|         else: | ||||
|             await query.edit_message_text(text="Please enter the date in the format DDMMYYYY") | ||||
|             return DATE_ENTRY | ||||
|  | ||||
|     async def date_entry(self, update, context): | ||||
|         # create an inline keyboard with the option today and yesterday and custom | ||||
|         # date | ||||
|         date = update.message.text | ||||
|         try: | ||||
|             date = datetime.datetime.strptime(date, "%d%m%Y").date() | ||||
|             self.current_model = self.models.JournalEntry( | ||||
|             self.current_model, new = self.models.JournalEntry.get_or_create( | ||||
|                 date = date | ||||
|             ) | ||||
|             if not new: | ||||
|                 await update.message.reply_text("An entry already exists for this date") | ||||
|                 return ConversationHandler.END | ||||
|         except ValueError: | ||||
|             await update.message.reply_text("Please enter the date in the format DDMMYYYY") | ||||
|             return DATE_ENTRY | ||||
| @@ -69,8 +84,26 @@ class JournalHandler: | ||||
|         await update.message.reply_text("Please enter the content for the entry") | ||||
|         return CONTENT | ||||
|  | ||||
|  | ||||
|     async def content_text(self, update, context): | ||||
|         self.current_model.text = update.message.text | ||||
|         self.current_model.author_id = update.message.from_user.id | ||||
|         self.current_model.save() | ||||
|         return ConversationHandler.END | ||||
|  | ||||
|      | ||||
|         return  | ||||
|     async def content_media(self, update, context): | ||||
|         return   | ||||
|         self.current_model.author_id = update.message.from_user.id | ||||
|  | ||||
|         if update.message.photo: | ||||
|             file = await update.message.effective_attachment[-1].get_file() | ||||
|         else: | ||||
|             file = await update.message.effective_attachment.get_file() | ||||
|          | ||||
|         file_bytes = await file.download_as_bytearray() | ||||
|         file_path = file.file_path | ||||
|         self.current_model.save_media(file_bytes, file_path) | ||||
|  | ||||
|         self.current_model.text = update.message.caption | ||||
|         self.current_model.save() | ||||
|         return ConversationHandler.END | ||||
|   | ||||
| @@ -1,5 +1,15 @@ | ||||
| from peewee import * | ||||
| from pathlib import Path | ||||
| import os | ||||
|  | ||||
| ID_MAPPINGS = { | ||||
|     "Lia": 0, | ||||
|     "Rémy": 364520272, | ||||
| } | ||||
| ID_MAPPINGS_REV = dict((v, k) for k, v in ID_MAPPINGS.items()) | ||||
|  | ||||
| MEDIA_DIR = Path(os.getenv("MEDIA_DIR")) | ||||
| MEDIA_DIR.mkdir(parents=True, exist_ok=True) | ||||
|  | ||||
| db = DatabaseProxy() | ||||
|  | ||||
| @@ -11,25 +21,38 @@ class BaseModel(Model): | ||||
|  | ||||
| # model for a single journal entry | ||||
| class JournalEntry(BaseModel): | ||||
|     # the date of the entry | ||||
|     date = DateField() | ||||
|     # the text of the entry | ||||
|     text = TextField() | ||||
|     media_path = TextField() | ||||
|     author = TextField() | ||||
|     date = DateField(unique=True) | ||||
|     author = TextField(null=True) | ||||
|     text = TextField(null=True) | ||||
|     media_path = TextField(null=True) | ||||
|  | ||||
|      | ||||
|     @property | ||||
|     def media(self): | ||||
|         return Path(self.media_path).open('rb') | ||||
|      | ||||
|     @media.setter | ||||
|     def media(self, media): | ||||
|         self.media_path = Path(media).absolute() | ||||
|     def save_media(self, media: bytearray, file_name: str): | ||||
|         ext = Path(file_name).suffix | ||||
|         file_name = f"{self.date.isoformat()}-media{ext}" | ||||
|         self.media_path = MEDIA_DIR / file_name | ||||
|         self.media_path.write_bytes(media) | ||||
|         self.save() | ||||
|  | ||||
|     @property | ||||
|     def author_id(self): | ||||
|         if self.author is None: | ||||
|             return None | ||||
|         else: | ||||
|             return ID_MAPPINGS[self.author] | ||||
|  | ||||
|     @author_id.setter | ||||
|     def author_id(self, author_id): | ||||
|         self.author = ID_MAPPINGS_REV[author_id] | ||||
|         self.save() | ||||
|  | ||||
|  | ||||
|  | ||||
| def set_db(db_path): | ||||
|     db.initialize(SqliteDatabase(db_path)) | ||||
|     db.connect() | ||||
|     db.create_tables([JournalEntry], safe=True) | ||||
|     db.create_tables([JournalEntry], safe=True) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user