Skip to content

GitHub Package Registry integration examples for Java/Kotlin projects

Notifications You must be signed in to change notification settings

igabaydulin/github-package-registry-example

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

29 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

How to Use GitHub Package Registry Basics

GitHub Package Registry integration examples for Java projects

GitHub Package Registry Public Beta

Notice: GitHub Package Registry is not yet released and to be able to publish package into GitHub Package Registry you must have access to the public beta. To request to join the limited public beta, see the GitHub Package Registry page. You will be notified by email when you've gained access to public beta.

P.S. I don't know if there are requirements for public beta access to be able to download packages. Let me know it there are no requirements πŸ™‚

Table of contents

Repository Structure

There are a few examples illustrating how to integrate GitHub Package Registry into your project:

  • Configuring Maven project
    maven
    β”œβ”€β”€ pom.xml
    β”œβ”€β”€ lib
    β”‚Β Β  β”œβ”€β”€ pom.xml
    β”‚Β Β  └── src
    β”‚Β Β      β”œβ”€β”€ main
    β”‚Β Β      β”‚Β Β  └── java
    β”‚Β Β      β”‚Β Β      └── com.github.igabaydulin.ping
    β”‚Β Β      β”‚Β Β          └── Ping.java
    β”‚Β Β      └── test
    β”‚Β Β          └── java
    β”‚Β Β              └── com.github.igabaydulin.ping
    β”‚Β Β                  └── PingTest.java
    └── sample
        β”œβ”€β”€ pom.xml
        └── src
            β”œβ”€β”€ main
            β”‚Β Β  └── java
            β”‚Β Β      └── com.github.igabaydulin.sample
            β”‚Β Β          └── App.java
            └── test
                └── java
                    └── com.github.igabaydulin.sample
                        └── AppTest.java
    

  • Configuring Gradle project
    gradle-groovy
    β”œβ”€β”€ build.gradle
    β”œβ”€β”€ settings.gradle
    β”œβ”€β”€ gradle
    β”‚Β Β  └── wrapper
    β”‚Β Β      β”œβ”€β”€ gradle-wrapper.jar
    β”‚Β Β      └── gradle-wrapper.properties
    β”œβ”€β”€ gradlew
    β”œβ”€β”€ gradlew.bat
    β”œβ”€β”€ lib
    β”‚Β Β  β”œβ”€β”€ build.gradle
    β”‚Β Β  └── src
    β”‚Β Β      β”œβ”€β”€ main
    β”‚Β Β      β”‚Β Β  └── java
    β”‚Β Β      β”‚Β Β      └── com.github.igabaydulin.ping
    β”‚Β Β      β”‚Β Β          └── Ping.java
    β”‚Β Β      └── test
    β”‚Β Β          └── java
    β”‚Β Β              └── com.github.igabaydulin.ping
    β”‚Β Β                  └── PingTest.java
    └── sample
     Β Β  β”œβ”€β”€ build.gradle
     Β Β  └── src
     Β Β      β”œβ”€β”€ main
     Β Β      β”‚Β Β  └── java
     Β Β      β”‚Β Β      └── com.github.igabaydulin.sample
     Β Β      β”‚Β Β          └── App.java
     Β Β      └── test
     Β Β          └── java
     Β Β              └── com.github.igabaydulin.sample
     Β Β                  └── AppTest.java
    

  • Configuring Gradle project using Kotlin DSL
    gradle-kotlin
    β”œβ”€β”€ build.gradle.kts
    β”œβ”€β”€ settings.gradle.kts
    β”œβ”€β”€ gradle
    β”‚Β Β  └── wrapper
    β”‚Β Β      β”œβ”€β”€ gradle-wrapper.jar
    β”‚Β Β      └── gradle-wrapper.properties
    β”œβ”€β”€ gradlew
    β”œβ”€β”€ gradlew.bat
    β”œβ”€β”€ lib
    β”‚Β Β  β”œβ”€β”€ build.gradle.kts
    β”‚Β Β  └── src
    β”‚Β Β      β”œβ”€β”€ main
    β”‚Β Β      β”‚Β Β  └── kotlin
    β”‚Β Β      β”‚Β Β      └── com.github.igabaydulin.ping
    β”‚Β Β      β”‚Β Β          └── Ping.kt
    β”‚Β Β      └── test
    β”‚Β Β          └── kotlin
    β”‚Β Β              └── com.github.igabaydulin.ping
    β”‚Β Β                  └── PingTest.kt
    └── sample
     Β Β  β”œβ”€β”€ build.gradle.kts
     Β Β  └── src
     Β Β      β”œβ”€β”€ main
     Β Β      β”‚Β Β  └── kotlin
     Β Β      β”‚Β Β      └── com.github.igabaydulin.sample
     Β Β      β”‚Β Β          └── App.kt
     Β Β      └── test
     Β Β          └── kotlin
     Β Β              └── com.github.igabaydulin.sample
     Β Β                  └── AppTest.kt
    

Useful Links:

Prerequisites

Public Beta Access

As was mentioned before make sure you have an access to public beta πŸ™‚ (you can use this link to sign up).

Create GitHub Personal Access Token

You need to create a personal access token with the read:packages and write:packages scopes to publish and download packages. This article explains how to create a personal access token.

Configuring Apache Maven to Use Generated Token

