Opened 13 months ago

Last modified 2 months ago

#5624 new defect

Provide JSON version of PostGIS_Full_Version() for easier parsing

Reported by: Lars Aksel Opsahl Owned by: strk
Priority: medium Milestone: PostGIS 3.6.0
Component: upgrade Version: 3.4.x
Keywords: Cc: Lars Aksel Opsahl

Description (last modified by Lars Aksel Opsahl)

Case 1 (using a EOL geos)

POSTGIS="3.4.0 0874ea3" [EXTENSION] PGSQL="120" GEOS="3.10.1-CAPI-1.16.0" SFCGAL="1.3.7" PROJ="8.2.0 NETWORK_ENABLED=OFF URL_ENDPOINT=https://cdn.proj.org USER_WRITABLE_DIRECTORY=/tmp/proj DATABASE_PATH=/usr/share/proj/proj.db" LIBXML="2.9.10" LIBJSON="0.13.1" LIBPROTOBUF="1.3.3" WAGYU="0.5.0 (Internal)" TOPOLOGY

Then a message like this could be added

Your geos has reached EOL, please try to upgrade your geos. To be sure to get all feature supported latest geos at [https://libgeos.org/usage/download/]

Case 2 (Using a valid geos, but not latest)

POSTGIS="3.4.0 0874ea3" [EXTENSION] PGSQL="120" GEOS="3.10.6" SFCGAL="1.3.7" PROJ="8.2.0 NETWORK_ENABLED=OFF URL_ENDPOINT=https://cdn.proj.org USER_WRITABLE_DIRECTORY=/tmp/proj DATABASE_PATH=/usr/share/proj/proj.db" LIBXML="2.9.10" LIBJSON="0.13.1" LIBPROTOBUF="1.3.3" WAGYU="0.5.0 (Internal)" TOPOLOGY

Then a message like this could be added

Your geos is valid, but to be sure to get all feature supported try to use latest geos at [https://libgeos.org/usage/download/]

Case 3 (Using a latest geos or newer)

POSTGIS="3.4.0 0874ea3" [EXTENSION] PGSQL="120" GEOS="3.12.1" SFCGAL="1.3.7" PROJ="8.2.0 NETWORK_ENABLED=OFF URL_ENDPOINT=https://cdn.proj.org USER_WRITABLE_DIRECTORY=/tmp/proj DATABASE_PATH=/usr/share/proj/proj.db" LIBXML="2.9.10" LIBJSON="0.13.1" LIBPROTOBUF="1.3.3" WAGYU="0.5.0 (Internal)" TOPOLOGY

There is no printed message about geos

Change History (9)

comment:1 by Lars Aksel Opsahl, 13 months ago

Description: modified (diff)

A assume doing online check here maybe out off scope ? So if you install postgis and never touch server the next 5 years there may not be passed out any info about EOL geos.

I thinks what's more important is that when you install a new postgis and you think that you have an update to date system, it would be nice with a warning message about geos if that is not fully up to date.

comment:2 by robe, 13 months ago

Component: postgisupgrade
Milestone: PostGIS 3.4.2PostGIS 3.5.0
Owner: changed from pramsey to strk

Pushing this to 3.5.0 since we can't be changing the output at micro versions since some people parse that info. I'm still against this idea BTW, but I'll leave it up to strk to decide what to do.

comment:3 by strk, 13 months ago

I don't think we should do online lookups to tell what's EOL and what not, but we could leave a note about PostGIS having been compiled to a version of GEOS which is not the one recommended at the time of PostGIS release. Would that help ?

comment:4 by strk, 13 months ago

Note that if the version of GEOS used when compiling does not match the version of GEOS found at runtime should already be giving you the compiled version in parens, right after the runtime version.

I'm thinking we should really have a JSON flavor of this version function as it would be much easier to parse.

Feel free to file a ticket on the GEOS side to expose an web endpoint to report what the latest version is, btw, as that endpoint would be needed shall you decide to implement the check you are asking for in your custom code.

in reply to:  3 comment:5 by Lars Aksel Opsahl, 13 months ago

Replying to strk:

I don't think we should do online lookups to tell what's EOL and what not, but we could leave a note about PostGIS having been compiled to a version of GEOS which is not the one recommended at the time of PostGIS release. Would that help ?

Yes I think that is very nice. I believe then we may avoid to report "invalid" tickets because of EOL geos after an upgrade to latest postgis.

in reply to:  4 ; comment:6 by Lars Aksel Opsahl, 13 months ago

Replying to strk:

Note that if the version of GEOS used when compiling does not match the version of GEOS found at runtime should already be giving you the compiled version in parens, right after the runtime version.

I'm thinking we should really have a JSON flavor of this version function as it would be much easier to parse.

Yes agree and then it's much more safe to add new elements without cause parsing problem for existing users.

in reply to:  6 comment:7 by robe, 13 months ago

Replying to Lars Aksel Opsahl:

Replying to strk:

Note that if the version of GEOS used when compiling does not match the version of GEOS found at runtime should already be giving you the compiled version in parens, right after the runtime version.

I'm thinking we should really have a JSON flavor of this version function as it would be much easier to parse.

Yes agree and then it's much more safe to add new elements without cause parsing problem for existing users.

I agree too then we can stuff as much as we want in there as long as old queries for specific items don't break.

comment:8 by robe, 3 months ago

Milestone: PostGIS 3.5.0PostGIS 3.6.0

comment:9 by robe, 2 months ago

Summary: Provide more info about out of date geos when checking PostGIS_Full_Version() ;Provide JSON version of PostGIS_Full_Version() for easier parsing

I'm retitling this since we already have this info but it's hard to parse.

Note: See TracTickets for help on using tickets.