Skip to content

Publish to Maven Central #30

Publish to Maven Central

Publish to Maven Central #30

Workflow file for this run

name: Java CI
on: [push]
jobs:
build_faiss:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@master
with:
submodules: true
- uses: whoan/docker-build-with-cache-action@v5
with:
username: ${{ github.actor }}
password: "${{ secrets.GITHUB_TOKEN }}"
registry: docker.pkg.github.com
#or
#registry: ghcr.io
image_name: jfaiss-cpu
dockerfile: Dockerfile
# - name: Run the docker image
# uses: ./.github/actions
# - name: Debugging with tmate
# uses: mxschmitt/action-tmate@v3
# - run: docker image ls
- run: docker run -v "/home/runner/work/jfaiss-cpu/jfaiss-cpu":"/github/workspace" docker.pkg.github.com/criteo/jfaiss-cpu/jfaiss-cpu
- uses: actions/upload-artifact@v4
with:
name: faiss_JNI_and_SO
path: build
build:
needs: build_faiss
runs-on: ubuntu-latest
name: Build jfaiss-cpu.jar, pack it with faiss.so, and publish it to Maven Central
steps:
- name: Checkout
uses: actions/checkout@v2
- name: Read GPG private key
run: echo -ne "$GPG_PRIVATE_KEY" | base64 --decode > $RUNNER_TEMP/key.asc
env:
GPG_PRIVATE_KEY: ${{ secrets.MAVEN_SECRING_GPG_BASE64 }}
- name: Download build artifacts
uses: actions/download-artifact@v4
with:
name: faiss_JNI_and_SO
path: build_copy
- name: Move build artifacts
run: |
rm -rf src/main/java/com/vectorsearch/faiss/swig
cp -r build_copy/java/com/vectorsearch/faiss/swig src/main/java/com/vectorsearch/faiss/swig
rm -rf src/main/resources
cp -r build_copy/resources src/main/resources
- name: Set version
id: version
run: |
VERSION="2.1.0-$(git rev-parse --short HEAD)"
mvn -B versions:set -DnewVersion=$VERSION
echo "::set-output name=version::$VERSION"
- name: Set up Maven Central Repository
uses: warrenseine/setup-java@v1
env:
ACTIONS_ALLOW_UNSECURE_COMMANDS: true
with:
java-version: "1.8.0"
java-package: jdk
architecture: x64
server-id: ossrh
server-username: MAVEN_USERNAME
server-password: MAVEN_PASSWORD
gpg-private-key-path: ${{ runner.temp }}/key.asc
gpg-passphrase: MAVEN_GPG_PASSPHRASE
- name: Clean GPG private key
if: ${{ always() }}
run: rm -f $RUNNER_TEMP/key.asc
- name: Publish to the Maven Central Repository
run: mvn -B -DskipTests -P deploy deploy
env:
MAVEN_USERNAME: ${{ secrets.SONATYPE_USERNAME }}
MAVEN_PASSWORD: ${{ secrets.SONATYPE_PASSWORD }}
MAVEN_GPG_PASSPHRASE: ${{ secrets.MAVEN_SECRING_PASSWORD }}