-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathpayloads.py
70 lines (54 loc) · 1.6 KB
/
payloads.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
from typing import List
from pydantic import BaseModel
class CustomBaseModel(BaseModel):
@classmethod
def from_tuple(cls, tpl):
return cls(**{k: v for k, v in zip(cls.__fields__.keys(), tpl)})
@classmethod
def from_list(cls, tpl):
return cls(**{k: v for k, v in zip(cls.__fields__.keys(), tpl)})
class CrosspostRequestPayload(BaseModel):
sub: str
planned_unix_datetime: int | None = None
class RedditUserPayload(CustomBaseModel):
username: str
password: str
client_id: str
client_secret: str
class RedditUserPayloadWithCrosspostables(RedditUserPayload):
crosspostable_subs: List = []
@classmethod
def from_user_payload(
cls,
user: RedditUserPayload,
crosspostable_subs: List = [],
):
return cls(
**dict(user), crosspostable_subs=crosspostable_subs
)
class RedditUsersListPayload(BaseModel):
page: int
per_page: int
count: int
users: List[RedditUserPayload]
class RedditPostPayload(CustomBaseModel):
rowid: int | None = None
planned_unix_datetime: int | None = None
status: str | None = None
username: str
sub: str
title: str
text: str | None = None
link: str | None = None
image_name: str | None = None
video: str | None = None
flairid: str | None = None
nsfw: bool | None = False
submission_id: str | None = None
crosspost_of: int | None = None
crosspost_requests: List[CrosspostRequestPayload] = []
class RedditPostsListPayload(BaseModel):
page: int
per_page: int
count: int
users: List[RedditPostPayload]