Skip to content
Snippets Groups Projects
Select Git revision
  • master default protected
  • release/202005
  • release/202001
  • release/201912
  • release/windows-test/201910
  • release/201908
  • release/201906
  • release/201905
  • release/201904
  • release/201903
  • release/201902
  • release/201901
  • release/201812
  • release/201811
  • release/201808
  • wip/patches_poly_2017/cedryk_doucet/abderahmane_bouziane
  • releases/beta1
  • android/release_460
  • android/release_459
  • android/release_458
  • android/release_457
  • android/release_456
  • android/release_455
  • android/release_454
  • android/release_453
  • android/release_452
  • android/release_451
  • android/release_450
  • android/release_449
  • android/release_448
  • android/release_447
  • android/release_446
  • android/release_445
  • android/release_444
  • android/release_443
  • android/release_442
  • android/release_441
37 results

fdroidMergeRequest.sh

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    fdroidMergeRequest.sh 3.29 KiB
    #!/usr/bin/env bash
    
    # This script pull/clone a fdroiddata repository
    
    set -x # Get a more verbose output for Jenkins
    
    if [ $# -lt 4 ] ; then
        echo "Usage:"
        echo "1: commit"
        echo "2: versionName"
        echo "3: versionCode"
        echo "4: ndkVersion"
        echo "4: private gitlab.com access token (optional)"
        echo "e.g. ./fdroidMergeRequest.sh e5d0d7d2e625e2455fce3d041dd563c45ab9d4a9 20190123 146 r19c djlhsdKH345456DDGfo7"
        exit
    fi
    
    commit=$1
    versionName="$2"
    versionCode=$3
    ndkVersion=$4
    gitlabToken=$5
    
    if [ -d "fdroiddata" ]
    then
        echo "fdroiddata repository exists"
        git -C fdroiddata checkout master
        git -C fdroiddata pull --rebase
    else
        echo "fdroiddata repository does not exists"
        git clone git@gitlab.com:savoirfairelinux/fdroiddata.git
    fi
    
    git -C fdroiddata remote add upstream git@gitlab.com:fdroid/fdroiddata.git
    git -C fdroiddata fetch upstream || exit
    git -C fdroiddata status
    git -C fdroiddata checkout upstream/master
    git -C fdroiddata config user.name "savoirfairelinux"
    git -C fdroiddata config user.email mobile@savoirfairelinux.com
    
    METADATA_FOLDER=fdroiddata/metadata
    
    cp ${METADATA_FOLDER}/cx.ring.yml ${METADATA_FOLDER}/cx.ring.yml_
    
    head -n -11 ${METADATA_FOLDER}/cx.ring.yml_ > ${METADATA_FOLDER}/cx.ring.yml
    
    if [[ ${versionName} =~ ^[0-9]+$ ]]; then
       versionName="'${versionName}'"
    fi
    
    echo "  - versionName: ${versionName}
        versionCode: ${versionCode}
        commit: ${commit}
        timeout: 10800
        subdir: client-android/ring-android/app
        submodules: true
        sudo:
          - apt-get update || apt-get update
          - apt-get install -y -t testing swig
          - apt-get install -y -t stretch-backports-sloppy libarchive13
          - apt-get install -y -t stretch-backports cmake
        gradle:
          - noPush
        rm:
          - client-electron
          - client-gnome
          - client-ios
          - client-macosx
          - client-uwp
          - client-qt
          - plugins
          - docker
          - docs
          - lrc
          - packaging
          - scripts
        prebuild: \$ANDROID_HOME/tools/bin/sdkmanager 'platforms;android-30' 'build-tools;30.0.3'
        build:
          - cd ../..
          - export ANDROID_NDK_ROOT=\"\$ANDROID_NDK\"
          - export ANDROID_ABI=\"armeabi-v7a arm64-v8a x86_64\"
          - ./compile.sh --release --daemon
        ndk: ${ndkVersion}" >> ${METADATA_FOLDER}/cx.ring.yml
    
    
    tail -n 12 ${METADATA_FOLDER}/cx.ring.yml_ | head -n -2 >> ${METADATA_FOLDER}/cx.ring.yml
    
    echo "CurrentVersion: ${versionName}" >> ${METADATA_FOLDER}/cx.ring.yml
    echo "CurrentVersionCode: ${versionCode}" >> ${METADATA_FOLDER}/cx.ring.yml
    
    rm ${METADATA_FOLDER}/cx.ring.yml_
    
    releaseDate=`date +%Y%m`
    releaseBranch="release_${releaseDate}"
    
    git -C fdroiddata add metadata/cx.ring.yml
    git -C fdroiddata commit -s -m "Updates Jami to $versionName"
    git -C fdroiddata push origin HEAD:refs/heads/${releaseBranch} -f
    git -C fdroiddata status
    
    FDROID_METADATA_PROJECT_ID=36528
    SFL_METADATA_PROJECT_ID=10540147
    
    if [ $# -ge 4 ] ; then
        curl --request POST \
        --url https://gitlab.com/api/v4/projects/${SFL_METADATA_PROJECT_ID}/merge_requests \
        --header 'content-type: application/json' \
        --header "private-token: ${gitlabToken}" \
        --data "{
        \"id\": 1,
        \"title\": \"New Jami revision\",
        \"target_branch\": \"master\",
        \"source_branch\": \"${releaseBranch}\",
        \"target_project_id\": ${FDROID_METADATA_PROJECT_ID}
        }"
    fi