Mercurial > libervia-web
comparison libervia/pages/lists/view/page_meta.py @ 1509:106bae41f5c8
massive refactoring from camelCase -> snake_case. See backend commit log for more details
author | Goffi <goffi@goffi.org> |
---|---|
date | Sat, 08 Apr 2023 13:44:11 +0200 |
parents | 595e7fef41f3 |
children |
comparison
equal
deleted
inserted
replaced
1508:ec3ad9abf9f9 | 1509:106bae41f5c8 |
---|---|
13 access = C.PAGES_ACCESS_PUBLIC | 13 access = C.PAGES_ACCESS_PUBLIC |
14 template = "list/overview.html" | 14 template = "list/overview.html" |
15 | 15 |
16 | 16 |
17 def parse_url(self, request): | 17 def parse_url(self, request): |
18 self.getPathArgs(request, ["service", "node"], service="jid") | 18 self.get_path_args(request, ["service", "node"], service="jid") |
19 data = self.getRData(request) | 19 data = self.get_r_data(request) |
20 service, node = data["service"], data["node"] | 20 service, node = data["service"], data["node"] |
21 if node is None: | 21 if node is None: |
22 self.HTTPRedirect(request, self.getPageByName("lists_disco").url) | 22 self.http_redirect(request, self.get_page_by_name("lists_disco").url) |
23 if node == "@": | 23 if node == "@": |
24 node = data["node"] = "" | 24 node = data["node"] = "" |
25 template_data = request.template_data | 25 template_data = request.template_data |
26 template_data["url_list_items"] = self.getURL(service.full(), node or "@") | 26 template_data["url_list_items"] = self.get_url(service.full(), node or "@") |
27 template_data["url_list_new"] = self.getPageByName("list_new").getURL( | 27 template_data["url_list_new"] = self.get_page_by_name("list_new").get_url( |
28 service.full(), node or "@") | 28 service.full(), node or "@") |
29 | 29 |
30 | 30 |
31 async def prepare_render(self, request): | 31 async def prepare_render(self, request): |
32 data = self.getRData(request) | 32 data = self.get_r_data(request) |
33 template_data = request.template_data | 33 template_data = request.template_data |
34 service, node = data["service"], data["node"] | 34 service, node = data["service"], data["node"] |
35 submitted_node = await self.host.bridgeCall( | 35 submitted_node = await self.host.bridge_call( |
36 "psSchemaSubmittedNodeGet", | 36 "ps_schema_submitted_node_get", |
37 node or self.host.ns_map["tickets"] | 37 node or self.host.ns_map["tickets"] |
38 ) | 38 ) |
39 profile = self.getProfile(request) or C.SERVICE_PROFILE | 39 profile = self.get_profile(request) or C.SERVICE_PROFILE |
40 | 40 |
41 self.checkCache(request, C.CACHE_PUBSUB, service=service, node=node, short="tickets") | 41 self.check_cache(request, C.CACHE_PUBSUB, service=service, node=node, short="tickets") |
42 | 42 |
43 try: | 43 try: |
44 lists_types = self.getPageData(request, "lists_types") | 44 lists_types = self.get_page_data(request, "lists_types") |
45 if lists_types is None: | 45 if lists_types is None: |
46 lists_types = {} | 46 lists_types = {} |
47 self.setPageData(request, "lists_types", lists_types) | 47 self.set_page_data(request, "lists_types", lists_types) |
48 list_type = lists_types[(service, node)] | 48 list_type = lists_types[(service, node)] |
49 except KeyError: | 49 except KeyError: |
50 ns_tickets_type = self.host.ns_map["tickets_type"] | 50 ns_tickets_type = self.host.ns_map["tickets_type"] |
51 schema_raw = await self.host.bridgeCall( | 51 schema_raw = await self.host.bridge_call( |
52 "psSchemaDictGet", | 52 "ps_schema_dict_get", |
53 service.full(), | 53 service.full(), |
54 submitted_node, | 54 submitted_node, |
55 profile | 55 profile |
56 ) | 56 ) |
57 schema = data_format.deserialise(schema_raw) | 57 schema = data_format.deserialise(schema_raw) |
69 list_type = list_type_field["value"].lower().strip() | 69 list_type = list_type_field["value"].lower().strip() |
70 lists_types[(service, node)] = list_type | 70 lists_types[(service, node)] = list_type |
71 | 71 |
72 data["list_type"] = template_data["list_type"] = list_type | 72 data["list_type"] = template_data["list_type"] = list_type |
73 | 73 |
74 extra = self.getPubsubExtra(request) | 74 extra = self.get_pubsub_extra(request) |
75 extra["labels_as_list"] = C.BOOL_TRUE | 75 extra["labels_as_list"] = C.BOOL_TRUE |
76 self.handleSearch(request, extra) | 76 self.handle_search(request, extra) |
77 | 77 |
78 list_raw = await self.host.bridgeCall( | 78 list_raw = await self.host.bridge_call( |
79 "listGet", | 79 "list_get", |
80 service.full() if service else "", | 80 service.full() if service else "", |
81 node, | 81 node, |
82 C.NO_LIMIT, | 82 C.NO_LIMIT, |
83 [], | 83 [], |
84 "", | 84 "", |
85 data_format.serialise(extra), | 85 data_format.serialise(extra), |
86 profile, | 86 profile, |
87 ) | 87 ) |
88 if profile != C.SERVICE_PROFILE: | 88 if profile != C.SERVICE_PROFILE: |
89 try: | 89 try: |
90 affiliations = await self.host.bridgeCall( | 90 affiliations = await self.host.bridge_call( |
91 "psNodeAffiliationsGet", | 91 "ps_node_affiliations_get", |
92 service.full() if service else "", | 92 service.full() if service else "", |
93 submitted_node, | 93 submitted_node, |
94 profile | 94 profile |
95 ) | 95 ) |
96 except BridgeException as e: | 96 except BridgeException as e: |
97 log.warning( | 97 log.warning( |
98 f"Can't get affiliations for node {submitted_node!r} at {service}: {e}" | 98 f"Can't get affiliations for node {submitted_node!r} at {service}: {e}" |
99 ) | 99 ) |
100 template_data["owner"] = False | 100 template_data["owner"] = False |
101 else: | 101 else: |
102 is_owner = affiliations.get(self.getJid(request).userhost()) == 'owner' | 102 is_owner = affiliations.get(self.get_jid(request).userhost()) == 'owner' |
103 template_data["owner"] = is_owner | 103 template_data["owner"] = is_owner |
104 if is_owner: | 104 if is_owner: |
105 self.exposeToScripts( | 105 self.expose_to_scripts( |
106 request, | 106 request, |
107 affiliations={str(e): str(a) for e, a in affiliations.items()} | 107 affiliations={str(e): str(a) for e, a in affiliations.items()} |
108 ) | 108 ) |
109 else: | 109 else: |
110 template_data["owner"] = False | 110 template_data["owner"] = False |
111 | 111 |
112 list_items, metadata = data_format.deserialise(list_raw, type_check=list) | 112 list_items, metadata = data_format.deserialise(list_raw, type_check=list) |
113 template_data["list_items"] = [ | 113 template_data["list_items"] = [ |
114 template_xmlui.create(self.host, x) for x in list_items | 114 template_xmlui.create(self.host, x) for x in list_items |
115 ] | 115 ] |
116 view_url = self.getPageByName('list_view').getURL(service.full(), node or '@') | 116 view_url = self.get_page_by_name('list_view').get_url(service.full(), node or '@') |
117 template_data["on_list_item_click"] = data_objects.OnClick( | 117 template_data["on_list_item_click"] = data_objects.OnClick( |
118 url=f"{view_url}/{{item.id}}" | 118 url=f"{view_url}/{{item.id}}" |
119 ) | 119 ) |
120 self.setPagination(request, metadata) | 120 self.set_pagination(request, metadata) |
121 self.exposeToScripts( | 121 self.expose_to_scripts( |
122 request, | 122 request, |
123 lists_ns=self.host.ns_map["tickets"], | 123 lists_ns=self.host.ns_map["tickets"], |
124 pubsub_service=service.full(), | 124 pubsub_service=service.full(), |
125 pubsub_node=node, | 125 pubsub_node=node, |
126 list_type=list_type, | 126 list_type=list_type, |
127 ) | 127 ) |
128 | 128 |
129 | 129 |
130 async def on_data_post(self, request): | 130 async def on_data_post(self, request): |
131 data = self.getRData(request) | 131 data = self.get_r_data(request) |
132 profile = self.getProfile(request) | 132 profile = self.get_profile(request) |
133 service = data["service"] | 133 service = data["service"] |
134 node = data["node"] | 134 node = data["node"] |
135 list_type = self.getPostedData(request, ("type",)) | 135 list_type = self.get_posted_data(request, ("type",)) |
136 if list_type == "grocery": | 136 if list_type == "grocery": |
137 name, quantity = self.getPostedData(request, ("name", "quantity")) | 137 name, quantity = self.get_posted_data(request, ("name", "quantity")) |
138 if not name: | 138 if not name: |
139 self.pageError(request, C.HTTP_BAD_REQUEST) | 139 self.page_error(request, C.HTTP_BAD_REQUEST) |
140 item_data = { | 140 item_data = { |
141 "name": [name], | 141 "name": [name], |
142 } | 142 } |
143 if quantity: | 143 if quantity: |
144 item_data["quantity"] = [quantity] | 144 item_data["quantity"] = [quantity] |
145 await self.host.bridgeCall( | 145 await self.host.bridge_call( |
146 "listSet", service.full(), node, item_data, "", "", "", profile | 146 "list_set", service.full(), node, item_data, "", "", "", profile |
147 ) | 147 ) |
148 return C.POST_NO_CONFIRM | 148 return C.POST_NO_CONFIRM |
149 else: | 149 else: |
150 raise NotImplementedError( | 150 raise NotImplementedError( |
151 f"Can't use quick list item set for list of type {list_type!r}" | 151 f"Can't use quick list item set for list of type {list_type!r}" |