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 maven dependency #365

Open
keski opened this issue Oct 2, 2024 · 14 comments
Open

publish maven dependency #365

keski opened this issue Oct 2, 2024 · 14 comments

Comments

@keski
Copy link
Collaborator

keski commented Oct 2, 2024

This issue is about publishing HeFQUIN releases using GitHub Packages as a Maven repository. To use HefQUIN as dependency would then require something like:

<repositories>
    <repository>
        <id>github</id>
        <name>GitHub LiUSemWeb Repository</name>
        <url>https://maven.pkg.github.com/LiUSemWeb/HeFQUIN</url>
    </repository>
</repositories>

<dependencies>
    <dependency>
        <groupId>se.liu.ida.hefquin</groupId>
        <artifactId>hefquin-engine</artifactId>
        <version>x.y.z</version> 
    </dependency>
</dependencies>

I'd suggest adding an action that is triggered automatically whenever a new release is published.

Note: Maven releases are immutable also when using GitHub Packages.

@hartig

@hartig
Copy link
Member

hartig commented Oct 2, 2024

Good idea, but I have a few questions to better understand what this entails:

Would this mean that, if I do mvn deploy in my local copy of the repo, then the package will be uploaded and published at GitHub Packages? If yes, who else besides me would be able to do that?

Regarding the immutability that you speak of, does it mean doing mvn deploy a second time with the same version number would result in an error message?

@keski
Copy link
Collaborator Author

keski commented Oct 2, 2024

Good idea, but I have a few questions to better understand what this entails:

Would this mean that, if I do mvn deploy in my local copy of the repo, then the package will be uploaded and published at GitHub Packages? If yes, who else besides me would be able to do that?

No, doing mvn deploy on a local copy would not publish to GitHub Packages. Just like the publishing of gh-pages, this would be an action triggered by an event on the repo (release). Anyone with permissions to create a new release would in principle be able to indirectly trigger this.

Regarding the immutability that you speak of, does it mean doing mvn deploy a second time with the same version number would result in an error message?

Exactly, so when creating releases we should adhere to, e.g., semantic versioning.

@hartig
Copy link
Member

hartig commented Oct 2, 2024

Thanks for answering my questions. Sounds like a good idea then!

@keski
Copy link
Collaborator Author

keski commented Oct 7, 2024

