summaryrefslogtreecommitdiff
path: root/pkgs/build-support/php/builders/v2/hooks/php-script-utils.bash
blob: 83dce2e9715adfc42c3f2fc40a1ebc952b06f8e8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
# shellcheck shell=bash

declare -g version
declare -g -i composerStrictValidation="${composerStrictValidation:-0}"

setComposerRootVersion() {
  if [[ -n $version ]]; then
    echo -e "\e[32mSetting COMPOSER_ROOT_VERSION to $version\e[0m"
    export COMPOSER_ROOT_VERSION="$version"
  fi
}

setComposerEnvVariables() {
  echo -e "\e[32mSetting some required environment variables for Composer...\e[0m"
  export COMPOSER_MIRROR_PATH_REPOS=1
  export COMPOSER_HTACCESS_PROTECT=0
  export COMPOSER_FUND=0
  COMPOSER_VENDOR_DIR=$(composer config vendor-dir)
  export COMPOSER_VENDOR_DIR
}

checkComposerValidate() {
  command="composer validate --strict --quiet --no-interaction --no-check-all --no-check-lock"
  if ! $command; then
    echo
    echo -e "\e[31mERROR: composer files validation failed\e[0m"
    echo
    echo -e '\e[31mThe validation of the composer.json failed.\e[0m'
    echo -e '\e[31mMake sure that the file composer.json is valid.\e[0m'
    echo
    echo -e '\e[31mTo address the issue efficiently, follow one of these steps:\e[0m'
    echo -e '\e[31m  1. File an issue in the project'\''s issue tracker with detailed information, and apply any available remote patches as a temporary solution '\('with fetchpatch'\)'.\e[0m'
    echo -e '\e[31m  2. If an immediate fix is needed or if reporting upstream isn'\''t suitable, develop a temporary local patch.\e[0m'
    echo

    if [[ "${composerStrictValidation}" == "1" ]]; then
      echo
      echo -e '\e[33mThis check is blocking, set the attribute composerStrictValidation to false to make it not blocking.\e[0m'
      echo
      exit 1
    else
      echo
      echo -e '\e[33mThis check is not blocking, but it is recommended to fix the issue.\e[0m'
      echo
    fi
  fi

  command="composer validate --strict --no-ansi --no-interaction --quiet --no-check-all --check-lock"
  if ! $command; then
    echo
    echo -e "\e[31mERROR: composer files validation failed\e[0m"
    echo
    echo -e '\e[31mThe validation of the composer.json and composer.lock failed.\e[0m'
    echo -e '\e[31mMake sure that the file composer.lock is consistent with composer.json.\e[0m'
    echo
    echo -e '\e[31mThis often indicates an issue with the upstream project, which can typically be resolved by reporting the issue to the relevant project maintainers.\e[0m'
    echo
    echo -e '\e[31mTo address the issue efficiently, follow one of these steps:\e[0m'
    echo -e '\e[31m  1. File an issue in the project'\''s issue tracker with detailed information '\('run '\''composer update --lock --no-install'\'' to fix the issue'\)', and apply any available remote patches as a temporary solution with '\('with fetchpatch'\)'.\e[0m'
    echo -e '\e[31m  2. If an immediate fix is needed or if reporting upstream isn'\''t suitable, develop a temporary local patch.\e[0m'
    echo

    if [[ "${composerStrictValidation}" == "1" ]]; then
      echo
      echo -e '\e[33mThis check is blocking, set the attribute composerStrictValidation to false to make it not blocking.\e[0m'
      echo
      exit 1
    else
      echo
      echo -e '\e[33mThis check is not blocking, but it is recommended to fix the issue.\e[0m'
      echo
    fi
  fi
}