<div dir="ltr">Hi!<div><br></div><div>Just for records: PGDump is valid solution for this:</div><div>- First I created SQL file with ogr2ogr and "-f PGDump"-option</div><div>- Second, I uploaded result SQL file with psql: psql -t -q -c "SET ROLE admins;" -f ./result.sql</div><div><br></div><div>So this is work-around to manage group roles.</div><div><br></div><div>Rgs,</div><div><br></div><div>Pekka</div><div><div><div dir="ltr" class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><div><div dir="ltr"><div dir="ltr"><div dir="ltr"><p><span style="font-size:12.8000001907349px">Pekka Sarkola<br></span><span style="font-size:12.8000001907349px">Gispo Oy<br></span><a href="mailto:pekka.sarkola@gispo.fi" style="font-size:12.8000001907349px" target="_blank">pekka.sarkola@gispo.fi</a><span style="font-size:12.8000001907349px">   -
GSM +358 40 725 2042<br></span><a href="http://www.gispo.fi/" style="font-size:12.8000001907349px" target="_blank">www.gispo.fi</a><span style="font-size:12.8000001907349px"> – </span><a href="http://www.paikkatieto.com/" style="font-size:12.8000001907349px" target="_blank">www.paikkatieto.com</a></p></div></div></div></div></div></div></div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">ma 5. heinäk. 2021 klo 7.53 Pekka Sarkola (<a href="mailto:pekka@gispo.fi">pekka@gispo.fi</a>) kirjoitti:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div dir="ltr"><div dir="ltr">Hi!<div><br></div><div>PGDump: that might be the solution, I need to check. Thank you!</div><div><br></div><div>Yes, libpg-connection doesn't have role parameters. Maybe it should? I don't know how, but you can define role settings in pgAdmin connections</div><div><br></div><div>Rgs,</div><div><br></div><div>Pekka</div><div><div><div dir="ltr"><div dir="ltr"><div><div dir="ltr"><div dir="ltr"><div dir="ltr"><p><span style="font-size:12.8px">Pekka Sarkola<br></span><span style="font-size:12.8px">Gispo Oy<br></span><a href="mailto:pekka.sarkola@gispo.fi" style="font-size:12.8px" target="_blank">pekka.sarkola@gispo.fi</a><span style="font-size:12.8px">   -
GSM +358 40 725 2042<br></span><a href="http://www.gispo.fi/" style="font-size:12.8px" target="_blank">www.gispo.fi</a><span style="font-size:12.8px"> – </span><a href="http://www.paikkatieto.com/" style="font-size:12.8px" target="_blank">www.paikkatieto.com</a></p></div></div></div></div></div></div></div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">pe 2. heinäk. 2021 klo 15.51 Rahkonen Jukka (MML) (<a href="mailto:jukka.rahkonen@maanmittauslaitos.fi" target="_blank">jukka.rahkonen@maanmittauslaitos.fi</a>) kirjoitti:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">Hi again,<br>
<br>
GDAL is using the standand libpg-connect <a href="https://www.postgresql.org/docs/12/libpq-connect.html" rel="noreferrer" target="_blank">https://www.postgresql.org/docs/12/libpq-connect.html</a> and that does not have support for defining roles during connect.<br>
<br>
Do I understand right that your user "Joe" does not have direct CREATEDB privileges but gets them through the admins role? And because CREATEDB has a special handling <a href="https://www.postgresql.org/docs/current/role-membership.html" rel="noreferrer" target="_blank">https://www.postgresql.org/docs/current/role-membership.html</a> there is no other way to let Joe to create db that through SET ROLE ADMINS.<br>
<br>
Making GDAL to support <br>
"-doo "PRELUDE_STATEMENTS=SET ROLE admins"<br>
feels like a good idea but I have no idea about how difficult it would be to implement.<br>
<br>
-Jukka Rahkonen-<br>
<br>
<br>
<br>
-----Alkuperäinen viesti-----<br>
Lähettäjä: Rahkonen Jukka (MML) <br>
Lähetetty: perjantai 2. heinäkuuta 2021 14.40<br>
Vastaanottaja: '<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank">gdal-dev@lists.osgeo.org</a>' <<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank">gdal-dev@lists.osgeo.org</a>><br>
Aihe: Re: Setting roles in PostGIS connection<br>
<br>
Hi,<br>
<br>
I wonder if writing the output into pgdump <a href="https://gdal.org/drivers/vector/pgdump.html" rel="noreferrer" target="_blank">https://gdal.org/drivers/vector/pgdump.html</a> and editing the SQL a bit could be used as a workaround. <br>
<br>
-Jukka Rahkonen-<br>
<br>
Pekka Sarkola wrote:<br>
<br>
> Hi!<br>
<br>
> We have a PostGIS database with login roles and group roles (like <br>
> "admins", "editors" and "viewers"). We have defined that only "admins" <br>
> can create new schemas and tables (among other privileges). My problem <br>
> is that I'd like to use ogr2ogr to bulk load some data to a PostGIS <br>
> database using ogr2ogr with a certain login role with "admins" role.<br>
<br>
> It seems that it is not possible to define roles in PostgreSQL <br>
> connection parameters (my first try) or in PostgreSQL driver options.<br>
<br>
> I tried to use PREDUDE_STATEMENTS like: "-doo "PRELUDE_STATEMENTS=SET <br>
> ROLE admins", but got warning "Warning 1: -doo ignored when creating <br>
> the output datasource."<br>
<br>
> Any solutions or suggestions?<br>
<br>
> There is also similar case in QGIS: Supporting "set role" when <br>
> connecting to a postgres database - <br>
> <a href="https://github.com/qgis/QGIS/issues/42763" rel="noreferrer" target="_blank">https://github.com/qgis/QGIS/issues/42763</a><br>
<br>
> Versions: GDAL 3.0.4, released 2020/01/28, PostgreSQL 12.7, PostGIS <br>
> 3.1<br>
<br>
> Rgs,<br>
<br>
> Pekka<br>
_______________________________________________<br>
gdal-dev mailing list<br>
<a href="mailto:gdal-dev@lists.osgeo.org" target="_blank">gdal-dev@lists.osgeo.org</a><br>
<a href="https://lists.osgeo.org/mailman/listinfo/gdal-dev" rel="noreferrer" target="_blank">https://lists.osgeo.org/mailman/listinfo/gdal-dev</a><br>
</blockquote></div></div>
</blockquote></div>