After a lot of experimentation I have a few things to add to this issue:

  1. Artifact IDs should be lowercase (i.e., HefQUIN -> hefquin) to comply with Maven conventions (it's even a strict requirement in some systems). So to avoid issues in the future, we should change to lowercase.

  2. It turns out that using GitHub Packages as a Maven repository requires authentication... I believe it has something to do with how GitHub handles public vs. private repos, but either way it is quite limiting to require users to authenticate to use an open source library. Interestingly, this is not the case when hosting docker images. Anyways, this means that it's probably better to publish to using Sonatype and the Maven Central Repository.

  3. Sonatype is transitioning from to a new publishing system (see central portal vs. legacy OSSRH). In terms of functionality, the main difference seems to be that the new system currently does not support SNAPSHOT versions. We could use the legacy system but it seems like we would have to transition eventually anyways.

  4. Maven Central Repository requires that a few extra details are added to the main pom.xml file (see requirements).

  5. The process for starting to publish to the central repository is bit involved (see summary here). The basic steps would be:

I was thinking that we could set up a common Maven Central account for the group LiUSemWeb, which we can manage as a group. That way the publishing steps will persist even if the group members change in future and we don't have to share any personal tokens etc. Also, an email can only be used to register a single Sonatype account. If this sounds like a good idea, do we have some email address that could be used for this or should we create a new one? What domain?

@hartig

@hartig
Copy link
Member

hartig commented Oct 7, 2024

  1. Artifact IDs should be lowercase (i.e., HefQUIN -> hefquin) to comply with Maven conventions (it's even a strict requirement in some systems). So to avoid issues in the future, we should change to lowercase.

Okay, we can do that.

In this case, would it make sense to change the groupId from se.liu.ida.hefquin to se.liu.ida? Maybe not, or what do you think?

  1. It turns out that using GitHub Packages as a Maven repository requires authentication [...] Anyways, this means that it's probably better to publish to using Sonatype and the Maven Central Repository.

Okay

  1. Sonatype is transitioning from to a new publishing system (see central portal vs. legacy OSSRH). In terms of functionality, the main difference seems to be that the new system currently does not support SNAPSHOT versions. We could use the legacy system but it seems like we would have to transition eventually anyways.

We wouldn't publish SNAPSHOT versions anyways, would we?

  1. Maven Central Repository requires that a few extra details are added to the main pom.xml file (see requirements).

Can you please create a PR with an initial version of these changes. Then, I can take a look and expand/adjust as I see fit. (The PR may also contain the change as per point 1 above)

I was thinking that we could set up a common Maven Central account for the group LiUSemWeb, which we can manage as a group. That way the publishing steps will persist even if the group members change in future and we don't have to share any personal tokens etc.

What do you mean by personal tokens?
I guess, among the (three senior) seniors in the group, the only one who would care about having the option to publish to Maven Central is me, and I am not planning to have my status as a group member change in the future ;-) So, in principle, we could also choose that I create the account with the understanding that this is the account for the group. But then, what would the personal tokens be?

Also, an email can only be used to register a single Sonatype account.

Is such an account then only for Maven packages for one project or can it be for multiple?

If this sounds like a good idea, do we have some email address that could be used for this or should we create a new one? What domain?

If we don't use my email address, then it should be one for the group, preferably with @liu.se. But as we don't have such an email address, I am afraid trying to get one may be more effort than simply using my LiU email address.

@keski keski closed this as completed Oct 17, 2024
@keski keski reopened this Oct 17, 2024
@keski
Copy link
Collaborator Author

keski commented Oct 18, 2024

  1. Artifact IDs should be lowercase (i.e., HefQUIN -> hefquin) to comply with Maven conventions (it's even a strict requirement in some systems). So to avoid issues in the future, we should change to lowercase.

Okay, we can do that.

In this case, would it make sense to change the groupId from se.liu.ida.hefquin to se.liu.ida? Maybe not, or what do you think?

Jena uses Apache Jena uses jena as its artifact ID so maybe we can probably keep the groupId as is:

  <name>Apache Jena</name>
  <groupId>org.apache.jena</groupId>
  <artifactId>jena</artifactId>
  <packaging>pom</packaging>
  ...
  1. Sonatype is transitioning from to a new publishing system (see central portal vs. legacy OSSRH). In terms of functionality, the main difference seems to be that the new system currently does not support SNAPSHOT versions. We could use the legacy system but it seems like we would have to transition eventually anyways.

We wouldn't publish SNAPSHOT versions anyways, would we?

I agree.

  1. Maven Central Repository requires that a few extra details are added to the main pom.xml file (see requirements).

Can you please create a PR with an initial version of these changes. Then, I can take a look and expand/adjust as I see fit. (The PR may also contain the change as per point 1 above)

Will do.

I was thinking that we could set up a common Maven Central account for the group LiUSemWeb, which we can manage as a group. That way the publishing steps will persist even if the group members change in future and we don't have to share any personal tokens etc.

What do you mean by personal tokens? I guess, among the (three senior) seniors in the group, the only one who would care about having the option to publish to Maven Central is me, and I am not planning to have my status as a group member change in the future ;-) So, in principle, we could also choose that I create the account with the understanding that this is the account for the group. But then, what would the personal tokens be?

Okay. So maybe it's just overkill to automate the maven publishing step? We could instead just make sure that the process is properly documented and then you can authenticate by modifying ~/.m2/settings.xml locally on your machine. I'll look into the details and try it for my self in an example project and get back to you.

Also, an email can only be used to register a single Sonatype account.

Is such an account then only for Maven packages for one project or can it be for multiple?

Managing multiple projects with a single project is fine, but we can't create a dedicated LiUSemWeb account using our own email addresses.

If this sounds like a good idea, do we have some email address that could be used for this or should we create a new one? What domain?

If we don't use my email address, then it should be one for the group, preferably with @liu.se. But as we don't have such an email address, I am afraid trying to get one may be more effort than simply using my LiU email address.

Let's use yours then. I'll get back with details.

@LiUSemWeb LiUSemWeb deleted a comment from keski Oct 18, 2024
@hartig
Copy link
Member

hartig commented Oct 18, 2024

Sounds all good. I will wait for you to get back with details then.

(And we keep the the groupId as se.liu.ida.hefquin)

@keski
Copy link
Collaborator Author

keski commented Oct 22, 2024

I've now finally managed to publish an example project using Maven Central! I was a bit taken aback by how complicated it actually was, but I've taken note of all the steps so next time should be much easier, and updated the Release-Logistics.

The key takeaways are the following:

  • We need to register a namespace. For example, using se.liu.ida.hefquin as the namespace would mean that we have to prove ownership of the subdomain hefquin.ida.liu.se (see https://central.sonatype.org/register/namespace/#adding-a-namespace).
  • As the owner or maintainer of a domain name, you can use any groupId starting with the reverse domain name and as many subsections as you desire. I.e., if we register a namespace for LiUSemWeb, we could publish under this one without having to add additional namespaces later on. E.g. we could register se.liu.ida.liusemweb and then publish HeFQUIN under se.ida.liu.liusemweb.hefquin.
  • Proving ownership on an LiU subdomain is not something we can do ourselves as far as I know, even if we had access to the subdomain right now. I've submitted a ticket to IT to see what the practice is. I asked about Maven library publishing in general, as well as the possibility of registering hefquin.ida.liu.se or liusemweb.ida.liu.se as namespaces. No reply yet.
  • We could also use the namespace io.github.liusemweb, and thus publish with, e.g., io.github.liusemweb.hefquin. The benefit would of course be that we can handle it all ourselves. If so, do we want to update our package names?

According to the Maven Central docs, multiple users should be able to share a namespace but there seems to be no way of adding users manually, so I think it's best that @hartig claims the namespace.

@hartig, perhaps we can schedule a time for setting it up on your computer once we now how to manage deal with namespace/subdomain question?

@keski
Copy link
Collaborator Author

keski commented Oct 22, 2024

For testing purposes, I've published HeFQUIN in my own github namespace. The libs work as expected and the modules can be imported separately. E.g.:

  <dependency>
    <groupId>io.github.keski.hefquin</groupId>
    <artifactId>hefquin-cli</artifactId>
    <version>0.0.1</version>
  </dependency>

I've update the pom.xml file in https://github.com/LiUSemWeb/HeFQUIN/tree/365-publish-maven-dependency. Once we we have the namespace we should be ready to publish.

@hartig
Copy link
Member

hartig commented Oct 23, 2024

Thanks for your efforts. Let's wait for IT to respond to your ticket.

In the meantime, I'm repeating my thoughts from our brief discussion yesterday about some of the other points, just for the record:

  • I prefer using a se.liu namespace over io.github.liusemweb because it has a more official touch.
  • If we register se.liu.ida.liusemweb as namespace at Maven Central and then publish HeFQUIN under se.liu.ida.liusemweb.hefquin, we should rename the Java packages in our code base accordingly.
  • Related to the previous point, I would find se.liu.ida.liusemweb.hefquin as the base part of all our Java package names quite long. se.liu.ida.hefquin is much nicer.
  • Yet, I also see that registering se.liu.ida.liusemweb as namespace is more reasonable, given that we might have other Java projects to publish in the future.
  • In fact, the best possible option would be to have se.liu.ida registered as our domain name for the whole department. Then, we could still use se.liu.ida.hefquin for HeFQUIN. But let's see what IT says.

@hartig
Copy link
Member

hartig commented Nov 11, 2024

@keski any update on this one?

@keski
Copy link
Collaborator Author

keski commented Nov 26, 2024

@hartig I got an update regarding this! If we want to use a subdomain directly under ida.liu.se we apparently need approval from the prefect at IDA. But another suggestion was to use the domain research.liu.se which is used for something similar in two other projects. We would then use something like semweb.research.liu.se. What do you think?

@hartig
Copy link
Member

hartig commented Nov 28, 2024

Thanks for investigating!

I assume that, instead of se.liu.research.semweb, we may also get se.liu.research.hefquin. Right?

If so, I would prefer that (but keep our Java packages named as they are). Can you please ask IT what we need to do have them help us set this up. In particular, as far as I understand the related part of the Sonatype documentation, they need to add a "DNS TXT record" for us where the value of this record is the verification key that we get from Sonatype in the process of verifying the namespace. Can you please confirm with IT that they would do that for us (feel free to include me in CC).

@keski
Copy link
Collaborator Author

keski commented Dec 3, 2024

This matches my understanding as well. I've forwarded our request to IT.

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

When branches are created from issues, their pull requests are automatically linked.

2 participants