dootask-tools 1.0.0__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.
- dootask_tools-1.0.0/LICENSE +21 -0
- dootask_tools-1.0.0/MANIFEST.in +7 -0
- dootask_tools-1.0.0/PKG-INFO +289 -0
- dootask_tools-1.0.0/README.md +245 -0
- dootask_tools-1.0.0/client.py +443 -0
- dootask_tools-1.0.0/dootask_tools.egg-info/PKG-INFO +289 -0
- dootask_tools-1.0.0/dootask_tools.egg-info/SOURCES.txt +14 -0
- dootask_tools-1.0.0/dootask_tools.egg-info/dependency_links.txt +1 -0
- dootask_tools-1.0.0/dootask_tools.egg-info/requires.txt +4 -0
- dootask_tools-1.0.0/dootask_tools.egg-info/top_level.txt +3 -0
- dootask_tools-1.0.0/example.py +56 -0
- dootask_tools-1.0.0/exceptions.py +27 -0
- dootask_tools-1.0.0/models.py +487 -0
- dootask_tools-1.0.0/requirements.txt +2 -0
- dootask_tools-1.0.0/setup.cfg +4 -0
- dootask_tools-1.0.0/setup.py +56 -0
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
MIT License
|
|
2
|
+
|
|
3
|
+
Copyright (c) 2024 DooTask Team
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
6
|
+
of this software and associated documentation files (the "Software"), to deal
|
|
7
|
+
in the Software without restriction, including without limitation the rights
|
|
8
|
+
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
9
|
+
copies of the Software, and to permit persons to whom the Software is
|
|
10
|
+
furnished to do so, subject to the following conditions:
|
|
11
|
+
|
|
12
|
+
The above copyright notice and this permission notice shall be included in all
|
|
13
|
+
copies or substantial portions of the Software.
|
|
14
|
+
|
|
15
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
16
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
17
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
18
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
19
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
20
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
21
|
+
SOFTWARE.
|
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
Metadata-Version: 2.4
|
|
2
|
+
Name: dootask-tools
|
|
3
|
+
Version: 1.0.0
|
|
4
|
+
Summary: DooTask Tools 客户端库
|
|
5
|
+
Home-page: https://github.com/dootask/dootask-tools
|
|
6
|
+
Author: DooTask Team
|
|
7
|
+
Author-email: support@dootask.com
|
|
8
|
+
Project-URL: Bug Reports, https://github.com/dootask/dootask-tools/issues
|
|
9
|
+
Project-URL: Source, https://github.com/dootask/dootask-tools
|
|
10
|
+
Project-URL: Documentation, https://github.com/dootask/dootask-tools#readme
|
|
11
|
+
Keywords: dootask api client chat project management collaboration
|
|
12
|
+
Classifier: Development Status :: 5 - Production/Stable
|
|
13
|
+
Classifier: Intended Audience :: Developers
|
|
14
|
+
Classifier: License :: OSI Approved :: MIT License
|
|
15
|
+
Classifier: Operating System :: OS Independent
|
|
16
|
+
Classifier: Programming Language :: Python :: 3
|
|
17
|
+
Classifier: Programming Language :: Python :: 3.7
|
|
18
|
+
Classifier: Programming Language :: Python :: 3.8
|
|
19
|
+
Classifier: Programming Language :: Python :: 3.9
|
|
20
|
+
Classifier: Programming Language :: Python :: 3.10
|
|
21
|
+
Classifier: Programming Language :: Python :: 3.11
|
|
22
|
+
Classifier: Programming Language :: Python :: 3.12
|
|
23
|
+
Classifier: Topic :: Software Development :: Libraries :: Python Modules
|
|
24
|
+
Classifier: Topic :: Communications :: Chat
|
|
25
|
+
Classifier: Topic :: Office/Business :: Groupware
|
|
26
|
+
Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content
|
|
27
|
+
Requires-Python: >=3.7
|
|
28
|
+
Description-Content-Type: text/markdown
|
|
29
|
+
License-File: LICENSE
|
|
30
|
+
Requires-Dist: requests>=2.28.0
|
|
31
|
+
Requires-Dist: dataclasses>=0.8; python_version < "3.7"
|
|
32
|
+
Dynamic: author
|
|
33
|
+
Dynamic: author-email
|
|
34
|
+
Dynamic: classifier
|
|
35
|
+
Dynamic: description
|
|
36
|
+
Dynamic: description-content-type
|
|
37
|
+
Dynamic: home-page
|
|
38
|
+
Dynamic: keywords
|
|
39
|
+
Dynamic: license-file
|
|
40
|
+
Dynamic: project-url
|
|
41
|
+
Dynamic: requires-dist
|
|
42
|
+
Dynamic: requires-python
|
|
43
|
+
Dynamic: summary
|
|
44
|
+
|
|
45
|
+
# DooTask Tools
|
|
46
|
+
|
|
47
|
+
一个用于与 DooTask 系统交互的 Python 客户端库,提供了完整的 API 封装和类型支持。
|
|
48
|
+
|
|
49
|
+
## 安装
|
|
50
|
+
|
|
51
|
+
```bash
|
|
52
|
+
pip install dootask-tools
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
## 快速开始
|
|
56
|
+
|
|
57
|
+
### 初始化客户端
|
|
58
|
+
|
|
59
|
+
```python
|
|
60
|
+
from dootask import DooTaskClient
|
|
61
|
+
|
|
62
|
+
# 创建客户端
|
|
63
|
+
client = DooTaskClient(
|
|
64
|
+
token="your_token_here",
|
|
65
|
+
server="https://your-dootask-server.com"
|
|
66
|
+
)
|
|
67
|
+
|
|
68
|
+
# 获取用户信息
|
|
69
|
+
user = client.get_user_info()
|
|
70
|
+
print(f"用户: {user.nickname}")
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
### 发送消息示例
|
|
74
|
+
|
|
75
|
+
```python
|
|
76
|
+
from dootask import SendMessageRequest, SendMessageToUserRequest
|
|
77
|
+
|
|
78
|
+
# 发送消息到指定对话
|
|
79
|
+
client.send_message(SendMessageRequest(
|
|
80
|
+
dialog_id=123,
|
|
81
|
+
text="Hello, World!",
|
|
82
|
+
text_type="md"
|
|
83
|
+
))
|
|
84
|
+
|
|
85
|
+
# 发送消息到用户
|
|
86
|
+
client.send_message_to_user(SendMessageToUserRequest(
|
|
87
|
+
userid=456,
|
|
88
|
+
text="私信内容",
|
|
89
|
+
text_type="md"
|
|
90
|
+
))
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
### 项目管理示例
|
|
94
|
+
|
|
95
|
+
```python
|
|
96
|
+
from dootask import GetProjectListRequest, CreateProjectRequest, CreateTaskRequest
|
|
97
|
+
|
|
98
|
+
# 获取项目列表
|
|
99
|
+
projects = client.get_project_list(GetProjectListRequest(
|
|
100
|
+
page=1,
|
|
101
|
+
pagesize=20
|
|
102
|
+
))
|
|
103
|
+
|
|
104
|
+
# 创建项目
|
|
105
|
+
project = client.create_project(CreateProjectRequest(
|
|
106
|
+
name="新项目",
|
|
107
|
+
desc="项目描述"
|
|
108
|
+
))
|
|
109
|
+
|
|
110
|
+
# 创建任务
|
|
111
|
+
task = client.create_task(CreateTaskRequest(
|
|
112
|
+
project_id=project.id,
|
|
113
|
+
name="新任务",
|
|
114
|
+
content="任务内容"
|
|
115
|
+
))
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
## API 方法列表
|
|
119
|
+
|
|
120
|
+
### 客户端配置
|
|
121
|
+
|
|
122
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
123
|
+
|------|------|------|--------|
|
|
124
|
+
| `DooTaskClient` | 创建客户端实例 | `token, server, timeout` | `DooTaskClient` |
|
|
125
|
+
|
|
126
|
+
### 用户相关接口
|
|
127
|
+
|
|
128
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
129
|
+
|------|------|------|--------|
|
|
130
|
+
| `get_user_info` | 获取用户信息 | `no_cache=False` | `UserInfo` |
|
|
131
|
+
| `check_user_identity` | 检查用户身份 | `identity` | `UserInfo` |
|
|
132
|
+
| `get_user_departments` | 获取用户部门信息 | - | `List[Department]` |
|
|
133
|
+
| `get_users_basic` | 获取多个用户基础信息 | `userids: List[int]` | `List[UserBasic]` |
|
|
134
|
+
| `get_user_basic` | 获取单个用户基础信息 | `userid: int` | `UserBasic` |
|
|
135
|
+
|
|
136
|
+
### 消息相关接口
|
|
137
|
+
|
|
138
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
139
|
+
|------|------|------|--------|
|
|
140
|
+
| `send_message` | 发送消息 | `SendMessageRequest` | `None` |
|
|
141
|
+
| `send_message_to_user` | 发送消息到用户 | `SendMessageToUserRequest` | `None` |
|
|
142
|
+
| `send_bot_message` | 发送机器人消息 | `SendBotMessageRequest` | `None` |
|
|
143
|
+
| `send_anonymous_message` | 发送匿名消息 | `SendAnonymousMessageRequest` | `None` |
|
|
144
|
+
|
|
145
|
+
### 对话相关接口
|
|
146
|
+
|
|
147
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
148
|
+
|------|------|------|--------|
|
|
149
|
+
| `get_dialog_list` | 获取对话列表 | `TimeRangeRequest` | `ResponsePaginate[DialogInfo]` |
|
|
150
|
+
| `search_dialog` | 搜索会话 | `SearchDialogRequest` | `List[DialogInfo]` |
|
|
151
|
+
| `get_dialog_one` | 获取单个会话信息 | `GetDialogRequest` | `DialogInfo` |
|
|
152
|
+
| `get_dialog_user` | 获取会话成员 | `GetDialogUserRequest` | `List[DialogMember]` |
|
|
153
|
+
|
|
154
|
+
### 群组相关接口
|
|
155
|
+
|
|
156
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
157
|
+
|------|------|------|--------|
|
|
158
|
+
| `create_group` | 创建群组 | `CreateGroupRequest` | `DialogInfo` |
|
|
159
|
+
| `edit_group` | 修改群组 | `EditGroupRequest` | `None` |
|
|
160
|
+
| `add_group_user` | 添加群成员 | `AddGroupUserRequest` | `None` |
|
|
161
|
+
| `remove_group_user` | 移除群成员 | `RemoveGroupUserRequest` | `None` |
|
|
162
|
+
| `exit_group` | 退出群组 | `dialog_id: int` | `None` |
|
|
163
|
+
| `transfer_group` | 转让群组 | `TransferGroupRequest` | `None` |
|
|
164
|
+
| `disband_group` | 解散群组 | `DisbandGroupRequest` | `None` |
|
|
165
|
+
|
|
166
|
+
### 项目管理相关接口
|
|
167
|
+
|
|
168
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
169
|
+
|------|------|------|--------|
|
|
170
|
+
| `get_project_list` | 获取项目列表 | `GetProjectListRequest` | `ResponsePaginate[Project]` |
|
|
171
|
+
| `get_project` | 获取项目信息 | `GetProjectRequest` | `Project` |
|
|
172
|
+
| `create_project` | 创建项目 | `CreateProjectRequest` | `Project` |
|
|
173
|
+
| `update_project` | 更新项目 | `UpdateProjectRequest` | `Project` |
|
|
174
|
+
| `exit_project` | 退出项目 | `project_id: int` | `None` |
|
|
175
|
+
| `delete_project` | 删除项目 | `project_id: int` | `None` |
|
|
176
|
+
|
|
177
|
+
### 任务列表相关接口
|
|
178
|
+
|
|
179
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
180
|
+
|------|------|------|--------|
|
|
181
|
+
| `get_column_list` | 获取任务列表 | `GetColumnListRequest` | `ResponsePaginate[ProjectColumn]` |
|
|
182
|
+
| `create_column` | 创建任务列表 | `CreateColumnRequest` | `ProjectColumn` |
|
|
183
|
+
| `update_column` | 更新任务列表 | `UpdateColumnRequest` | `ProjectColumn` |
|
|
184
|
+
| `delete_column` | 删除任务列表 | `column_id: int` | `None` |
|
|
185
|
+
|
|
186
|
+
### 任务相关接口
|
|
187
|
+
|
|
188
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
189
|
+
|------|------|------|--------|
|
|
190
|
+
| `get_task_list` | 获取任务列表 | `GetTaskListRequest` | `ResponsePaginate[ProjectTask]` |
|
|
191
|
+
| `get_task` | 获取任务信息 | `GetTaskRequest` | `ProjectTask` |
|
|
192
|
+
| `get_task_content` | 获取任务内容 | `GetTaskContentRequest` | `TaskContent` |
|
|
193
|
+
| `get_task_files` | 获取任务文件列表 | `GetTaskFilesRequest` | `List[TaskFile]` |
|
|
194
|
+
| `create_task` | 创建任务 | `CreateTaskRequest` | `ProjectTask` |
|
|
195
|
+
| `create_sub_task` | 创建子任务 | `CreateSubTaskRequest` | `ProjectTask` |
|
|
196
|
+
| `update_task` | 更新任务 | `UpdateTaskRequest` | `ProjectTask` |
|
|
197
|
+
| `create_task_dialog` | 创建任务对话 | `CreateTaskDialogRequest` | `CreateTaskDialogResponse` |
|
|
198
|
+
| `archive_task` | 归档任务 | `task_id: int, archive_type: str` | `None` |
|
|
199
|
+
| `delete_task` | 删除任务 | `task_id: int, delete_type: str` | `None` |
|
|
200
|
+
|
|
201
|
+
### 系统设置相关接口
|
|
202
|
+
|
|
203
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
204
|
+
|------|------|------|--------|
|
|
205
|
+
| `get_system_settings` | 获取系统设置 | - | `SystemSettings` |
|
|
206
|
+
| `get_version` | 获取版本信息 | - | `VersionInfo` |
|
|
207
|
+
|
|
208
|
+
## 主要数据类型
|
|
209
|
+
|
|
210
|
+
- `UserInfo` - 用户信息
|
|
211
|
+
- `UserBasic` - 用户基础信息
|
|
212
|
+
- `Department` - 部门信息
|
|
213
|
+
- `DialogInfo` - 对话信息
|
|
214
|
+
- `DialogMember` - 对话成员
|
|
215
|
+
- `Project` - 项目信息
|
|
216
|
+
- `ProjectColumn` - 项目列表
|
|
217
|
+
- `ProjectTask` - 项目任务
|
|
218
|
+
- `TaskFile` - 任务文件
|
|
219
|
+
- `TaskContent` - 任务内容
|
|
220
|
+
- `SystemSettings` - 系统设置
|
|
221
|
+
- `VersionInfo` - 版本信息
|
|
222
|
+
|
|
223
|
+
## 详细示例
|
|
224
|
+
|
|
225
|
+
```python
|
|
226
|
+
from dootask import (
|
|
227
|
+
DooTaskClient,
|
|
228
|
+
CreateProjectRequest,
|
|
229
|
+
CreateTaskRequest,
|
|
230
|
+
DooTaskException
|
|
231
|
+
)
|
|
232
|
+
|
|
233
|
+
client = DooTaskClient(
|
|
234
|
+
token="your_token",
|
|
235
|
+
server="https://your-server.com"
|
|
236
|
+
)
|
|
237
|
+
|
|
238
|
+
try:
|
|
239
|
+
# 创建项目
|
|
240
|
+
project = client.create_project(CreateProjectRequest(
|
|
241
|
+
name="我的项目",
|
|
242
|
+
desc="项目描述"
|
|
243
|
+
))
|
|
244
|
+
|
|
245
|
+
# 创建任务
|
|
246
|
+
task = client.create_task(CreateTaskRequest(
|
|
247
|
+
project_id=project.id,
|
|
248
|
+
name="任务名称",
|
|
249
|
+
content="任务内容",
|
|
250
|
+
owner=[user.userid]
|
|
251
|
+
))
|
|
252
|
+
|
|
253
|
+
print(f"项目创建成功: {project.name}")
|
|
254
|
+
print(f"任务创建成功: {task.name}")
|
|
255
|
+
|
|
256
|
+
except DooTaskException as e:
|
|
257
|
+
print(f"错误: {e}")
|
|
258
|
+
```
|
|
259
|
+
|
|
260
|
+
## 异常处理
|
|
261
|
+
|
|
262
|
+
所有方法都可能抛出异常,包含详细的错误信息:
|
|
263
|
+
|
|
264
|
+
```python
|
|
265
|
+
from dootask import (
|
|
266
|
+
DooTaskException,
|
|
267
|
+
DooTaskAPIException,
|
|
268
|
+
DooTaskHTTPException,
|
|
269
|
+
DooTaskAuthException,
|
|
270
|
+
DooTaskPermissionException
|
|
271
|
+
)
|
|
272
|
+
|
|
273
|
+
try:
|
|
274
|
+
user = client.get_user_info()
|
|
275
|
+
except DooTaskAuthException:
|
|
276
|
+
print("认证失败,请检查 token")
|
|
277
|
+
except DooTaskPermissionException:
|
|
278
|
+
print("权限不足")
|
|
279
|
+
except DooTaskAPIException as e:
|
|
280
|
+
print(f"API 错误: {e}")
|
|
281
|
+
except DooTaskHTTPException as e:
|
|
282
|
+
print(f"网络错误: {e}")
|
|
283
|
+
except DooTaskException as e:
|
|
284
|
+
print(f"其他错误: {e}")
|
|
285
|
+
```
|
|
286
|
+
|
|
287
|
+
## 许可证
|
|
288
|
+
|
|
289
|
+
MIT License
|
|
@@ -0,0 +1,245 @@
|
|
|
1
|
+
# DooTask Tools
|
|
2
|
+
|
|
3
|
+
一个用于与 DooTask 系统交互的 Python 客户端库,提供了完整的 API 封装和类型支持。
|
|
4
|
+
|
|
5
|
+
## 安装
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
pip install dootask-tools
|
|
9
|
+
```
|
|
10
|
+
|
|
11
|
+
## 快速开始
|
|
12
|
+
|
|
13
|
+
### 初始化客户端
|
|
14
|
+
|
|
15
|
+
```python
|
|
16
|
+
from dootask import DooTaskClient
|
|
17
|
+
|
|
18
|
+
# 创建客户端
|
|
19
|
+
client = DooTaskClient(
|
|
20
|
+
token="your_token_here",
|
|
21
|
+
server="https://your-dootask-server.com"
|
|
22
|
+
)
|
|
23
|
+
|
|
24
|
+
# 获取用户信息
|
|
25
|
+
user = client.get_user_info()
|
|
26
|
+
print(f"用户: {user.nickname}")
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
### 发送消息示例
|
|
30
|
+
|
|
31
|
+
```python
|
|
32
|
+
from dootask import SendMessageRequest, SendMessageToUserRequest
|
|
33
|
+
|
|
34
|
+
# 发送消息到指定对话
|
|
35
|
+
client.send_message(SendMessageRequest(
|
|
36
|
+
dialog_id=123,
|
|
37
|
+
text="Hello, World!",
|
|
38
|
+
text_type="md"
|
|
39
|
+
))
|
|
40
|
+
|
|
41
|
+
# 发送消息到用户
|
|
42
|
+
client.send_message_to_user(SendMessageToUserRequest(
|
|
43
|
+
userid=456,
|
|
44
|
+
text="私信内容",
|
|
45
|
+
text_type="md"
|
|
46
|
+
))
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
### 项目管理示例
|
|
50
|
+
|
|
51
|
+
```python
|
|
52
|
+
from dootask import GetProjectListRequest, CreateProjectRequest, CreateTaskRequest
|
|
53
|
+
|
|
54
|
+
# 获取项目列表
|
|
55
|
+
projects = client.get_project_list(GetProjectListRequest(
|
|
56
|
+
page=1,
|
|
57
|
+
pagesize=20
|
|
58
|
+
))
|
|
59
|
+
|
|
60
|
+
# 创建项目
|
|
61
|
+
project = client.create_project(CreateProjectRequest(
|
|
62
|
+
name="新项目",
|
|
63
|
+
desc="项目描述"
|
|
64
|
+
))
|
|
65
|
+
|
|
66
|
+
# 创建任务
|
|
67
|
+
task = client.create_task(CreateTaskRequest(
|
|
68
|
+
project_id=project.id,
|
|
69
|
+
name="新任务",
|
|
70
|
+
content="任务内容"
|
|
71
|
+
))
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
## API 方法列表
|
|
75
|
+
|
|
76
|
+
### 客户端配置
|
|
77
|
+
|
|
78
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
79
|
+
|------|------|------|--------|
|
|
80
|
+
| `DooTaskClient` | 创建客户端实例 | `token, server, timeout` | `DooTaskClient` |
|
|
81
|
+
|
|
82
|
+
### 用户相关接口
|
|
83
|
+
|
|
84
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
85
|
+
|------|------|------|--------|
|
|
86
|
+
| `get_user_info` | 获取用户信息 | `no_cache=False` | `UserInfo` |
|
|
87
|
+
| `check_user_identity` | 检查用户身份 | `identity` | `UserInfo` |
|
|
88
|
+
| `get_user_departments` | 获取用户部门信息 | - | `List[Department]` |
|
|
89
|
+
| `get_users_basic` | 获取多个用户基础信息 | `userids: List[int]` | `List[UserBasic]` |
|
|
90
|
+
| `get_user_basic` | 获取单个用户基础信息 | `userid: int` | `UserBasic` |
|
|
91
|
+
|
|
92
|
+
### 消息相关接口
|
|
93
|
+
|
|
94
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
95
|
+
|------|------|------|--------|
|
|
96
|
+
| `send_message` | 发送消息 | `SendMessageRequest` | `None` |
|
|
97
|
+
| `send_message_to_user` | 发送消息到用户 | `SendMessageToUserRequest` | `None` |
|
|
98
|
+
| `send_bot_message` | 发送机器人消息 | `SendBotMessageRequest` | `None` |
|
|
99
|
+
| `send_anonymous_message` | 发送匿名消息 | `SendAnonymousMessageRequest` | `None` |
|
|
100
|
+
|
|
101
|
+
### 对话相关接口
|
|
102
|
+
|
|
103
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
104
|
+
|------|------|------|--------|
|
|
105
|
+
| `get_dialog_list` | 获取对话列表 | `TimeRangeRequest` | `ResponsePaginate[DialogInfo]` |
|
|
106
|
+
| `search_dialog` | 搜索会话 | `SearchDialogRequest` | `List[DialogInfo]` |
|
|
107
|
+
| `get_dialog_one` | 获取单个会话信息 | `GetDialogRequest` | `DialogInfo` |
|
|
108
|
+
| `get_dialog_user` | 获取会话成员 | `GetDialogUserRequest` | `List[DialogMember]` |
|
|
109
|
+
|
|
110
|
+
### 群组相关接口
|
|
111
|
+
|
|
112
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
113
|
+
|------|------|------|--------|
|
|
114
|
+
| `create_group` | 创建群组 | `CreateGroupRequest` | `DialogInfo` |
|
|
115
|
+
| `edit_group` | 修改群组 | `EditGroupRequest` | `None` |
|
|
116
|
+
| `add_group_user` | 添加群成员 | `AddGroupUserRequest` | `None` |
|
|
117
|
+
| `remove_group_user` | 移除群成员 | `RemoveGroupUserRequest` | `None` |
|
|
118
|
+
| `exit_group` | 退出群组 | `dialog_id: int` | `None` |
|
|
119
|
+
| `transfer_group` | 转让群组 | `TransferGroupRequest` | `None` |
|
|
120
|
+
| `disband_group` | 解散群组 | `DisbandGroupRequest` | `None` |
|
|
121
|
+
|
|
122
|
+
### 项目管理相关接口
|
|
123
|
+
|
|
124
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
125
|
+
|------|------|------|--------|
|
|
126
|
+
| `get_project_list` | 获取项目列表 | `GetProjectListRequest` | `ResponsePaginate[Project]` |
|
|
127
|
+
| `get_project` | 获取项目信息 | `GetProjectRequest` | `Project` |
|
|
128
|
+
| `create_project` | 创建项目 | `CreateProjectRequest` | `Project` |
|
|
129
|
+
| `update_project` | 更新项目 | `UpdateProjectRequest` | `Project` |
|
|
130
|
+
| `exit_project` | 退出项目 | `project_id: int` | `None` |
|
|
131
|
+
| `delete_project` | 删除项目 | `project_id: int` | `None` |
|
|
132
|
+
|
|
133
|
+
### 任务列表相关接口
|
|
134
|
+
|
|
135
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
136
|
+
|------|------|------|--------|
|
|
137
|
+
| `get_column_list` | 获取任务列表 | `GetColumnListRequest` | `ResponsePaginate[ProjectColumn]` |
|
|
138
|
+
| `create_column` | 创建任务列表 | `CreateColumnRequest` | `ProjectColumn` |
|
|
139
|
+
| `update_column` | 更新任务列表 | `UpdateColumnRequest` | `ProjectColumn` |
|
|
140
|
+
| `delete_column` | 删除任务列表 | `column_id: int` | `None` |
|
|
141
|
+
|
|
142
|
+
### 任务相关接口
|
|
143
|
+
|
|
144
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
145
|
+
|------|------|------|--------|
|
|
146
|
+
| `get_task_list` | 获取任务列表 | `GetTaskListRequest` | `ResponsePaginate[ProjectTask]` |
|
|
147
|
+
| `get_task` | 获取任务信息 | `GetTaskRequest` | `ProjectTask` |
|
|
148
|
+
| `get_task_content` | 获取任务内容 | `GetTaskContentRequest` | `TaskContent` |
|
|
149
|
+
| `get_task_files` | 获取任务文件列表 | `GetTaskFilesRequest` | `List[TaskFile]` |
|
|
150
|
+
| `create_task` | 创建任务 | `CreateTaskRequest` | `ProjectTask` |
|
|
151
|
+
| `create_sub_task` | 创建子任务 | `CreateSubTaskRequest` | `ProjectTask` |
|
|
152
|
+
| `update_task` | 更新任务 | `UpdateTaskRequest` | `ProjectTask` |
|
|
153
|
+
| `create_task_dialog` | 创建任务对话 | `CreateTaskDialogRequest` | `CreateTaskDialogResponse` |
|
|
154
|
+
| `archive_task` | 归档任务 | `task_id: int, archive_type: str` | `None` |
|
|
155
|
+
| `delete_task` | 删除任务 | `task_id: int, delete_type: str` | `None` |
|
|
156
|
+
|
|
157
|
+
### 系统设置相关接口
|
|
158
|
+
|
|
159
|
+
| 方法 | 描述 | 参数 | 返回值 |
|
|
160
|
+
|------|------|------|--------|
|
|
161
|
+
| `get_system_settings` | 获取系统设置 | - | `SystemSettings` |
|
|
162
|
+
| `get_version` | 获取版本信息 | - | `VersionInfo` |
|
|
163
|
+
|
|
164
|
+
## 主要数据类型
|
|
165
|
+
|
|
166
|
+
- `UserInfo` - 用户信息
|
|
167
|
+
- `UserBasic` - 用户基础信息
|
|
168
|
+
- `Department` - 部门信息
|
|
169
|
+
- `DialogInfo` - 对话信息
|
|
170
|
+
- `DialogMember` - 对话成员
|
|
171
|
+
- `Project` - 项目信息
|
|
172
|
+
- `ProjectColumn` - 项目列表
|
|
173
|
+
- `ProjectTask` - 项目任务
|
|
174
|
+
- `TaskFile` - 任务文件
|
|
175
|
+
- `TaskContent` - 任务内容
|
|
176
|
+
- `SystemSettings` - 系统设置
|
|
177
|
+
- `VersionInfo` - 版本信息
|
|
178
|
+
|
|
179
|
+
## 详细示例
|
|
180
|
+
|
|
181
|
+
```python
|
|
182
|
+
from dootask import (
|
|
183
|
+
DooTaskClient,
|
|
184
|
+
CreateProjectRequest,
|
|
185
|
+
CreateTaskRequest,
|
|
186
|
+
DooTaskException
|
|
187
|
+
)
|
|
188
|
+
|
|
189
|
+
client = DooTaskClient(
|
|
190
|
+
token="your_token",
|
|
191
|
+
server="https://your-server.com"
|
|
192
|
+
)
|
|
193
|
+
|
|
194
|
+
try:
|
|
195
|
+
# 创建项目
|
|
196
|
+
project = client.create_project(CreateProjectRequest(
|
|
197
|
+
name="我的项目",
|
|
198
|
+
desc="项目描述"
|
|
199
|
+
))
|
|
200
|
+
|
|
201
|
+
# 创建任务
|
|
202
|
+
task = client.create_task(CreateTaskRequest(
|
|
203
|
+
project_id=project.id,
|
|
204
|
+
name="任务名称",
|
|
205
|
+
content="任务内容",
|
|
206
|
+
owner=[user.userid]
|
|
207
|
+
))
|
|
208
|
+
|
|
209
|
+
print(f"项目创建成功: {project.name}")
|
|
210
|
+
print(f"任务创建成功: {task.name}")
|
|
211
|
+
|
|
212
|
+
except DooTaskException as e:
|
|
213
|
+
print(f"错误: {e}")
|
|
214
|
+
```
|
|
215
|
+
|
|
216
|
+
## 异常处理
|
|
217
|
+
|
|
218
|
+
所有方法都可能抛出异常,包含详细的错误信息:
|
|
219
|
+
|
|
220
|
+
```python
|
|
221
|
+
from dootask import (
|
|
222
|
+
DooTaskException,
|
|
223
|
+
DooTaskAPIException,
|
|
224
|
+
DooTaskHTTPException,
|
|
225
|
+
DooTaskAuthException,
|
|
226
|
+
DooTaskPermissionException
|
|
227
|
+
)
|
|
228
|
+
|
|
229
|
+
try:
|
|
230
|
+
user = client.get_user_info()
|
|
231
|
+
except DooTaskAuthException:
|
|
232
|
+
print("认证失败,请检查 token")
|
|
233
|
+
except DooTaskPermissionException:
|
|
234
|
+
print("权限不足")
|
|
235
|
+
except DooTaskAPIException as e:
|
|
236
|
+
print(f"API 错误: {e}")
|
|
237
|
+
except DooTaskHTTPException as e:
|
|
238
|
+
print(f"网络错误: {e}")
|
|
239
|
+
except DooTaskException as e:
|
|
240
|
+
print(f"其他错误: {e}")
|
|
241
|
+
```
|
|
242
|
+
|
|
243
|
+
## 许可证
|
|
244
|
+
|
|
245
|
+
MIT License
|