| #!/usr/bin/env bash |
| |
| # |
| # Licensed to the Apache Software Foundation (ASF) under one or more |
| # contributor license agreements. See the NOTICE file distributed with |
| # this work for additional information regarding copyright ownership. |
| # The ASF licenses this file to You under the Apache License, Version 2.0 |
| # (the "License"); you may not use this file except in compliance with |
| # the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| |
| set -o pipefail |
| set -e |
| set -x |
| |
| SKIP_GPG=${SKIP_GPG:-false} |
| |
| exit_with_usage() { |
| local NAME=$(basename $0) |
| cat << EOF |
| Usage: $NAME <source|binary> |
| |
| Top level targets are: |
| source: Create source release tarball |
| binary: Create binary release tarball |
| |
| All other inputs are environment variables: |
| |
| SKIP_GPG - (optional) Default false |
| EOF |
| exit 1 |
| } |
| |
| PROJECT_DIR="$(cd "$(dirname "$0")"/..; pwd)" |
| RELEASE_DIR="${PROJECT_DIR}/tmp" |
| |
| RELEASE_VERSION=$(grep 'uniffle-parent' "${PROJECT_DIR}/pom.xml" -C 3 |grep 'version' \ |
| | head -n 1 \ |
| | sed 's/<\/*version>//g' \ |
| | sed 's/ //g') |
| |
| SHASUM="sha512sum" |
| if [ "$(uname)" == "Darwin" ]; then |
| SHASUM="shasum -a 512" |
| fi |
| |
| package_source() { |
| SRC_TGZ_FILE="apache-uniffle-${RELEASE_VERSION}-incubating-src.tar.gz" |
| SRC_TGZ="${RELEASE_DIR}/${SRC_TGZ_FILE}" |
| |
| mkdir -p "${RELEASE_DIR}" |
| rm -f "${SRC_TGZ}*" |
| |
| echo "Creating source release tarball ${SRC_TGZ_FILE}" |
| |
| git archive --prefix="apache-uniffle-${RELEASE_VERSION}-incubating-src/" -o "${SRC_TGZ}" HEAD |
| |
| if [ "$SKIP_GPG" == "false" ] ; then |
| gpg --armor --detach-sig "${SRC_TGZ}" |
| fi |
| (cd "${RELEASE_DIR}" && $SHASUM "${SRC_TGZ_FILE}" > "${SRC_TGZ_FILE}.sha512") |
| } |
| |
| package_binary() { |
| BIN_TGZ_FILE="apache-uniffle-${RELEASE_VERSION}-incubating-bin.tar.gz" |
| BIN_TGZ="${RELEASE_DIR}/${BIN_TGZ_FILE}" |
| |
| mkdir -p "${RELEASE_DIR}" |
| rm -f "${BIN_TGZ}*" |
| |
| echo "Creating binary release tarball ${BIN_TGZ_FILE}" |
| |
| ${PROJECT_DIR}/build_distribution.sh |
| |
| BIN_ORIGIN_NAME="rss-${RELEASE_VERSION}-hadoop2.8.tgz" |
| BIN_DIR_NAME="rss-${RELEASE_VERSION}-hadoop2.8" |
| tar -zxf $BIN_ORIGIN_NAME |
| cp "${PROJECT_DIR}/LICENSE-binary" "${BIN_DIR_NAME}/LICENSE" |
| cp "${PROJECT_DIR}/NOTICE-binary" "${BIN_DIR_NAME}/NOTICE" |
| cp "${PROJECT_DIR}/DISCLAIMER-WIP" ${BIN_DIR_NAME} |
| cp -r "${PROJECT_DIR}/licenses-binary" "${BIN_DIR_NAME}/licenses" |
| tar -zcf $BIN_TGZ_FILE $BIN_DIR_NAME |
| |
| cp $BIN_TGZ_FILE $RELEASE_DIR |
| |
| if [ "$SKIP_GPG" == "false" ] ; then |
| gpg --armor --detach-sig "${BIN_TGZ}" |
| fi |
| (cd "${RELEASE_DIR}" && $SHASUM "${BIN_TGZ_FILE}" > "${BIN_TGZ_FILE}.sha512") |
| } |
| |
| if [[ "$1" == "source" ]]; then |
| package_source |
| exit 0 |
| fi |
| |
| if [[ "$1" == "binary" ]]; then |
| package_binary |
| exit 0 |
| fi |
| |
| exit_with_usage |