-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
0 parents
commit 8043836
Showing
17 changed files
with
1,143 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
README-en.md linguist-language=English | ||
README.md linguist-language=Chinese |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,138 @@ | ||
# Byte-compiled / optimized / DLL files | ||
__pycache__/ | ||
*.py[cod] | ||
*$py.class | ||
|
||
# C extensions | ||
*.so | ||
|
||
# Distribution / packaging | ||
.Python | ||
build/ | ||
develop-eggs/ | ||
dist/ | ||
downloads/ | ||
eggs/ | ||
.eggs/ | ||
lib/ | ||
lib64/ | ||
parts/ | ||
sdist/ | ||
var/ | ||
wheels/ | ||
share/python-wheels/ | ||
*.egg-info/ | ||
.installed.cfg | ||
*.egg | ||
MANIFEST | ||
|
||
# PyInstaller | ||
# Usually these files are written by a python script from a template | ||
# before PyInstaller builds the exe, so as to inject date/other infos into it. | ||
*.manifest | ||
*.spec | ||
|
||
# Installer logs | ||
pip-log.txt | ||
pip-delete-this-directory.txt | ||
|
||
# Unit test / coverage reports | ||
htmlcov/ | ||
.tox/ | ||
.nox/ | ||
.coverage | ||
.coverage.* | ||
.cache | ||
nosetests.xml | ||
coverage.xml | ||
*.cover | ||
*.py,cover | ||
.hypothesis/ | ||
.pytest_cache/ | ||
cover/ | ||
|
||
# Translations | ||
*.mo | ||
*.pot | ||
|
||
# Django stuff: | ||
*.log | ||
local_settings.py | ||
db.sqlite3 | ||
db.sqlite3-journal | ||
|
||
# Flask stuff: | ||
instance/ | ||
.webassets-cache | ||
|
||
# Scrapy stuff: | ||
.scrapy | ||
|
||
# Sphinx documentation | ||
docs/_build/ | ||
|
||
# PyBuilder | ||
.pybuilder/ | ||
target/ | ||
|
||
# Jupyter Notebook | ||
.ipynb_checkpoints | ||
|
||
# IPython | ||
profile_default/ | ||
ipython_config.py | ||
|
||
# pyenv | ||
# For a library or package, you might want to ignore these files since the code is | ||
# intended to run in multiple environments; otherwise, check them in: | ||
# .python-version | ||
|
||
# pipenv | ||
# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. | ||
# However, in case of collaboration, if having platform-specific dependencies or dependencies | ||
# having no cross-platform support, pipenv may install dependencies that don't work, or not | ||
# install all needed dependencies. | ||
#Pipfile.lock | ||
|
||
# PEP 582; used by e.g. github.com/David-OConnor/pyflow | ||
__pypackages__/ | ||
|
||
# Celery stuff | ||
celerybeat-schedule | ||
celerybeat.pid | ||
|
||
# SageMath parsed files | ||
*.sage.py | ||
|
||
# Environments | ||
.env | ||
.venv | ||
env/ | ||
venv/ | ||
ENV/ | ||
env.bak/ | ||
venv.bak/ | ||
|
||
# Spyder project settings | ||
.spyderproject | ||
.spyproject | ||
|
||
# Rope project settings | ||
.ropeproject | ||
|
||
# mkdocs documentation | ||
/site | ||
|
||
# mypy | ||
.mypy_cache/ | ||
.dmypy.json | ||
dmypy.json | ||
|
||
# Pyre type checker | ||
.pyre/ | ||
|
||
# pytype static type analyzer | ||
.pytype/ | ||
|
||
# Cython debug symbols | ||
cython_debug/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,21 @@ | ||
MIT License | ||
|
||
Copyright (c) 2023 Shiki@Z | ||
|
||
Permission is hereby granted, free of charge, to any person obtaining a copy | ||
of this software and associated documentation files (the "Software"), to deal | ||
in the Software without restriction, including without limitation the rights | ||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||
copies of the Software, and to permit persons to whom the Software is | ||
furnished to do so, subject to the following conditions: | ||
|
||
The above copyright notice and this permission notice shall be included in all | ||
copies or substantial portions of the Software. | ||
|
||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||
SOFTWARE. |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,188 @@ | ||
# InspectionLite | ||
InspectionLite is a Python project used to detect updates on specified web pages. It can automatically detect updates on the specified page based on the user-defined task list and push update notifications to specified users. | ||
|
||
# Features | ||
- **Supports multiple notification methods**: This program supports multiple notification methods, such as QQ bot based on Mirai HTTP, SMTP emails, etc., to meet the different needs of users. | ||
- **Customizable tasks**: InspectionLite supports reading the task list from the configuration file. Users can add new detection tasks according to their needs. | ||
- **Easy to extend**: The program adopts a modular design, and users can easily write new notification methods and register them in the system. | ||
- **High degree of customization**: Users can configure parameters according to their own needs, such as modifying database connection information, task lists, notification methods, etc. | ||
- **High reliability**: The program runs stably and reliably, and can promptly send emails to administrators in case of abnormal situations. | ||
|
||
# Installation | ||
1. Clone the repository to your local machine. | ||
2. Enter the project directory. | ||
3. Install dependencies: `pip install -r requirements.txt` | ||
4. Configure program parameters: edit the configuration file in the `/conf` directory and modify parameter values as needed. | ||
5. Run the program: `python main.py`. | ||
|
||
# Usage Examples | ||
<details> | ||
<summary>1. Modify the conf/push.py file</summary> | ||
|
||
```python | ||
push_setting = { | ||
# The administrator's email address. If there are any notification errors during runtime, they will be sent to this email address. | ||
'admin': { | ||
'email': '[email protected]' | ||
}, | ||
# Fill in the parameters for the Mirai notification protocol here. | ||
# If you don't need Mirai notification, leave it blank. | ||
# Note: This project defaults to using Mirai HTTP protocol for notification. | ||
'mirai': { | ||
'host': 'mirai.host.com:port', | ||
'verify_key': 'Mirai HTTP verify key', | ||
# Fill in the sender's QQ number here. The sender must have logged in to Mirai Console. | ||
'sender': 10000 | ||
}, | ||
# Fill in the parameters for the SMTP (email) notification protocol here. | ||
# This is required because messages will be sent via email in case of notification errors. | ||
'smtp': { | ||
'host': 'smtp.example.com', | ||
'port': 465, | ||
'username': '[email protected]', | ||
'password': 'example password' | ||
} | ||
} | ||
``` | ||
|
||
</details> | ||
|
||
<details> | ||
<summary>2. Modify the conf/sql.py file</summary> | ||
|
||
```python | ||
# The project uses a MySQL database, so fill in the login parameters for the database here. | ||
# Note: The database user must have read/write permission for the database. | ||
sql_setting = { | ||
'host': 'database address', | ||
'user': 'database username', | ||
'password': 'database password', | ||
'db': 'database to use' | ||
} | ||
``` | ||
|
||
</details> | ||
|
||
<details> | ||
<summary>3. Modify the conf/subscribers.py file</summary> | ||
|
||
```python | ||
subscribers = [ | ||
# User 1 | ||
{ | ||
# If subscribing to all notifications, set range to True; | ||
# If subscribing to some notifications, write them as a list here; | ||
# If subscribing to no notifications, set range to False (or delete this user). | ||
'range': True, | ||
'mirai': { | ||
# Enable Mirai notification by setting enable to True. | ||
# If not using Mirai notification, ignore id and is_group. | ||
'enable': True, | ||
'id': 10001, | ||
'is_group': False, | ||
}, | ||
'smtp': { | ||
# Enable SMTP (email) notification by setting enable to True. | ||
# If not using SMTP notification, ignore email. | ||
'enable': True, | ||
'email': '[email protected]' | ||
} | ||
}, | ||
# User 2 | ||
{ | ||
'range': ['CSP notifications'], | ||
'mirai': { | ||
'enable': True, | ||
'id': 20001, | ||
'is_group': True, | ||
}, | ||
'smtp': { | ||
'enable': False | ||
} | ||
} | ||
] | ||
``` | ||
|
||
</details> | ||
|
||
<details> | ||
<summary>4. Modify the conf/tasks.py file</summary> | ||
|
||
```python | ||
task_list = [ | ||
'CSP notifications', | ||
'NJ Tech Academic Affairs Office', | ||
# Add your tasks here. | ||
# The following two functions are the main process of the task. Please read the examples carefully and fill in the same format. | ||
] | ||
|
||
|
||
def get_task_url(task_name: str) -> str: | ||
""" | ||
Get the URL of the specified task. | ||
|
||
:param task_name: Task name | ||
:return: URL | ||
""" | ||
if task_name == task_list[0]: | ||
jump_request = task_url_parse('https://www.cspro.org/cms/show.action?code=jumpchanneltemplate') | ||
return urljoin('https://www.cspro.org', findall('\".*\"', jump_request.script.text)[1].strip('\"')) | ||
elif task_name == task_list[1]: | ||
return 'http://jwc.njtech.edu.cn/' | ||
|
||
|
||
def get_task_css(task_name: str) -> str: | ||
""" | ||
Get the CSS selector of the specified task. | ||
|
||
:param task_name: Task name | ||
:return: CSS selector | ||
""" | ||
if task_name == task_list[0]: | ||
return 'body > div.l_mainouter > div > div:nth-child(1) > div.l_newsmsg.clearfix > div.l_overflowhidden > ' \ | ||
'span > a ' | ||
elif task_name == task_list[1]: | ||
return '#notice > div.ct > ul > li > p > a' | ||
``` | ||
|
||
</details> | ||
|
||
<details> | ||
<summary>(Optional) 5. Add your own notification method under the push directory</summary> | ||
|
||
```python | ||
# To implement your own notification method, you must inherit the push.base.PushBase class. | ||
# Then, you only need to implement the _send_update method. | ||
from push.base import PushBase | ||
|
||
|
||
class MyPush(PushBase): | ||
def _send_update(self, | ||
task: str, | ||
title: str, | ||
url: str, | ||
subscriber: dict) -> bool: | ||
# Implement your notification method here. | ||
# Suppose you use mypush.py as your file name here: | ||
# 1. Put the global parameters you need to use in push_setting['mypush'] in conf/push.py (if necessary); | ||
# 2. Put individual parameters for each user in subscribers[index]['mypush'] in conf/subscribers.py. | ||
pass | ||
``` | ||
|
||
</details> | ||
|
||
# Technical Details | ||
### The InspectionLite project mainly consists of the following modules: | ||
|
||
- `main.py`: Program entry point, responsible for creating database connections and task units. | ||
- `/conf` directory: Stores the program's configuration files, such as MySQL connection information, notification methods, and task lists. | ||
- `/core` directory: Stores the core code of the program, such as task detection, data storage, and notification function implementations. | ||
- `/push` directory: Stores specific implementations of different notification methods. | ||
|
||
### The workflow of InspectionLite is as follows: | ||
|
||
- Obtain the Web page URL and CSS selector to be detected based on the task list. | ||
- Detect the update status of the Web page, and if an update occurs, save the update record to the MySQL database. | ||
- Use multiple notification methods to send update notifications to specified users. | ||
- If a notification failure occurs, retry and email the administrator with details if the retry fails. | ||
- The entire program runs on the main program and can automatically perform task detection and notification operations. |
Oops, something went wrong.