As described in Configuring Apache Maven for use with GitHub Package Registry article you need to provide Maven generated token (configuring Maven to use GitHub Registry as Maven repository along the way) by editing ~/.m2/settings.xml (if it does not exists create a new one).

Notice: It doesn't matter if you're using Gradle instead, create or modify ~/.m2/settings.xml as well.

~/.m2/settings.xml should look like this (example is taken from the article):

<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0
                      http://maven.apache.org/xsd/settings-1.0.0.xsd">

  <activeProfiles>
    <activeProfile>github</activeProfile>
  </activeProfiles>

  <profiles>
    <profile>
      <id>github</id>
      <repositories>
        <repository>
          <id>central</id>
          <url>https://repo1.maven.org/maven2</url>
          <releases><enabled>true</enabled></releases>
          <snapshots><enabled>true</enabled></snapshots>
        </repository>
        <repository>
          <id>github</id>
          <name>GitHub OWNER Apache Maven Packages</name>
          <url>https://maven.pkg.github.com/OWNER</url>
        </repository>
      </repositories>
    </profile>
  </profiles>

  <servers>
    <server>
      <id>github</id>
      <username>USERNAME</username>
      <password>TOKEN</password>
    </server>
  </servers>
</settings>

where

  • OWNER: the repository/packages owner (if you wanna try to download packages from this repository, use igabaydulin)
  • USERNAME: your GitHub username
  • TOKEN: personal access token generated on the previous step

Project Configuration to Publish Packages

Maven Project

Besides providing the necessary Maven plugins (maven-deploy-plugin as an example) or using the built-in plugins versions you need to configure where you will publish the package. Add these lines in your pom.xml file:

<distributionManagement>
  <repository>
    <id>github</id> <!-- this id must be equal to id in ~/.m2/settings.xml file! -->
    <name>GitHub igabaydulin Apache Maven Packages</name>
    <url>https://maven.pkg.github.com/igabaydulin/github-package-registry-example</url>
  </repository>
</distributionManagement>

Package Publishing

mvn deploy

Details

You can take a look at maven project for more details

Gradle Project

By default Gradle does not use ~/.m2/settings.xml. To fix this we can use one of the Gradle plugins. I recommend to use net.linguica.maven-settings plugin:

plugins {
  id "net.linguica.maven-settings" version "0.5"
}

To be able to publish packages you also must use maven-publish plugin:

  id "maven-publish"

You can read about current publishing mechanism in this Gradle article. Your publishing configuration may look like this:

publishing {
    publishing {
        publications {
            lib(MavenPublication) {
                artifactId = "groovy-example-ping" // not required if you project name is equal to artifactId (in my example project has "lib" name)
                from components.java // otherwise you will get an empty package and publishing step will be skipped
            }
        }

        repositories {
            maven {
                name = "github" // must be equal to id in ~/.m2/settings.xml file!
                url = uri("https://maven.pkg.github.com/igabaydulin/github-package-registry-example")
            }
        }
    }
}

Package Publishing

./gradlew publish

Details

You can take a look at gradle-groovy project for more details

Gradle Project with Kotlin DSL

The configuration is pretty the same as a previous one.

First, specify the necessery plugins:

plugins {
    id("java-library")
    id("org.jetbrains.kotlin.jvm") version "1.3.41"
    id("maven-publish")
    id("net.linguica.maven-settings") version "0.5"
}

Second, configure publishing:

publishing {
    publications {
        create<MavenPublication>("lib") {
            artifactId = "kotlin-example-ping"
            from(components["java"])
        }
    }

    repositories {
        maven {
            name = "github"
            url = uri("https://maven.pkg.github.com/igabaydulin/github-package-registry-example")
        }
    }
}

Package Publishing

You can use the same command described in the previous section (obviously! 🀠):

./gradlew publish

Details

And as always you can take a look at gradle-kotlin project for more details

Few Words about Dependency Configuration

Maven Project

Add the next dependency:

<dependency>
    <groupId>com.github.igabaydulin</groupId>
    <artifactId>maven-example-ping</artifactId>
    <version>1.1.0</version>
</dependency>

And... that's it! πŸ˜ƒ

Gradle Project

Add the next dependency:

dependencies {
    implementation 'com.github.igabaydulin:groovy-example-ping:1.1.0'
}

And... and do not forget to provide maven-settings plugin:

plugins {
  id("net.linguica.maven-settings") version "0.5"
}

And... and specify repository to download the package:

repositories {
    maven {
        name = "github"
        url = uri("https://maven.pkg.github.com/igabaydulin/github-package-registry-example")
    }
}

Note: I don't even know why this is required (maybe some lack of code in maven-settings plugin). If you know the reason, please, DM me :)

And... that's it! 😫

Gradle Project with Kotlin DSL

Pretty the same.

Add plugins:

plugins {
    id("application")
    id("org.jetbrains.kotlin.jvm") version "1.3.41"
    id("net.linguica.maven-settings") version "0.5"
}

Specify repository:

repositories {
    jcenter()
    maven {
        name = "github"
        url = uri("https://maven.pkg.github.com/igabaydulin/github-package-registry-example")
    }
}

Add dependency:

dependencies {
    implementation("com.github.igabaydulin:kotlin-example-ping:1.1.0")
}

About

GitHub Package Registry integration examples for Java/Kotlin projects

Resources

Stars

Watchers

Forks

Packages