diff --git a/.github/workflows/publish.yml b/.github/workflows/publish.yml deleted file mode 100644 index 26bdb4e8..00000000 --- a/.github/workflows/publish.yml +++ /dev/null @@ -1,20 +0,0 @@ -name: Publish package to the Maven Central Repository -on: - release: - types: [created] -jobs: - publish: - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v2 - - name: Set up Java - uses: actions/setup-java@v1 - with: - java-version: 1.8 - - name: Publish package - run: gradle publish - env: - SONATYPE_USERNAME: ${{ secrets.SONATYPE_USERNAME }} - SONATYPE_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }} - SIGNING_KEY: ${{ secrets.SIGNING_KEY }} - SIGNING_PASSWORD: ${{ secrets.SIGNING_PASSWORD }} diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml new file mode 100644 index 00000000..485f7b36 --- /dev/null +++ b/.github/workflows/release.yml @@ -0,0 +1,89 @@ +name: Release +on: + push: + tags: + - 'sputnik*' + +jobs: + build: + name: Upload Release Asset + runs-on: ubuntu-latest + steps: + - name: Checkout code + uses: actions/checkout@v2 + - name: Set up Java + uses: actions/setup-java@v1 + with: + java-version: 1.8 + - name: Extract version + run: echo "##[set-output name=version;]$(echo ${GITHUB_REF#refs/tags/sputnik-})" + id: extract_version + - name: Build project + run: ./gradlew -Pversion=${{ steps.extract_version.outputs.version }} build + - name: Publish package + run: ./gradlew -Pversion=${{ steps.extract_version.outputs.version }} publish + env: + SONATYPE_USERNAME: ${{ secrets.SONATYPE_USERNAME }} + SONATYPE_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }} + SIGNING_PRIVATE_KEY: ${{ secrets.SIGNING_PRIVATE_KEY }} + SIGNING_PASSWORD: ${{ secrets.SIGNING_PASSWORD }} + - name: Create Release + id: create_release + uses: actions/create-release@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + tag_name: ${{ github.ref }} + release_name: Sputnik ${{ steps.extract_version.outputs.version }} + draft: true + prerelease: false + - name: Upload jar + id: upload-release-asset-jar + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: ./build/libs/sputnik-${{ steps.extract_version.outputs.version }}.jar + asset_name: sputnik-${{ steps.extract_version.outputs.version }}.jar + asset_content_type: application/java-archive + - name: Upload javadoc + id: upload-release-asset-javadoc + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: ./build/libs/sputnik-${{ steps.extract_version.outputs.version }}-javadoc.jar + asset_name: sputnik-${{ steps.extract_version.outputs.version }}-javadoc.jar + asset_content_type: application/java-archive + - name: Upload sources + id: upload-release-asset-sources + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: ./build/libs/sputnik-${{ steps.extract_version.outputs.version }}-sources.jar + asset_name: sputnik-${{ steps.extract_version.outputs.version }}-sources.jar + asset_content_type: application/java-archive + - name: Upload zip + id: upload-release-asset-zip + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: ./build/distributions/sputnik-${{ steps.extract_version.outputs.version }}.zip + asset_name: sputnik-${{ steps.extract_version.outputs.version }}.zip + asset_content_type: application/zip + - name: Upload tar + id: upload-release-asset-tar + uses: actions/upload-release-asset@v1 + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + with: + upload_url: ${{ steps.create_release.outputs.upload_url }} + asset_path: ./build/distributions/sputnik-${{ steps.extract_version.outputs.version }}.tar + asset_name: sputnik-${{ steps.extract_version.outputs.version }}.tar + asset_content_type: application/tar diff --git a/build.gradle b/build.gradle index ec2bc56d..985720a0 100644 --- a/build.gradle +++ b/build.gradle @@ -34,7 +34,7 @@ configurations { } } -project.version = '2.3.1.1' //scmVersion.version +project.version = findProperty("version") ?: scmVersion.version sourceCompatibility = 1.8 targetCompatibility = 1.8 @@ -218,6 +218,32 @@ publishing { distribution = 'repo' } } + developers { + developer { + id = 'tomasz_kalkosinski' + name = 'Tomasz Kalkosinski' + } + developer { + id = 'marcin_cylke' + name = 'Marcin Cylke' + } + developer { + id = 'piotr_jagielski' + name = 'Piotr Jagielski' + } + developer { + id = 'karol_lassak' + name = 'Karol Lassak' + } + developer { + id = 'dominik_przybysz' + name = 'Dominik Przybysz' + } + developer { + id = 'henning_hoefer' + name = 'Henning Hoefer' + } + } } } } @@ -234,8 +260,6 @@ publishing { } signing { - def signingKey = System.getenv('SIGNING_KEY') - def signingPassword = System.getenv('SIGNING_PASSWORD') - useInMemoryPgpKeys(signingKey, signingPassword) + useInMemoryPgpKeys(System.getenv('SIGNING_PRIVATE_KEY'), System.getenv('SIGNING_PASSWORD')) sign publishing.publications.mavenJava }