Skip to content

Commit b3ed352

Browse files
committed
feat: Add webusage and mailusage endpoints
1 parent 55addfb commit b3ed352

File tree

2 files changed

+28
-0
lines changed

2 files changed

+28
-0
lines changed

src/opalstack/api.py

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,7 @@
2626
from .addresses import AddressesManager
2727
from .mailusers import MailusersManager
2828
from .quarantinedmails import QuarantinedmailsManager
29+
from .usage import UsageManager
2930

3031
API_URL = 'https://my.opalstack.com/api/v1'
3132

@@ -56,6 +57,7 @@ def __init__(self, token):
5657
self.sites = SitesManager(self)
5758
self.mailusers= MailusersManager(self)
5859
self.addresses = AddressesManager(self)
60+
self.usage = UsageManager(self)
5961

6062
## Not live yet ##
6163
# self.quarantinedmails = QuarantinedmailsManager(self)

src/opalstack/usage.py

Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
from .manager import ApiModelManager
2+
3+
class UsageManager(ApiModelManager):
4+
def __init__(self, api):
5+
self.model_name = 'usage'
6+
self.model_name_plural = 'usages'
7+
self.is_instantaneous = True
8+
self.primary_key = None
9+
super().__init__(api)
10+
11+
def webusage_latest(self, embed=[]):
12+
qs = ('?embed=' + ','.join(embed)) if embed else ''
13+
return self.api.http_get_result(f'/{self.model_name}/web/latest/{qs}', ensure_status=[200])
14+
15+
def mailusage_latest(self, embed=[]):
16+
qs = ('?embed=' + ','.join(embed)) if embed else ''
17+
return self.api.http_get_result(f'/{self.model_name}/mail/latest/{qs}', ensure_status=[200])
18+
19+
def check_equals(self, a, b):
20+
return ( a['id'] == b['id'] )
21+
22+
def check_obstructs(self, existing, new):
23+
return False
24+
25+
def check_satisfies(self, existing, new):
26+
return False

0 commit comments

Comments
 (0)