--- kind: pipeline type: docker name: default steps: - name: build image: alpine:latest environment: PACKAGE_BASENAME: igmpgen_linux_amd64 commands: - apk update - apk add cmake gcc g++ libnet libnet-dev debian-devscripts rpm make - cmake -S . -B _build - cmake --build _build - make -C _build/ package - mkdir -p /_cache/bin /_cache/packages - cp -r _build/igmpgen /_cache/bin/$PACKAGE_BASENAME - ls -l _build - _build/igmpgen --help #- cp -r _build/igmpgen /_cache/bin/$PACKAGE_BASENAME volumes: - name: cache path: /_cache - name: publish:tag image: alpine environment: PACKAGE_UPLOAD_URL: https://code.apps.glenux.net/api/v1/packages/glenux/generic/igmpgen RELEASES_URL: https://code.apps.glenux.net/api/v1/repos/glenux/igmpgen/releases PACKAGE_BASENAME: igmpgen_linux_amd64 RELEASE_UPLOAD_TOKEN: from_secret: RELEASE_UPLOAD_TOKEN PACKAGE_UPLOAD_TOKEN: from_secret: PACKAGE_UPLOAD_TOKEN when: ref: include: - refs/tags/** volumes: - name: cache path: /_cache commands: - apk add --update --no-cache curl jq - env |grep DRONE - | curl -H "Authorization: token $PACKAGE_UPLOAD_TOKEN" \ --upload-file "/_cache/bin/$PACKAGE_BASENAME" \ "$PACKAGE_UPLOAD_URL/$DRONE_TAG/$PACKAGE_BASENAME" - | set -x curl -X POST \ -H "Authorization: token $RELEASE_UPLOAD_TOKEN" \ -H 'accept: application/json' \ -H 'Content-Type: application/json' \ -d "{\"body\": \"DRAFT\", \"draft\": true, \"name\": \"$DRONE_TAG - DRAFT\", \"prerelease\": false, \"tag_name\": \"$DRONE_TAG\", \"target_commitish\": \"$DRONE_COMMIT_SHA\"}" \ "$RELEASES_URL" - | curl -X 'GET' \ -H 'accept: application/json' \ "$RELEASES_URL/tags/$DRONE_TAG" - | TAG_ID="$(curl -X 'GET' \ -H 'accept: application/json' \ "$RELEASES_URL/tags/$DRONE_TAG" | jq -r .id)" echo "TAG_ID=$TAG_ID" - | set -x curl -X POST \ -H "Authorization: token $RELEASE_UPLOAD_TOKEN" \ -H "accept: application/json" \ -H "Content-Type: multipart/form-data" \ -F "attachment=@/_cache/bin/$PACKAGE_BASENAME" \ "$RELEASES_URL/$TAG_ID/assets?name=$PACKAGE_BASENAME" services: - name: docker image: docker:dind privileged: true volumes: - name: dockersock path: /var/run volumes: - name: cache temp: {} - name: dockersock temp: {} #