fastapi-basic 0.1.3__tar.gz → 0.1.5__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of fastapi-basic might be problematic. Click here for more details.

Files changed (23) hide show
  1. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/PKG-INFO +1 -1
  2. fastapi_basic-0.1.5/fastapi_basic/ext/line/__init__.py +56 -0
  3. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic.egg-info/PKG-INFO +1 -1
  4. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/setup.py +1 -1
  5. fastapi_basic-0.1.3/fastapi_basic/ext/line/__init__.py +0 -29
  6. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/README.md +0 -0
  7. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/__init__.py +0 -0
  8. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/base_config.py +0 -0
  9. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/base_factory.py +0 -0
  10. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/const.py +0 -0
  11. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/database/__init__.py +0 -0
  12. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/database/mongodb.py +0 -0
  13. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/exception/__init__.py +0 -0
  14. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/exception/base_exception.py +0 -0
  15. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/ext/__init__.py +0 -0
  16. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/ext/aws/__init__.py +0 -0
  17. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/ext/aws/const.py +0 -0
  18. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic/utils.py +0 -0
  19. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic.egg-info/SOURCES.txt +0 -0
  20. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic.egg-info/dependency_links.txt +0 -0
  21. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic.egg-info/requires.txt +0 -0
  22. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/fastapi_basic.egg-info/top_level.txt +0 -0
  23. {fastapi_basic-0.1.3 → fastapi_basic-0.1.5}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: fastapi_basic
3
- Version: 0.1.3
3
+ Version: 0.1.5
4
4
  Summary: A short description of your module
5
5
  Home-page: https://github.com/szx21023/fastapi-base
6
6
  Author: szx21023
@@ -0,0 +1,56 @@
1
+ from abc import ABCMeta, abstractmethod
2
+ import asyncio
3
+
4
+ from linebot import LineBotApi, WebhookHandler
5
+ from linebot.exceptions import LineBotApiError
6
+ from linebot.models import TextMessage, TextSendMessage, MessageEvent
7
+
8
+ from ...exception.base_exception import LineBotException
9
+
10
+ class LineBot(metaclass=ABCMeta):
11
+ def __init__(self, channel_access_token: str, channel_secret: str, logger=None):
12
+ self.channel_access_token = channel_access_token
13
+ self.channel_secret = channel_secret
14
+ self.line_bot_api = LineBotApi(self.channel_access_token)
15
+ self.handler = WebhookHandler(self.channel_secret)
16
+ self.logger = logger
17
+
18
+ self.register_handlers()
19
+
20
+ async def reply_message(self, event, text: str):
21
+ try:
22
+ self.line_bot_api.reply_message(event.reply_token, TextMessage(text=text))
23
+ message = f"Send line message successful, event: {event}, text: {text}"
24
+ self.log_message(message)
25
+
26
+ except LineBotApiError as err:
27
+ exception = LineBotException(str(err))
28
+ raise exception
29
+
30
+ async def push_message(self, line_uid: str, text: str):
31
+ try:
32
+ self.line_bot_api.push_message(line_uid, TextSendMessage(text=text))
33
+ message = f"Send line message successful, line_uid: {line_uid}, text: {text}"
34
+ self.log_message(message)
35
+
36
+ except LineBotApiError as err:
37
+ message = f"Send line message fail, line_uid: {line_uid}, text: {text}, err: {str(err)}"
38
+ exception = LineBotException(message)
39
+ raise exception
40
+
41
+ async def log_message(self, log_message: str):
42
+ if self.logger:
43
+ self.logger.info(log_message)
44
+
45
+ @abstractmethod
46
+ async def handle_message(self):
47
+ """
48
+ Each bot should define what handle_message it wants.
49
+ """
50
+
51
+ def register_handlers(self):
52
+ @self.handler.add(MessageEvent, message=TextMessage)
53
+ def handle_message(event: MessageEvent):
54
+ message = f'handle_message: {event}'
55
+ self.log_message(message)
56
+ asyncio.create_task(self.handle_message(event))
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: fastapi_basic
3
- Version: 0.1.3
3
+ Version: 0.1.5
4
4
  Summary: A short description of your module
5
5
  Home-page: https://github.com/szx21023/fastapi-base
6
6
  Author: szx21023
@@ -5,7 +5,7 @@ with open('requirements.txt', 'r') as f:
5
5
 
6
6
  setup(
7
7
  name='fastapi_basic', # 模組名稱
8
- version='0.1.3', # 版號版號
8
+ version='0.1.5', # 版號版號
9
9
  description='A short description of your module', # 模塊描述
10
10
  long_description=open('README.md').read(), # 詳細描述,通常是 README 文件的内容
11
11
  long_description_content_type='text/markdown', # markdown 格式
@@ -1,29 +0,0 @@
1
- from linebot import LineBotApi, WebhookHandler
2
- from linebot.exceptions import LineBotApiError
3
- from linebot.models import TextMessage, TextSendMessage
4
-
5
- from ...exception.base_exception import LineBotException
6
-
7
- class LineBot:
8
- def __init__(self, channel_access_token: str, channel_secret: str):
9
- self.channel_access_token = channel_access_token
10
- self.channel_secret = channel_secret
11
- self.line_bot_api = LineBotApi(self.channel_access_token)
12
- self.handler = WebhookHandler(self.channel_secret)
13
-
14
- async def reply_message(self, event, text: str):
15
- try:
16
- self.line_bot_api.reply_message(event.reply_token, TextMessage(text=text))
17
-
18
- except LineBotApiError as err:
19
- exception = LineBotException(str(err))
20
- raise exception
21
-
22
- async def push_message(self, line_uid: str, text: str):
23
- try:
24
- self.line_bot_api.push_message(line_uid, TextSendMessage(text=text))
25
-
26
- except LineBotApiError as err:
27
- message = f"Send line message fail, line_uid: {line_uid}, text: {text}, err: {str(err)}"
28
- exception = LineBotException(message)
29
- raise exception
File without changes
File without changes