src/server/plugins/postgresql/webdav.c

Mon, 26 May 2025 21:13:11 +0200

author
Olaf Wintermann <olaf.wintermann@gmail.com>
date
Mon, 26 May 2025 21:13:11 +0200
changeset 584
f3ddd6dc8e7b
parent 579
e10457d74fe1
permissions
-rw-r--r--

remove ucx utils.h includes

299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1 /*
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
3 *
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
4 * Copyright 2022 Olaf Wintermann. All rights reserved.
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
5 *
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
6 * Redistribution and use in source and binary forms, with or without
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
7 * modification, are permitted provided that the following conditions are met:
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
8 *
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
9 * 1. Redistributions of source code must retain the above copyright
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
10 * notice, this list of conditions and the following disclaimer.
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
11 *
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
12 * 2. Redistributions in binary form must reproduce the above copyright
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
13 * notice, this list of conditions and the following disclaimer in the
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
14 * documentation and/or other materials provided with the distribution.
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
15 *
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
26 * POSSIBILITY OF SUCH DAMAGE.
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
27 */
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
28
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
29 #include "webdav.h"
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
30 #include "vfs.h"
366
47bc686fafe4 add new dav config element
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 356
diff changeset
31 #include "config.h"
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
32
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
33 #include "../../util/util.h"
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
34 #include "../../util/pblock.h"
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
35
348
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
36 #include "../../daemon/http.h" // etag
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
37
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
38 #include <cx/buffer.h>
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
39 #include <cx/printf.h>
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
40 #include <libxml/tree.h>
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
41
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
42
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
43 static WebdavBackend pg_webdav_backend = {
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
44 pg_dav_propfind_init,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
45 pg_dav_propfind_do,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
46 pg_dav_propfind_finish,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
47 pg_dav_proppatch_do,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
48 pg_dav_proppatch_finish,
479
2a42ba73ecdd add new xattr based webdav backend (unimplemented)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 415
diff changeset
49 NULL, // opt_mkcol
2a42ba73ecdd add new xattr based webdav backend (unimplemented)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 415
diff changeset
50 NULL, // opt_mkcol_finish
2a42ba73ecdd add new xattr based webdav backend (unimplemented)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 415
diff changeset
51 NULL, // opt_delete
2a42ba73ecdd add new xattr based webdav backend (unimplemented)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 415
diff changeset
52 NULL, // opt_delete_finish
2a42ba73ecdd add new xattr based webdav backend (unimplemented)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 415
diff changeset
53 0, // settings
303
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
54 NULL,
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
55 NULL
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
56 };
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
57
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
58
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
59
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
60 /*
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
61 * SQL query components
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
62 */
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
63
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
64 /*
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
65 * PROPFIND queries are build from components:
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
66 *
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
67 * cte cte_recursive or empty
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
68 * select
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
69 * ppath ppath column
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
70 * cols list of columns
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
71 * ext_cols* list of extension columns
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
72 * from from [table] / from cte
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
73 * prop_join join with property table, allprop or plist
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
74 * ext_join* extension table join
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
75 * where different where clauses for depth0 and depth1
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
76 * order depth0 doesn't need order
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
77 */
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
78
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
79 static const char *sql_propfind_cte_recursive = "\
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
80 with recursive resolvepath as (\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
81 select\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
82 '' as ppath,\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
83 *\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
84 from Resource\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
85 where resource_id = $1 \n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
86 union\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
87 select\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
88 p.ppath || '/' || r.nodename,\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
89 r.*\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
90 from Resource r\n\
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
91 inner join resolvepath p on r.parent_id = p.resource_id\n\
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
92 )\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
93
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
94 static const char *sql_propfind_select = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
95 select\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
96
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
97 static const char *sql_propfind_ppath_depth0 = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
98 $2::text as ppath,\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
99
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
100 static const char *sql_propfind_ppath_depth1 = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
101 case when r.resource_id = $1 then $2\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
102 else $2 || '/' || r.nodename\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
103 end as ppath,\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
104
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
105 static const char *sql_propfind_ppath_depth_infinity = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
106 case when r.resource_id = $1 then $2\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
107 else $2 || r.ppath\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
108 end as ppath,\n";
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
109
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
110 static const char *sql_propfind_cols = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
111 r.resource_id,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
112 r.parent_id,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
113 r.nodename,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
114 r.iscollection,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
115 r.lastmodified,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
116 r.creationdate,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
117 r.contentlength,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
118 r.etag,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
119 p.prefix,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
120 p.xmlns,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
121 p.pname,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
122 p.lang,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
123 p.nsdeflist,\n\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
124 p.pvalue\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
125
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
126 static const char *sql_propfind_from_table = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
127 from Resource r\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
128
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
129 static const char *sql_propfind_from_cte = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
130 from resolvepath r\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
131
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
132 static const char *sql_propfind_propjoin_allprop = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
133 left join Property p on r.resource_id = p.resource_id\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
134
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
135 static const char *sql_propfind_propjoin_plist = "\
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
136 left join (\n\
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
137 select p.* from Property p\
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
138 inner join (select unnest($3::text[]) as xmlns, unnest($4::text[]) as pname) n\n\
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
139 on p.xmlns = n.xmlns and p.pname = n.pname\n\
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
140 ) p on r.resource_id = p.resource_id\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
141
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
142 static const char *sql_propfind_where_depth0 = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
143 where r.resource_id = $1\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
144
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
145 static const char *sql_propfind_where_depth1 = "\
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
146 where r.resource_id = $1 or r.parent_id = $1\n";
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
147
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
148 static const char *sql_propfind_order_depth1 = "\
401
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
149 order by case when r.resource_id = $1 then 0 else 1 end, r.nodename, r.resource_id";
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
150
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
151 static const char *sql_propfind_order_depth_infinity = "\
401
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
152 order by replace(ppath, '/', chr(1)), r.resource_id";
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
153
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
154 /*
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
155 * SQL Queries
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
156 */
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
157
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
158
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
159 // proppatch: set property
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
160 // params: $1: resource_id
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
161 // $2: xmlns prefix
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
162 // $3: xmlns href
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
163 // $4: property name
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
164 // $5: lang attribute value
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
165 // $6: namespace list string
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
166 // $7: property value
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
167 static const char *sql_proppatch_set = "\
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
168 insert into Property(resource_id, prefix, xmlns, pname, lang, nsdeflist, pvalue)\n\
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
169 values($1, $2, $3, $4, $5, $6, $7)\n\
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
170 on conflict (resource_id, xmlns, pname) do\n\
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
171 update set prefix=$2, lang=$5, nsdeflist=$6, pvalue=$7;";
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
172
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
173 // proppatch: remove property
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
174 // params: $1: resource_id
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
175 // $2: xmlns href
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
176 // $3: property name
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
177 static const char *sql_proppatch_remove = "\
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
178 delete from Property where resource_id = $1 and xmlns = $2 and pname = $3";
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
179
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
180
366
47bc686fafe4 add new dav config element
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 356
diff changeset
181 void* pg_webdav_init(ServerConfiguration *cfg, pool_handle_t *pool, WSConfigNode *config) {
372
1d2538a1ba8f add config option for pg root node lookup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 370
diff changeset
182 return pg_init_repo(cfg, pool, config);
366
47bc686fafe4 add new dav config element
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 356
diff changeset
183 }
47bc686fafe4 add new dav config element
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 356
diff changeset
184
47bc686fafe4 add new dav config element
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 356
diff changeset
185 WebdavBackend* pg_webdav_create(Session *sn, Request *rq, pblock *pb, void *initData) {
370
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
186 PgRepository *repo = initData;
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
187
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
188 char *resource_pool;
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
189 if(repo) {
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
190 resource_pool = repo->resourcepool.ptr;
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
191 } else {
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
192 // resourcepool is required
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
193 resource_pool = pblock_findval("resourcepool", pb);
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
194 if(!resource_pool) {
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
195 log_ereport(LOG_MISCONFIG, "pg_webdav_create: missing resourcepool parameter");
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
196 return NULL;
d6d8c86c95c3 adjust pg plugin to new dav initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 366
diff changeset
197 }
303
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
198 }
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
199
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
200 // get the resource first (should only fail in case of misconfig)
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
201 ResourceData *resdata = resourcepool_lookup(sn, rq, resource_pool, 0);
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
202 if(!resdata) {
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
203 log_ereport(LOG_MISCONFIG, "postgresql webdav: resource pool %s not found", resource_pool);
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
204 return NULL;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
205 }
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
206
374
77506ec632a4 use configured root node from PgRepository in pg vfs/webdav
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 372
diff changeset
207 return pg_webdav_create_from_resdata(sn, rq, repo, resdata);
303
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
208 }
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
209
374
77506ec632a4 use configured root node from PgRepository in pg vfs/webdav
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 372
diff changeset
210 WebdavBackend* pg_webdav_create_from_resdata(Session *sn, Request *rq, PgRepository *repo, ResourceData *resdata) {
303
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
211 WebdavBackend *webdav = pool_malloc(sn->pool, sizeof(WebdavBackend));
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
212 if(!webdav) {
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
213 return NULL;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
214 }
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
215 *webdav = pg_webdav_backend;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
216
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
217 PgWebdavBackend *instance = pool_malloc(sn->pool, sizeof(PgWebdavBackend));
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
218 if(!instance) {
303
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
219 pool_free(sn->pool, webdav);
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
220 return NULL;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
221 }
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
222 webdav->instance = instance;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
223
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
224 instance->pg_resource = resdata;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
225 instance->connection = resdata->data;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
226
374
77506ec632a4 use configured root node from PgRepository in pg vfs/webdav
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 372
diff changeset
227 instance->repository = repo;
77506ec632a4 use configured root node from PgRepository in pg vfs/webdav
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 372
diff changeset
228 snprintf(instance->root_resource_id_str, 32, "%" PRId64, repo->root_resource_id);
77506ec632a4 use configured root node from PgRepository in pg vfs/webdav
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 372
diff changeset
229
303
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
230 return webdav;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
231 }
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
232
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
233 WebdavBackend* pg_webdav_prop_create(Session *sn, Request *rq, pblock *pb) {
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
234 return NULL;
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
235 }
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
236
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
237 /*
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
238 * adds str to the buffer
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
239 * some characters will be escaped: \,{}
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
240 */
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
241 static void buf_addstr_escaped(CxBuffer *buf, const char *str) {
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
242 size_t len = strlen(str);
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
243 for(size_t i=0;i<len;i++) {
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
244 char c = str[i];
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
245 if(c == '{' || c == '}' || c == ',' || c == '\\') {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
246 cxBufferPut(buf, '\\');
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
247 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
248 cxBufferPut(buf, c);
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
249 }
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
250 }
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
251
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
252 /*
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
253 * convert a property list to two pg array parameter strings
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
254 * array format: {elm1,elm2,elm3}
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
255 * xmlns: buffer for the xmlns array
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
256 * pname: buffer for the property name array
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
257 *
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
258 * returns 0 on success, 1 otherwise
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
259 */
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
260 int pg_create_property_param_arrays(WebdavPList *plist, CxBuffer *xmlns, CxBuffer *pname) {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
261 cxBufferPut(xmlns, '{');
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
262 cxBufferPut(pname, '{');
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
263 while(plist) {
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
264 WebdavProperty *property = plist->property;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
265 if(property && property->namespace && property->namespace->href && property->name) {
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
266 buf_addstr_escaped(xmlns, (const char*)property->namespace->href);
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
267 buf_addstr_escaped(pname, (const char*)property->name);
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
268 if(plist->next) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
269 cxBufferPut(xmlns, ',');
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
270 cxBufferPut(pname, ',');
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
271 }
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
272 }
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
273 plist = plist->next;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
274 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
275 int r1 = cxBufferWrite("}\0", 2, 1, xmlns) == 0;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
276 int r2 = cxBufferWrite("}\0", 2, 1, pname) == 0;
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
277 return r1+r2 != 0;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
278 }
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
279
303
ad9ba51c8634 add pg webdav backend initialization
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 300
diff changeset
280
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
281 static int propfind_ext_cmp(const void *f1, const void *f2) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
282 const PgPropfindExtCol *e1 = f1;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
283 const PgPropfindExtCol *e2 = f2;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
284
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
285 if(e1->ext->tableindex != e2->ext->tableindex) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
286 return e1->ext->tableindex < e2->ext->tableindex ? -1 : 1;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
287 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
288
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
289 return 0;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
290 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
291
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
292
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
293 static int pg_create_propfind_query(
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
294 WebdavPropfindRequest *rq,
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
295 WSBool iscollection,
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
296 PgPropfindExtCol *ext,
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
297 size_t numext,
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
298 CxBuffer *sql)
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
299 {
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
300 PgWebdavBackend *pgdav = rq->dav->instance;
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
301 PgRepository *repo = pgdav->repository;
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
302 int depth = !iscollection ? 0 : rq->depth;
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
303
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
304 /*
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
305 * PROPFIND queries are build from components:
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
306 *
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
307 * cte cte_recursive or empty
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
308 * select
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
309 * ppath ppath column
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
310 * cols list of columns
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
311 * ext_cols* list of extension columns
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
312 * from from [table] / from cte
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
313 * prop_join join with property table, allprop or plist
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
314 * ext_join* extension table join
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
315 * where different where clauses for depth0 and depth1
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
316 * order depth0 doesn't need order
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
317 */
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
318
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
319 // CTE
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
320 if(depth == -1) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
321 cxBufferPutString(sql, sql_propfind_cte_recursive);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
322 }
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
323
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
324 // select
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
325 cxBufferPutString(sql, sql_propfind_select);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
326
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
327 // ppath
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
328 switch(depth) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
329 case 0: cxBufferPutString(sql, sql_propfind_ppath_depth0); break;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
330 case 1: cxBufferPutString(sql, sql_propfind_ppath_depth1); break;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
331 case -1: cxBufferPutString(sql, sql_propfind_ppath_depth_infinity); break;
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
332 }
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
333
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
334 // cols
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
335 cxBufferPutString(sql, sql_propfind_cols);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
336
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
337 // ext_cols
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
338 if(ext) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
339 if(rq->allprop) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
340 for(int i=0;i<repo->ntables;i++) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
341 cx_bprintf(sql, ",x%d.*\n", i);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
342 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
343 } else {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
344 for(int i=0;i<numext;i++) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
345 PgPropfindExtCol e = ext[i];
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
346 cx_bprintf(sql, ",x%d.%s\n", e.ext->tableindex, e.ext->column);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
347 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
348 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
349 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
350
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
351 // from
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
352 cxBufferPutString(sql, depth == -1 ? sql_propfind_from_cte : sql_propfind_from_table);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
353
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
354 // prop join
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
355 cxBufferPutString(sql, rq->allprop ? sql_propfind_propjoin_allprop : sql_propfind_propjoin_plist);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
356
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
357 // ext_join
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
358 if(ext) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
359 if(rq->allprop) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
360 for(int i=0;i<repo->ntables;i++) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
361 cx_bprintf(sql, "left join %s x%d on r.resource_id = x%d.resource_id\n", repo->tables[i].table, i, i);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
362 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
363 } else {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
364 int tab = -1;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
365 for(int i=0;i<numext;i++) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
366 PgPropfindExtCol e = ext[i];
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
367 if(e.ext->tableindex != tab) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
368 tab = e.ext->tableindex;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
369 cx_bprintf(sql, "left join %s x%d on r.resource_id = x%d.resource_id\n", repo->tables[tab].table, tab, tab);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
370 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
371 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
372 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
373
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
374 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
375
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
376 // where
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
377 if(depth == 0) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
378 cxBufferPutString(sql, sql_propfind_where_depth0);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
379 } else if(depth == 1) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
380 cxBufferPutString(sql, sql_propfind_where_depth1);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
381 }
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
382
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
383 // order
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
384 if(depth == 1) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
385 cxBufferPutString(sql, sql_propfind_order_depth1);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
386 } else if(depth == -1) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
387 cxBufferPutString(sql, sql_propfind_order_depth_infinity);
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
388 }
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
389
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
390 // end
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
391 cxBufferWrite(";\0", 1, 2, sql);
401
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
392
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
393 return 0;
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
394 }
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
395
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
396 int pg_dav_propfind_init(
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
397 WebdavPropfindRequest *rq,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
398 const char *path,
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
399 const char *href,
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
400 WebdavPList **outplist)
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
401 {
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
402 PgWebdavBackend *pgdav = rq->dav->instance;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
403 CxAllocator *a = pool_allocator(rq->sn->pool);
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
404
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
405 // first, check if the resource exists
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
406 // if it doesn't exist, we can return immediately
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
407 int64_t parent_id;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
408 int64_t resource_id;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
409 const char *resourcename;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
410 WSBool iscollection;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
411 int res_errno = 0;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
412 int err = pg_resolve_path(
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
413 pgdav->connection,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
414 path,
374
77506ec632a4 use configured root node from PgRepository in pg vfs/webdav
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 372
diff changeset
415 pgdav->root_resource_id_str,
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
416 &parent_id,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
417 &resource_id,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
418 NULL, // OID
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
419 &resourcename,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
420 &iscollection,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
421 NULL, // stat
346
784b24381bed extend postgresql vfs to store an etag in the file
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 331
diff changeset
422 NULL, // etag
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
423 &res_errno);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
424
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
425 if(err) {
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
426 if(res_errno == ENOENT) {
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
427 protocol_status(rq->sn, rq->rq, PROTOCOL_NOT_FOUND, NULL);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
428 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
429 return 1;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
430 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
431
380
0f85d9bde309 pg propfind stores resource_id in rq->vars
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 378
diff changeset
432 // store resource_id in rq->vars, maybe some other modules
0f85d9bde309 pg propfind stores resource_id in rq->vars
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 378
diff changeset
433 // like to use it
0f85d9bde309 pg propfind stores resource_id in rq->vars
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 378
diff changeset
434 char resource_id_str[32];
0f85d9bde309 pg propfind stores resource_id in rq->vars
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 378
diff changeset
435 snprintf(resource_id_str, 32, "%" PRId64, resource_id);
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
436 pblock_nvinsert("resource_id", resource_id_str, rq->rq->vars);
380
0f85d9bde309 pg propfind stores resource_id in rq->vars
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 378
diff changeset
437
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
438 // create a list of requsted extended properties
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
439 PgPropfindExtCol *ext;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
440 size_t numext;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
441 if(pgdav->repository->ntables == 0) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
442 // no property extensions configured
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
443 ext = NULL;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
444 numext = 0;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
445 } else {
579
e10457d74fe1 update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 564
diff changeset
446 numext = cxMapSize(pgdav->repository->prop_ext);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
447 ext = pool_calloc(rq->sn->pool, numext, sizeof(PgPropfindExtCol));
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
448
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
449 if(rq->allprop) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
450 // the map pgdav->repository->prop_ext contains all property extensions
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
451 // we can just convert the map to an array
579
e10457d74fe1 update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 564
diff changeset
452 CxMapIterator i = cxMapIteratorValues(pgdav->repository->prop_ext);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
453 int j = 0;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
454 cx_foreach(PgPropertyStoreExt *, cfg_ext, i) {
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
455 PgPropfindExtCol extcol;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
456 extcol.ext = cfg_ext;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
457 extcol.field_num = -1; // get the field_num after the PQexec
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
458 ext[j++] = extcol;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
459 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
460 } else {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
461 WebdavPListIterator i = webdav_plist_iterator(outplist);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
462 WebdavPList *cur;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
463 int j = 0;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
464 while(webdav_plist_iterator_next(&i, &cur)) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
465 WSNamespace *ns = cur->property->namespace;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
466 if(ns) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
467 CxHashKey pkey = webdav_property_key((const char*)ns->href, cur->property->name);
490
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
468 if(!pkey.data) {
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
469 return 1;
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
470 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
471 PgPropertyStoreExt *cfg_ext = cxMapGet(pgdav->repository->prop_ext, pkey);
490
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
472 free((void*)pkey.data);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
473 if(cfg_ext) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
474 PgPropfindExtCol extcol;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
475 extcol.ext = cfg_ext;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
476 extcol.field_num = -1; // get the field_num after the PQexec
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
477 ext[j++] = extcol;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
478
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
479 webdav_plist_iterator_remove_current(&i);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
480 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
481 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
482 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
483 numext = j;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
484 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
485
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
486 qsort(ext, numext, sizeof(PgPropfindExtCol), propfind_ext_cmp);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
487 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
488
375
32b8017f5308 build pg propfind query from components
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 374
diff changeset
489 // create sql query
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
490 const char *query = NULL;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
491 CxBuffer sql;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
492 if(cxBufferInit(&sql, NULL, 2048, a, CX_BUFFER_AUTO_EXTEND|CX_BUFFER_FREE_CONTENTS)) {
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
493 return 1;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
494 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
495
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
496 if(pg_create_propfind_query(rq, iscollection, ext, numext, &sql)) {
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
497 cxBufferDestroy(&sql);
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
498 return 1;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
499 }
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
500 query = sql.space;
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
501 log_ereport(LOG_DEBUG, "pg_dav_propfind_init query: %.*s\n", (int)sql.size, sql.space);
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
502
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
503 // get all resources and properties
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
504 size_t href_len = strlen(href);
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
505 char *href_param = pool_malloc(rq->sn->pool, href_len + 1);
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
506 memcpy(href_param, href, href_len);
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
507 if(href_param[href_len-1] == '/') {
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
508 href_len--;
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
509 }
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
510 href_param[href_len] = '\0';
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
511
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
512 // if allprop is false, create array pair for xmlns/property names
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
513 CxBuffer xmlns_buf;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
514 CxBuffer pname_buf;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
515 WSBool buf_initialized = FALSE;
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
516 char *xmlns_param = NULL;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
517 char *pname_param = NULL;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
518 int nparam = 2;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
519 if(!rq->allprop) {
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
520 size_t bufsize = rq->propcount < 200 ? 8 + rq->propcount * 32 : 4096;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
521 if(cxBufferInit(&xmlns_buf, NULL, bufsize, a, CX_BUFFER_AUTO_EXTEND|CX_BUFFER_FREE_CONTENTS)) {
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
522 return 1;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
523 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
524 if(cxBufferInit(&pname_buf, NULL, bufsize, a, CX_BUFFER_AUTO_EXTEND|CX_BUFFER_FREE_CONTENTS)) {
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
525 cxBufferDestroy(&sql);
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
526 cxBufferDestroy(&xmlns_buf);
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
527 return 1;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
528 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
529 if(pg_create_property_param_arrays(*outplist, &xmlns_buf, &pname_buf)) {
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
530 cxBufferDestroy(&sql);
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
531 cxBufferDestroy(&xmlns_buf);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
532 cxBufferDestroy(&pname_buf);
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
533 return 1;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
534 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
535 buf_initialized = TRUE;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
536 xmlns_param = xmlns_buf.space;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
537 pname_param = pname_buf.space;
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
538 nparam = 4;
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
539 }
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
540
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
541
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
542
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
543 const char* params[4] = { resource_id_str, href_param, xmlns_param, pname_param };
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
544 PGresult *result = PQexecParams(
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
545 pgdav->connection,
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
546 query,
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
547 nparam, // number of parameters
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
548 NULL,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
549 params, // parameter value
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
550 NULL,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
551 NULL,
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
552 0); // 0: result in text format
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
553 int nrows = PQntuples(result);
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
554 pool_free(rq->sn->pool, href_param);
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
555 cxBufferDestroy(&sql);
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
556 if(buf_initialized) {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
557 cxBufferDestroy(&xmlns_buf);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
558 cxBufferDestroy(&pname_buf);
315
b608b7aa43a6 fix sql query for selecting specific properties
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 314
diff changeset
559 }
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
560 if(nrows < 1) {
401
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
561 // we resolved the path, so the resource exists and nrows should
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
562 // be >= 1
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
563 if(PQresultStatus(result) != PGRES_TUPLES_OK) {
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
564 log_ereport(LOG_FAILURE, "pg_dav_propfind_init: %s", PQerrorMessage(pgdav->connection));
d2bfd11d3f8f fix invalid propfind pg queries created for allprop requests on collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 384
diff changeset
565 }
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
566 PQclear(result);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
567 return 1;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
568 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
569
300
0e3f275b2492 add instance field to webdav backend struct
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 299
diff changeset
570 PgPropfind *pg = pool_malloc(rq->sn->pool, sizeof(PgPropfind));
0e3f275b2492 add instance field to webdav backend struct
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 299
diff changeset
571 rq->userdata = pg;
0e3f275b2492 add instance field to webdav backend struct
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 299
diff changeset
572
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
573 pg->path = path;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
574 pg->resource_id = resource_id;
331
ab26980faad6 implement allprop in default and postgresql webdav backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 324
diff changeset
575 pg->vfsproperties = webdav_vfs_properties(outplist, TRUE, rq->allprop, 0);
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
576 pg->result = result;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
577 pg->nrows = nrows;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
578
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
579 pg->ext = ext;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
580 pg->numext = numext;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
581 if(ext) {
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
582 // build a map of all ext field names (excluding first fields from
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
583 // the resource and property table)
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
584 int nfields = PQnfields(result);
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
585 CxMap *fieldmap = cxHashMapCreate(pool_allocator(rq->sn->pool), sizeof(int), nfields);
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
586 if(!fieldmap) {
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
587 PQclear(result);
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
588 return 1;
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
589 }
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
590 // start with index 15 (see pg_dav_propfind_do for first column nums)
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
591 for(int i=15;i<nfields;i++) {
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
592 char *name = PQfname(result, i);
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
593 if(name) {
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
594 if(cxMapPut(fieldmap, name, &i)) {
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
595 PQclear(result);
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
596 return 1;
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
597 }
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
598 }
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
599 }
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
600
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
601 // get field_nums for all property extensions
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
602 for(int i=0;i<numext;i++) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
603 PgPropfindExtCol *c = &ext[i];
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
604 //c->field_num = PQfnumber(result, c->ext->column);
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
605 int *fieldnum = cxMapGet(fieldmap, c->ext->column);
564
f19fd264c69c fix wrong column name usage by pg prop extensions
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 562
diff changeset
606 if(fieldnum) {
f19fd264c69c fix wrong column name usage by pg prop extensions
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 562
diff changeset
607 c->field_num = *fieldnum;
f19fd264c69c fix wrong column name usage by pg prop extensions
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 562
diff changeset
608 }
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
609 }
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
610
579
e10457d74fe1 update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 564
diff changeset
611 cxMapFree(fieldmap);
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
612 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
613
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
614 return 0;
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
615 }
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
616
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
617 int pg_dav_propfind_do(
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
618 WebdavPropfindRequest *rq,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
619 WebdavResponse *response,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
620 VFS_DIR parent,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
621 WebdavResource *resource,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
622 struct stat *s)
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
623 {
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
624 PgPropfind *pg = rq->userdata;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
625 pool_handle_t *pool = rq->sn->pool;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
626 PGresult *result = pg->result;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
627 WebdavVFSProperties vfsprops = pg->vfsproperties;
378
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
628
313
3ad0b65ec838 test pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 312
diff changeset
629 WSBool vfsprops_set = 0; // are live properties added to the response?
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
630 WSBool extprops_set = 0; // are extended properties added to the response?
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
631 int64_t current_resource_id = pg->resource_id;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
632 for(int r=0;r<pg->nrows;r++) {
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
633 // columns:
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
634 // 0: path
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
635 // 1: resource_id
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
636 // 2: parent_id
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
637 // 3: nodename
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
638 // 4: iscollection
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
639 // 5: lastmodified
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
640 // 6: creationdate
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
641 // 7: contentlength
348
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
642 // 8: etag
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
643 // 9: property prefix
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
644 // 10: property xmlns
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
645 // 11: property name
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
646 // 12: property lang
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
647 // 13: property nsdeflist
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
648 // 14: property value
562
69fc4ecc5f60 fix pgext uses a wrong field number, if the column has the same name as a resource or property column
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 553
diff changeset
649
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
650 char *path = PQgetvalue(result, r, 0);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
651 char *res_id = PQgetvalue(result, r, 1);
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
652 char *iscollection_str = PQgetvalue(result, r, 4);
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
653 WSBool iscollection = iscollection_str && iscollection_str[0] == 't';
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
654 int64_t resource_id;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
655 if(!util_strtoint(res_id, &resource_id)) {
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
656 log_ereport(LOG_FAILURE, "pg_dav_propfind_do: cannot convert resource_id '%s' to int", res_id);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
657 return 1;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
658 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
659
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
660 if(resource_id != current_resource_id) {
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
661 // create a href string for the new resource
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
662 // if the resource is a collection, it should have a trailing '/'
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
663 size_t pathlen = strlen(path);
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
664 if(pathlen == 0) {
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
665 log_ereport(LOG_FAILURE, "pg_dav_propfind_do: query returned invalid path");
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
666 return 1;
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
667 }
356
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
668 if(pathlen > PG_MAX_PATH_LEN) {
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
669 log_ereport(LOG_FAILURE, "pg_dav_propfind_do: path too long: resource_id: %s", res_id);
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
670 return 1;
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
671 }
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
672 char *newres_href = pool_malloc(pool, (pathlen*3)+2);
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
673 util_uri_escape(newres_href, path);
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
674 if(iscollection && path[pathlen-1] != '/') {
356
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
675 size_t newres_href_len = strlen(newres_href);
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
676 newres_href[newres_href_len] = '/';
eebc3d32c7c1 escape child href in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 348
diff changeset
677 newres_href[newres_href_len+1] = '\0';
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
678 }
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
679
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
680 // new resource
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
681 resource = response->addresource(response, newres_href);
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
682 vfsprops_set = FALSE;
378
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
683 extprops_set = FALSE;
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
684 current_resource_id = resource_id;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
685 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
686
313
3ad0b65ec838 test pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 312
diff changeset
687 // standard webdav live properties
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
688 if(!vfsprops_set) {
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
689 if(vfsprops.getresourcetype) {
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
690 if(iscollection) {
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
691 resource->addproperty(resource, webdav_resourcetype_collection(), 200);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
692 } else {
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
693 resource->addproperty(resource, webdav_resourcetype_empty(), 200);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
694 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
695 }
348
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
696
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
697 char *lastmodified = PQgetvalue(result, r, 5);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
698 char *contentlength = PQgetvalue(result, r, 7);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
699 time_t t = pg_convert_timestamp(lastmodified);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
700
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
701 if(vfsprops.getlastmodified) {
311
e676ed461b5b implement pg getlastmodified propfind (and prepare creationdate)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 309
diff changeset
702 struct tm tm;
e676ed461b5b implement pg getlastmodified propfind (and prepare creationdate)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 309
diff changeset
703 gmtime_r(&t, &tm);
e676ed461b5b implement pg getlastmodified propfind (and prepare creationdate)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 309
diff changeset
704
e676ed461b5b implement pg getlastmodified propfind (and prepare creationdate)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 309
diff changeset
705 char buf[HTTP_DATE_LEN+1];
e676ed461b5b implement pg getlastmodified propfind (and prepare creationdate)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 309
diff changeset
706 strftime(buf, HTTP_DATE_LEN, HTTP_DATE_FMT, &tm);
314
6b1a6066ee43 fix pg propfind for getlastmodified property
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 313
diff changeset
707 webdav_resource_add_dav_stringproperty(resource, pool, "getlastmodified", buf, strlen(buf));
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
708 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
709 if(vfsprops.creationdate) {
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
710 char *creationdate = PQgetvalue(result, r, 6);
311
e676ed461b5b implement pg getlastmodified propfind (and prepare creationdate)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 309
diff changeset
711 webdav_resource_add_dav_stringproperty(resource, pool, "creationdate", creationdate, strlen(creationdate));
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
712 }
314
6b1a6066ee43 fix pg propfind for getlastmodified property
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 313
diff changeset
713 if(vfsprops.getcontentlength && !iscollection) {
309
fc021bd576d4 implement pg getcontentlength property
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 307
diff changeset
714 webdav_resource_add_dav_stringproperty(resource, pool, "getcontentlength", contentlength, strlen(contentlength));
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
715 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
716 if(vfsprops.getetag) {
348
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
717 char *etag = PQgetvalue(result, r, 8);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
718 if(!PQgetisnull(result, r, 8)) {
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
719 webdav_resource_add_dav_stringproperty(resource, pool, "getetag", etag, strlen(etag));
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
720 } else {
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
721 int64_t ctlen;
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
722 if(util_strtoint(contentlength, &ctlen)) {
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
723 char etag[MAX_ETAG];
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
724 http_format_etag(rq->sn, rq->rq, etag, MAX_ETAG, ctlen, t);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
725 webdav_resource_add_dav_stringproperty(resource, pool, "getetag", etag, strlen(etag));
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
726 }
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
727 }
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
728 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
729
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
730 vfsprops_set = TRUE;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
731 }
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
732
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
733 if(!extprops_set) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
734 // extended properties
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
735 if(pg->ext) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
736 for(int extc=0;extc<pg->numext;extc++) {
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
737 PgPropfindExtCol ext = pg->ext[extc];
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
738 int fieldnum = ext.field_num;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
739
564
f19fd264c69c fix wrong column name usage by pg prop extensions
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 562
diff changeset
740 if(fieldnum >= 0 && !PQgetisnull(result, r, fieldnum)) {
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
741 char *ext_value = PQgetvalue(result, r, fieldnum);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
742 int ext_value_len = PQgetlength(result, r, fieldnum);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
743 char ext_xmlns_prefix[32];
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
744 snprintf(ext_xmlns_prefix, 32, "x%d", ext.ext->tableindex);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
745
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
746 WebdavProperty *property = pool_malloc(pool, sizeof(WebdavProperty));
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
747 property->lang = NULL;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
748 property->name = pool_strdup(pool, ext.ext->name);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
749
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
750 xmlNs *namespace = pool_malloc(pool, sizeof(xmlNs));
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
751 memset(namespace, 0, sizeof(struct _xmlNs));
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
752 namespace->href = (xmlChar*)pool_strdup(pool, ext.ext->ns);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
753 namespace->prefix = (xmlChar*)pool_strdup(pool, ext_xmlns_prefix);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
754 property->namespace = namespace;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
755
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
756 char *content = pool_malloc(pool, ext_value_len+1);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
757 memcpy(content, ext_value, ext_value_len);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
758 content[ext_value_len] = '\0';
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
759
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
760 WebdavNSList *nslist = pool_malloc(pool, sizeof(WebdavNSList));
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
761 nslist->namespace = namespace;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
762 nslist->prev = NULL;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
763 nslist->next = NULL;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
764
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
765 property->vtype = WS_VALUE_XML_DATA;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
766 property->value.data.data = content;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
767 property->value.data.length = ext_value_len;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
768 property->value.data.namespaces = nslist;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
769
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
770 resource->addproperty(resource, property, 200);
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
771 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
772 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
773 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
774
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
775 extprops_set = TRUE;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
776 }
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
777
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
778 // dead properties
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
779 if(!PQgetisnull(result, r, 9)) {
348
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
780 char *prefix = PQgetvalue(result, r, 9);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
781 char *xmlns = PQgetvalue(result, r, 10);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
782 char *pname = PQgetvalue(result, r, 11);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
783 char *lang = PQgetvalue(result, r, 12);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
784 char *nsdef = PQgetvalue(result, r, 13);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
785 char *pvalue = PQgetvalue(result, r, 14);
317
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
786
348
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
787 int pvalue_len = PQgetlength(result, r, 14);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
788 WSBool lang_isnull = PQgetisnull(result, r, 12);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
789 WSBool nsdef_isnull = PQgetisnull(result, r, 13);
bdd31584141f implement etag in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 346
diff changeset
790 WSBool pvalue_isnull = PQgetisnull(result, r, 14);
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
791
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
792 WebdavProperty *property = pool_malloc(pool, sizeof(WebdavProperty));
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
793 property->lang = NULL;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
794 property->name = pool_strdup(pool, pname);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
795
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
796 xmlNs *namespace = pool_malloc(pool, sizeof(xmlNs));
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
797 memset(namespace, 0, sizeof(struct _xmlNs));
307
8787cb5ebab3 fix href in pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 306
diff changeset
798 namespace->href = (xmlChar*)pool_strdup(pool, xmlns);
317
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
799 namespace->prefix = (xmlChar*)pool_strdup(pool, prefix);
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
800 property->namespace = namespace;
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
801
317
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
802 if(!lang_isnull) {
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
803 property->lang = pool_strdup(pool, lang);
317
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
804 }
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
805
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
806 if(!pvalue_isnull) {
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
807 char *content = pool_malloc(pool, pvalue_len+1);
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
808 memcpy(content, pvalue, pvalue_len);
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
809 content[pvalue_len] = '\0';
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
810
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
811 if(nsdef_isnull) {
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
812 property->vtype = WS_VALUE_TEXT;
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
813 property->value.text.str = content;
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
814 property->value.text.length = pvalue_len;
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
815 } else {
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
816 WebdavNSList *nslist = wsxml_string2nslist(pool, nsdef);
324
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
817 property->vtype = WS_VALUE_XML_DATA;
376
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
818 property->value.data.data = content;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
819 property->value.data.length = pvalue_len;
61d481d3c2e4 Add support for extended properties in pg propfind
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 375
diff changeset
820 property->value.data.namespaces = nslist;
324
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
821
317
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
822 }
09676b559091 store property prefix in the database
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 315
diff changeset
823 }
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
824
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
825 resource->addproperty(resource, property, 200);
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
826 }
313
3ad0b65ec838 test pg propfind response
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 312
diff changeset
827 }
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
828
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
829 return 0;
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
830 }
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
831
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
832 int pg_dav_propfind_finish(WebdavPropfindRequest *rq) {
312
f7544e220a0f add pg propfind cleanup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 311
diff changeset
833 PgPropfind *pg = rq->userdata;
f7544e220a0f add pg propfind cleanup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 311
diff changeset
834 pool_handle_t *pool = rq->sn->pool;
f7544e220a0f add pg propfind cleanup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 311
diff changeset
835 PGresult *result = pg->result;
f7544e220a0f add pg propfind cleanup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 311
diff changeset
836
f7544e220a0f add pg propfind cleanup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 311
diff changeset
837 PQclear(result);
f7544e220a0f add pg propfind cleanup
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 311
diff changeset
838
306
e03737cea6e2 add semi functional pg propfind handler
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 303
diff changeset
839 return 0;
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
840 }
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
841
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
842 enum PgDavProp {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
843 PG_DAV_PROPPATCH_NOT_ALLOWED = 0,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
844 PG_DAV_CREATIONDATE,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
845 PG_DAV_DISPLAYNAME,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
846 PG_DAV_DEADPROP
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
847 };
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
848 /*
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
849 * checks if the property can be manipulated
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
850 */
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
851 static enum PgDavProp proppatch_check_dav_prop(const char *name) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
852 if(!strcmp(name, "getlastmodified")) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
853 return PG_DAV_PROPPATCH_NOT_ALLOWED;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
854 } else if(!strcmp(name, "getcontentlength")) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
855 return PG_DAV_PROPPATCH_NOT_ALLOWED;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
856 } else if(!strcmp(name, "resourcetype")) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
857 return PG_DAV_PROPPATCH_NOT_ALLOWED;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
858 } else if(!strcmp(name, "getetag")) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
859 return PG_DAV_PROPPATCH_NOT_ALLOWED;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
860 } else if(!strcmp(name, "creationdate")) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
861 return PG_DAV_CREATIONDATE;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
862 } else if(!strcmp(name, "displayname")) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
863 return PG_DAV_DISPLAYNAME;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
864 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
865 return PG_DAV_DEADPROP;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
866 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
867
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
868 typedef struct {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
869 WebdavProperty *creationdate;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
870 WebdavProperty *displayname;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
871 int error;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
872 } PgProppatchOpResult;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
873
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
874 typedef int(*pg_proppatch_func)(PgWebdavBackend*, WebdavProppatchRequest*, WebdavResource*, WebdavProperty*, void*);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
875
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
876 /*
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
877 * This function iterates the property list 'plist',
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
878 * analyses if any DAV: property is in the list
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
879 * and calls opfunc for the each property
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
880 *
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
881 * If the property list contains the properties creationdate or displayname,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
882 * the pointers to these properties will be stored in the result structure
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
883 */
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
884 static PgProppatchOpResult pg_proppatch_op(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
885 PgWebdavBackend *pgdav,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
886 WebdavProppatchRequest *request,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
887 WebdavResource *response,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
888 WebdavPList **plist,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
889 enum PgDavProp forbidden_extra,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
890 pg_proppatch_func opfunc,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
891 void *op_userdata)
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
892 {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
893 PgProppatchOpResult result;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
894 result.creationdate = NULL;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
895 result.displayname = NULL;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
896 result.error = 0;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
897
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
898 WebdavPListIterator i = webdav_plist_iterator(plist);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
899 WebdavPList *cur;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
900 while(webdav_plist_iterator_next(&i, &cur)) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
901 WebdavProperty *property = cur->property;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
902 WSNamespace *ns = property->namespace;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
903 if(!ns) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
904 continue; // maybe we should abort
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
905 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
906
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
907 // check if the property is a DAV: property that requires special
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
908 // handling
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
909 // get* properties can't be manipulated
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
910 // some properties can't be removed
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
911 if(!strcmp((const char*)ns->href, "DAV:")) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
912 const char *name = property->name;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
913 enum PgDavProp davprop = proppatch_check_dav_prop(name);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
914 if(davprop != PG_DAV_DEADPROP) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
915 if(davprop == PG_DAV_PROPPATCH_NOT_ALLOWED || davprop == forbidden_extra) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
916 response->addproperty(response, property, 409);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
917 } else if(davprop == PG_DAV_CREATIONDATE) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
918 result.creationdate = property;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
919 } else if(davprop == PG_DAV_DISPLAYNAME) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
920 result.displayname = property;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
921 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
922 webdav_plist_iterator_remove_current(&i);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
923 continue;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
924 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
925 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
926
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
927 // call op func (set, remove specific code)
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
928 if(opfunc(pgdav, request, response, property, op_userdata)) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
929 result.error = 1;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
930 break;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
931 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
932
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
933 webdav_plist_iterator_remove_current(&i);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
934 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
935
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
936 return result;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
937 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
938
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
939
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
940 static PgPropertyStoreExt* pg_proppatch_prop_get_ext(PgWebdavBackend *pgdav, WebdavProperty *property) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
941 CxHashKey pkey = webdav_property_key((const char*)property->namespace->href, property->name);
490
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
942 if(!pkey.data) {
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
943 return NULL;
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
944 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
945 PgPropertyStoreExt *ext = cxMapGet(pgdav->repository->prop_ext, pkey);
490
d218607f5a7e update ucx
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 479
diff changeset
946 free((void*)pkey.data);
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
947 return ext;
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
948 }
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
949
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
950 #define PG_PROPPATCH_EXT_SET 0
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
951 #define PG_PROPPATCH_EXT_REMOVE 1
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
952
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
953 static int pg_proppatch_add_ext_prop(
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
954 pool_handle_t *pool,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
955 PgWebdavBackend *pgdav,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
956 PgProppatch *proppatch,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
957 WebdavProperty *property,
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
958 PgPropertyStoreExt *ext,
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
959 int proppatch_op)
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
960 {
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
961 PgProppatchExtProp *ext_prop = pool_malloc(pool, sizeof(PgProppatchExtProp));
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
962 if(!ext_prop) {
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
963 return 1;
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
964 }
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
965 ext_prop->column = ext;
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
966 ext_prop->property = property;
553
a166a15f7b74 fix pg ext uninitialized memory acces - fixes #420
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 490
diff changeset
967 ext_prop->next = NULL;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
968
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
969 CxAllocator *a = pool_allocator(pool);
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
970 proppatch->ext[ext->tableindex].isused = TRUE;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
971
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
972 PgProppatchExtProp **list_begin;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
973 PgProppatchExtProp **list_end;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
974 if(proppatch_op == PG_PROPPATCH_EXT_SET) {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
975 list_begin = &proppatch->ext[ext->tableindex].set_begin;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
976 list_end = &proppatch->ext[ext->tableindex].set_end;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
977 } else {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
978 list_begin = &proppatch->ext[ext->tableindex].remove_begin;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
979 list_end = &proppatch->ext[ext->tableindex].remove_end;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
980 }
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
981
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
982 cx_linked_list_add((void**)list_begin, (void**)list_end, -1, offsetof(PgProppatchExtProp, next), ext_prop);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
983
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
984 proppatch->extensions_used = TRUE;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
985
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
986 return 0;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
987 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
988
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
989 static int pg_dav_set_property(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
990 PgWebdavBackend *pgdav,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
991 WebdavProppatchRequest *request,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
992 WebdavResource *response,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
993 WebdavProperty *property,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
994 void *userdata)
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
995 {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
996 pool_handle_t *pool = request->sn->pool;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
997 PgProppatch *proppatch = request->userdata;
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
998 WSNamespace *ns = property->namespace;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
999
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1000 // check if the property belongs to an extension
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1001 if(proppatch->ext && ns) {
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1002 PgPropertyStoreExt *ext = pg_proppatch_prop_get_ext(pgdav, property);
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1003 if(ext) {
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1004 return pg_proppatch_add_ext_prop(pool, pgdav, proppatch, property, ext, PG_PROPPATCH_EXT_SET);
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1005 } // else: property is not stored in an extension table, continue with normal property store
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1006 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1007
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1008 char *resource_id_str = userdata;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1009 int ret = 0;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1010
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1011 // convert the property value to WSXmlData
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1012 // property->vtype == WS_VALUE_XML_NODE should always be true
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1013 WSXmlData *property_value = property->vtype == WS_VALUE_XML_NODE ? wsxml_node2data(pool, property->value.node) : NULL;
324
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1014 char *value_str = NULL;
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1015 char *nsdef_str = NULL;
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1016 if(property_value) {
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1017 value_str = property_value->data;
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1018 if(property_value->namespaces) {
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1019 nsdef_str = wsxml_nslist2string(pool, property_value->namespaces);
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1020 if(!nsdef_str) {
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1021 return 1; // OOM
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1022 }
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1023 }
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1024 }
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1025
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1026 // exec sql
324
44cf877b3d9f add support for xml properties in propfind/proppatch requests (pg)
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 318
diff changeset
1027 const char* params[7] = { resource_id_str, (const char*)ns->prefix, (const char*)ns->href, property->name, NULL, nsdef_str, value_str};
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1028 PGresult *result = PQexecParams(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1029 pgdav->connection,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1030 sql_proppatch_set,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1031 7, // number of parameters
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1032 NULL,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1033 params, // parameter value
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1034 NULL,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1035 NULL,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1036 0); // 0: result in text format
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1037
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1038 if(PQresultStatus(result) != PGRES_COMMAND_OK) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1039 response->addproperty(response, property, 500);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1040 //printf(PQerrorMessage(pgdav->connection));
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1041 //fflush(stdout);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1042 ret = 1;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1043 } else {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1044 response->addproperty(response, property, 200);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1045 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1046 PQclear(result);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1047 if(value_str) pool_free(pool, value_str);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1048
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1049 return ret;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1050 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1051
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1052
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1053 static int pg_dav_remove_property(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1054 PgWebdavBackend *pgdav,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1055 WebdavProppatchRequest *request,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1056 WebdavResource *response,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1057 WebdavProperty *property,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1058 void *userdata)
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1059 {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1060 pool_handle_t *pool = request->sn->pool;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1061 PgProppatch *proppatch = request->userdata;
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1062 WSNamespace *ns = property->namespace;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1063
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1064 // check if the property belongs to an extension
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1065 if(proppatch->ext && ns) {
402
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1066 PgPropertyStoreExt *ext = pg_proppatch_prop_get_ext(pgdav, property);
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1067 if(ext) {
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1068 return pg_proppatch_add_ext_prop(pool, pgdav, proppatch, property, ext, PG_PROPPATCH_EXT_REMOVE);
712aca08da7f pg: fix proppatch not working for normal dead properties if extensions are enabled
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 401
diff changeset
1069 } // else: property is not stored in an extension table, continue with normal property store
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1070 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1071
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1072 char *resource_id_str = userdata;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1073 int ret = 0;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1074
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1075 // exec sql
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1076 const char* params[3] = { resource_id_str, (const char*)ns->href, property->name };
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1077 PGresult *result = PQexecParams(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1078 pgdav->connection,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1079 sql_proppatch_remove,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1080 3, // number of parameters
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1081 NULL,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1082 params, // parameter value
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1083 NULL,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1084 NULL,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1085 0); // 0: result in text format
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1086
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1087 if(PQresultStatus(result) != PGRES_COMMAND_OK) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1088 response->addproperty(response, property, 500);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1089 //printf(PQerrorMessage(pgdav->connection));
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1090 //fflush(stdout);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1091 ret = 1;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1092 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1093 PQclear(result);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1094
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1095 return ret;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1096 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1097
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1098
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1099 /*
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1100 * Creates an SQL query for inserting a new row to an extension table
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1101 * A parameter list for PQexecParams will also be generated, however
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1102 * params[0] will be empty (resource_id str)
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1103 *
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1104 * Query: insert into <table> (resource_id, col1, ...) values ($1, $2 ...);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1105 */
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1106 static CxBuffer* ext_row_create_insert_query(WebdavProppatchRequest *request, PgProppatchExt *ext, PgExtTable *table, char *** params, size_t *nparams) {
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1107 pool_handle_t *pool = request->sn->pool;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1108
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1109 CxBuffer *sql = pool_malloc(pool, sizeof(CxBuffer));
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1110 if(!sql) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1111 return NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1112 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1113 if(cxBufferInit(sql, NULL, 1024, pool_allocator(pool), CX_BUFFER_AUTO_EXTEND|CX_BUFFER_FREE_CONTENTS)) {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1114 pool_free(pool, sql);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1115 return NULL;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1116 }
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1117
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1118 size_t pg_nparams = cx_linked_list_size(ext->set_begin, offsetof(PgProppatchExtProp, next)) + 1;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1119 char** pg_params = pool_calloc(pool, pg_nparams, sizeof(char*));
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1120 if(!pg_params) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1121 cxBufferDestroy(sql);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1122 pool_free(pool, sql);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1123 return NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1124 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1125
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1126 cxBufferPutString(sql, "insert into ");
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1127 cxBufferPutString(sql, table->table);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1128 cxBufferPutString(sql, "(resource_id");
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1129 for(PgProppatchExtProp *prop=ext->set_begin;prop;prop=prop->next) {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1130 cx_bprintf(sql, ",%s", prop->column->name);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1131 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1132
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1133 cxBufferPutString(sql, ") values ($1\n");
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1134 int i = 1;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1135 for(PgProppatchExtProp *prop=ext->set_begin;prop;prop=prop->next) {
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1136 WebdavProperty *property = prop->property;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1137 // convert the property value to WSXmlData
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1138 // property->vtype == WS_VALUE_XML_NODE should always be true
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1139 WSXmlData *property_value = property->vtype == WS_VALUE_XML_NODE ? wsxml_node2data(pool, property->value.node) : NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1140 char *value_str = NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1141 //char *nsdef_str = NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1142 if(property_value) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1143 value_str = property_value->data;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1144 if(property_value->namespaces) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1145 // currently only text data is supported
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1146 pool_free(pool, params);
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1147 cxBufferDestroy(sql);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1148 return NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1149 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1150 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1151
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1152 pg_params[i] = value_str;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1153 cx_bprintf(sql, ",$%d", ++i);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1154 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1155 cxBufferPutString(sql, ");");
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1156
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1157
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1158 //printf("\n\n%.*s\n\n", (int)sql->size, sql->space);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1159 //fflush(stdout);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1160
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1161 *params = pg_params;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1162 *nparams = pg_nparams;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1163
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1164 return sql;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1165 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1166
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1167 /*
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1168 * Creates an SQL query for updating an extension table row
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1169 * A parameter list for PQexecParams will also be generated, however
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1170 * params[0] will be empty (resource_id str)
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1171 *
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1172 * Query: update <table> set
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1173 * col1 = $2,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1174 * col2 = $3,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1175 * ...
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1176 * where resource_id = $1 ;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1177 */
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1178 static CxBuffer* ext_row_create_update_query(WebdavProppatchRequest *request, PgProppatchExt *ext, PgExtTable *table, char *** params, size_t *nparams) {
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1179 pool_handle_t *pool = request->sn->pool;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1180
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1181 CxBuffer *sql = pool_malloc(pool, sizeof(CxBuffer));
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1182 if(!sql) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1183 return NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1184 }
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1185 if(cxBufferInit(sql, NULL, 1024, pool_allocator(pool), CX_BUFFER_AUTO_EXTEND|CX_BUFFER_FREE_CONTENTS)) {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1186 pool_free(pool, sql);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1187 return NULL;
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1188 }
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1189
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1190 cxBufferPutString(sql, "update ");
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1191 cxBufferPutString(sql, table->table);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1192 cxBufferPutString(sql, " set\n");
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1193
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1194 size_t pg_nparams = cx_linked_list_size(ext->set_begin, offsetof(PgProppatchExtProp, next)) + 1;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1195 char** pg_params = pool_calloc(pool, pg_nparams, sizeof(char*));
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1196 if(!pg_params) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1197 cxBufferDestroy(sql);
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1198 pool_free(pool, sql);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1199 return NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1200 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1201
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1202 int i = 1;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1203 for(PgProppatchExtProp *prop=ext->set_begin;prop;prop=prop->next) {
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1204 WebdavProperty *property = prop->property;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1205 // convert the property value to WSXmlData
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1206 // property->vtype == WS_VALUE_XML_NODE should always be true
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1207 WSXmlData *property_value = property->vtype == WS_VALUE_XML_NODE ? wsxml_node2data(pool, property->value.node) : NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1208 char *value_str = NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1209 //char *nsdef_str = NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1210 if(property_value) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1211 value_str = property_value->data;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1212 if(property_value->namespaces) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1213 // currently only text data is supported
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1214 pool_free(pool, params);
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1215 cxBufferDestroy(sql);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1216 return NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1217 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1218 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1219
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1220 pg_params[i] = value_str;
564
f19fd264c69c fix wrong column name usage by pg prop extensions
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 562
diff changeset
1221 cx_bprintf(sql, " %s = $%d,\n", prop->column->column, ++i);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1222 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1223
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1224 for(PgProppatchExtProp *prop=ext->remove_begin;prop;prop=prop->next) {
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1225 cx_bprintf(sql, " %s = NULL,\n", prop->column->name);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1226 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1227
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1228 // check if any write worked
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1229 if(sql->pos == 0) {
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1230 cxBufferDestroy(sql);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1231 pool_free(pool, pg_params);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1232 return NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1233 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1234
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1235 // last line should end with ',' '\n'
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1236 // replace ',' with space
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1237 if(sql->space[sql->pos-2] == ',') {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1238 sql->space[sql->pos-2] = ' ';
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1239 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1240
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1241 cxBufferPutString(sql, "where resource_id = $1 ;");
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1242 cxBufferPut(sql, '\0');
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1243
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1244 //printf("\n\n%.*s\n\n", (int)sql->size, sql->space);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1245 //fflush(stdout);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1246
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1247 *params = pg_params;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1248 *nparams = pg_nparams;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1249
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1250 return sql;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1251 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1252
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1253 /*
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1254 * Executes an SQL insert for the extension table
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1255 */
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1256 int ext_row_insert(WebdavProppatchRequest *request, PgProppatchExt *ext, PgExtTable *table) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1257 PgWebdavBackend *pgdav = request->dav->instance;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1258 PgProppatch *proppatch = request->userdata;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1259 pool_handle_t *pool = request->sn->pool;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1260
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1261 char **params;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1262 size_t nparam;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1263 CxBuffer *sql = ext_row_create_insert_query(request, ext, table, &params, &nparam);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1264 if(!sql) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1265 return 1;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1266 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1267
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1268 char resource_id_str[32];
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1269 snprintf(resource_id_str, 32, "%" PRId64, proppatch->resource_id);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1270 params[0] = resource_id_str;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1271
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1272 PGresult *result = PQexecParams(
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1273 pgdav->connection,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1274 sql->space,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1275 nparam, // number of parameters
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1276 NULL,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1277 ( const char *const *)params, // parameter value
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1278 NULL,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1279 NULL,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1280 0); // 0: result in text format
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1281
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1282 cxBufferDestroy(sql);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1283
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1284 int ret = 1;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1285 if(PQresultStatus(result) == PGRES_COMMAND_OK) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1286 // command ok, check if any row was updated
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1287 char *nrows_affected = PQcmdTuples(result);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1288 if(nrows_affected[0] == '1') {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1289 ret = 0;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1290 } else {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1291 log_ereport(LOG_FAILURE, "pg: extension row insert failed");
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1292 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1293 } else {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1294 log_ereport(LOG_FAILURE, "pg: extension row insert failed: %s", PQresultErrorMessage(result));
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1295 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1296
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1297 PQclear(result);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1298
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1299 return ret;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1300 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1301
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1302 /*
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1303 * Executes an SQL update for the extension table
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1304 */
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1305 int ext_row_update(WebdavProppatchRequest *request, PgProppatchExt *ext, PgExtTable *table) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1306 PgWebdavBackend *pgdav = request->dav->instance;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1307 PgProppatch *proppatch = request->userdata;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1308 pool_handle_t *pool = request->sn->pool;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1309
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1310 char **params;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1311 size_t nparam;
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1312 CxBuffer *sql = ext_row_create_update_query(request, ext, table, &params, &nparam);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1313 if(!sql) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1314 return 1;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1315 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1316
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1317 char resource_id_str[32];
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1318 snprintf(resource_id_str, 32, "%" PRId64, proppatch->resource_id);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1319 params[0] = resource_id_str;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1320
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1321 PGresult *result = PQexecParams(
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1322 pgdav->connection,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1323 sql->space,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1324 nparam, // number of parameters
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1325 NULL,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1326 ( const char *const *)params, // parameter value
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1327 NULL,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1328 NULL,
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1329 0); // 0: result in text format
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1330
415
d938228c382e switch from ucx 2 to 3
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 402
diff changeset
1331 cxBufferDestroy(sql);
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1332
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1333 int ret = 1;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1334 if(PQresultStatus(result) == PGRES_COMMAND_OK) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1335 // command ok, check if any row was updated
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1336 char *nrows_affected = PQcmdTuples(result);
378
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1337 if(nrows_affected[0] == '1') {
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1338 ret = 0;
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1339 } else if(nrows_affected[0] == '0') {
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1340 // no rows affected, that means we have to insert a new row
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1341 // in the extension table for this resource
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1342
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1343 // TODO: cleanup params
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1344
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1345 ret = ext_row_insert(request, ext, table);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1346 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1347 } else {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1348 log_ereport(LOG_FAILURE, "pg: extension row update failed: %s", PQresultErrorMessage(result));
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1349 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1350
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1351
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1352 PQclear(result);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1353
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1354 return ret;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1355 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1356
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1357 static int pg_dav_update_extension_tables(WebdavProppatchRequest *request) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1358 PgWebdavBackend *pgdav = request->dav->instance;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1359 PgProppatch *proppatch = request->userdata;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1360
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1361 for(int i=0;i<proppatch->numext;i++) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1362 if(proppatch->ext[i].isused) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1363 if(ext_row_update(request, &proppatch->ext[i], &pgdav->repository->tables[i])) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1364 // extension proppatch failed
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1365 return 1;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1366 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1367 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1368 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1369
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1370 return 0;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1371 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1372
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1373 int pg_dav_proppatch_do(
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1374 WebdavProppatchRequest *request,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1375 WebdavResource *response,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1376 VFSFile *file,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1377 WebdavPList **out_set,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1378 WebdavPList **out_remove)
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1379 {
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1380 PgWebdavBackend *pgdav = request->dav->instance;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1381 pool_handle_t *pool = request->sn->pool;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1382 char *path = pblock_findkeyval(pb_key_path, request->rq->vars);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1383
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1384 PgProppatch proppatch;
378
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1385 proppatch.extensions_used = FALSE;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1386 if(pgdav->repository->ntables == 0) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1387 proppatch.ext = NULL;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1388 proppatch.numext = 0;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1389 } else {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1390 // some properties are stored in additional tables
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1391 // for each table we create a PgProppatchExt record
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1392 // which stores data about, which tables are used
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1393 // and which properties (columns) should be updated
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1394 //
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1395 // proppatch.ext[i] should contain the data for repository->tables[i]
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1396 proppatch.numext = pgdav->repository->ntables;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1397 proppatch.ext = pool_calloc(request->sn->pool, proppatch.numext, sizeof(PgProppatchExt));
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1398 if(!proppatch.ext) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1399 return 1; // OOM
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1400 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1401 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1402 request->userdata = &proppatch;
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1403
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1404 // check if the resource exists, we also need the resource_id
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1405 int64_t parent_id;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1406 int64_t resource_id;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1407 const char *resourcename;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1408 WSBool iscollection;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1409 int res_errno = 0;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1410 int err = pg_resolve_path(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1411 pgdav->connection,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1412 path,
374
77506ec632a4 use configured root node from PgRepository in pg vfs/webdav
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 372
diff changeset
1413 pgdav->root_resource_id_str,
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1414 &parent_id,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1415 &resource_id,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1416 NULL, // OID
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1417 &resourcename,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1418 &iscollection,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1419 NULL, // stat
346
784b24381bed extend postgresql vfs to store an etag in the file
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 331
diff changeset
1420 NULL, // etag
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1421 &res_errno);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1422
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1423 if(err) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1424 return 1;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1425 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1426
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1427 proppatch.resource_id = resource_id;
378
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1428
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1429 // because proppatch must be atomic and we have multiple sql
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1430 // queries and other backends that do stuff that could fail
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1431 // we need the possibility to reverse all changes
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1432 // we use a transaction savepoint for this
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1433 PGresult *result = PQexec(pgdav->connection, "savepoint proppatch;");
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1434 ExecStatusType execStatus = PQresultStatus(result);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1435 PQclear(result);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1436 if(execStatus != PGRES_COMMAND_OK) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1437 return 1;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1438 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1439
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1440 char resource_id_str[32];
378
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1441 snprintf(resource_id_str, 32, "%" PRId64, resource_id);
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1442 // store the resource_id in rq->vars, because it could be useful later
0344108db255 make original proppatch property list available to all backends
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 377
diff changeset
1443 pblock_nvinsert("resource_id", resource_id_str, request->rq->vars);
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1444
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1445 int ret = 0;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1446 PgProppatchOpResult set_res = pg_proppatch_op(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1447 pgdav,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1448 request,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1449 response,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1450 out_set,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1451 PG_DAV_PROPPATCH_NOT_ALLOWED,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1452 pg_dav_set_property,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1453 resource_id_str);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1454 if(set_res.error) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1455 return 1;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1456 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1457 PgProppatchOpResult rm_res = pg_proppatch_op(
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1458 pgdav,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1459 request,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1460 response,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1461 out_remove,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1462 PG_DAV_CREATIONDATE, // creationdate can't be removed
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1463 pg_dav_remove_property,
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1464 resource_id_str);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1465 if(rm_res.error) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1466 return 1;
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1467 }
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1468
377
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1469 // if extensions are in use and pg_proppatch_op found any
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1470 // properties, that should be stored in extension tables
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1471 // we do the update/insert now
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1472 if(proppatch.extensions_used) {
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1473 ret = pg_dav_update_extension_tables(request);
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1474 }
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1475
c011bc2b3143 Add support for extended properties in pg proppatch
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 376
diff changeset
1476
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1477 return ret;
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1478 }
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1479
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1480 int pg_dav_proppatch_finish(
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1481 WebdavProppatchRequest *request,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1482 WebdavResource *response,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1483 VFSFile *file,
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1484 WSBool commit)
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1485 {
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1486 PgWebdavBackend *pgdav = request->dav->instance;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1487 int ret = 0;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1488 if(!commit) {
382
9e2289c77b04 disable pg large object IO functions for collections
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 380
diff changeset
1489 log_ereport(LOG_VERBOSE, "proppatch: rollback");
318
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1490 PGresult *result = PQexec(pgdav->connection, "rollback to savepoint proppatch;");
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1491 if(PQresultStatus(result) != PGRES_COMMAND_OK) {
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1492 log_ereport(LOG_FAILURE, "pg_dav_proppatch_finish: rollback failed: %s", PQerrorMessage(pgdav->connection));
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1493 ret = 1;
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1494 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1495 PQclear(result);
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1496 }
60870dbac94f add basic pg proppatch implementation
Olaf Wintermann <olaf.wintermann@gmail.com>
parents: 317
diff changeset
1497 return ret;
299
f927ef81a12b add empty pg webdav funcs
Olaf Wintermann <olaf.wintermann@gmail.com>
parents:
diff changeset
1498 }

mercurial