Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Publish PlJava to a public Maven Repository #484

Open
TasMot opened this issue Apr 9, 2024 · 2 comments
Open

Publish PlJava to a public Maven Repository #484

TasMot opened this issue Apr 9, 2024 · 2 comments

Comments

@TasMot
Copy link

TasMot commented Apr 9, 2024

PlJava adds functionality that is fantastic. However; it is problematic in that it needs a -private- build from source in order to make the jar available. Is there any chance that the jar file for each build be added to a public Maven Repository so that everyone that wants to use it doesn't have to do a private build from source?

Please???

@jcflack
Copy link
Contributor

jcflack commented Apr 10, 2024

This has been a perennial to-do item that keeps perennially being not done. It would certainly be desirable for the pljava-api jar to be in a public repo so it can be referred to when compiling PL/Java client code. Only that jar is needed; the pljava implementation jar only needs to be among the files installed on the PostgreSQL server, as no client code refers to it.

So, the pljava-api jar can be built easily, without the rest of the project, using mvn clean install --projects pljava-api. Likewise, mvn site --projects pljava-api will generate the javadocs for the API. A jar of the generated javadocs and a jar of the API sources must also be uploaded to the repository, according to the requirements.

I would certainly be happy to look over a pull request with a GitHub Actions workflow in it that would create and sign the necessary jars, and be triggered only when a new release is published. Perhaps even just a script that can be manually run to do it.

Some coordination is needed with Dave Cramer, who is the registrant of the org.postgresql coordinates, currently used by the PGJDBC driver. org.postgresql.pljava creates no conflict with PGJDBC, but is within the namespace he controls. We discussed it some time ago and he has no objection, but some details may need to be worked out so the repo will accept the uploads.

PGJDBC uploads are signed using personal keys of Dave or Vladimir. What key to use for pljava-api needs to be determined. If the releasing will be done in a GHA workflow, a key generated for the purpose (with the private portion secured as a GHA environment secret) might be adequate. I'm not as keen on using a personal key that way.

None of this is truly complicated, just detail-heavy. Among the details to be sorted:

The publishing requirements also require uploading the POM. Only the pljava-api POM is directly needed, but its reference to the parent POM probably requires that one to to be uploaded also. Does that, in turn, require the other subproject POMs to be published there because it refers to them, even though there is no need for any of them to be available through a repository?

Or would it be better to revise the structuring of the subprojects and POMs? That sounds like a fairly disruptive headache.

Also to keep in mind: I have argued here and here for possibly moving away from Maven entirely and building with a simple jshell script. As it stands, PL/Java (which is tiny, and has no dependencies) pulls down over a hundred megabytes of assorted Maven dependencies during a build, which have version interactions and vulnerability reports and such nonsense, all of which are headaches existing only because of Maven and not because of PL/Java.

Perhaps some later PL/Java version will have a simple jshell-based build and have only one vestigial POM file, for pljava-api, present only to satisfy the publication requirements.

I see there is not any existing open issue for this, despite it having been on the to-do list for so long, so this issue can be labeled 'enhancement' and used for discussion.

@jcflack
Copy link
Contributor

jcflack commented Apr 20, 2024

As one stopgap measure, it may be worth noting that only the pljava-api-$version.jar file is needed, and that jar is already present if PL/Java has been installed from a prebuilt package. It can be found in $(pg_config --sharedir)/pljava/

For the convenience of local projects that depend on it, it can be added to the local Maven repository, as described here.

The jar contains its own POM file, so the last, simplest command shown in that guide is sufficient to install it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants