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}"