X-Git-Url: https://osm.etsi.org/gitweb/?a=blobdiff_plain;f=tools%2Flicense_scan.sh;h=b20bb0afb9002c8c8e5706a70ebf520f742de5f4;hb=ccabbe39368ab73645caa6ab469be795cae66df5;hp=f7a4ab7ed974259713480f9d3e98fe7233c51d9f;hpb=be2ed341e8f6a84b6bd27dba0d45da0dc0ab4fc3;p=osm%2Fdevops.git
diff --git a/tools/license_scan.sh b/tools/license_scan.sh
index f7a4ab7e..b20bb0af 100755
--- a/tools/license_scan.sh
+++ b/tools/license_scan.sh
@@ -1,3 +1,4 @@
+#!/bin/sh
#
# Copyright 2016 Telefónica Investigación y Desarrollo, S.A.U.
#
@@ -13,54 +14,34 @@
# See the License for the specific language governing permissions and
# limitations under the License.
#
-#!/bin/sh
-
-# Change log:
-# 1. Bug 722 : Jayant Madavi : JM00553988@techmahindra.com : Enhancement to use new fossology server. Had to change the variable name at # couple of places, while scanning the variable name was adding curl as a license.
-# 2.
-
-echo GERRIT BRANCH is $GERRIT_BRANCH
-dpkg -l wget &>/dev/null ||sudo apt-get install -y wget
-dpkg -l curl &>/dev/null ||sudo apt-get install -y curl
-#Curl can be used instead of wget:
-#curl -s -X POST -d @$file https://osm.etsi.org/fossology/?mod=agent_nomos_once
apache=0
nolicense=0
other=0
-
+exception_list="':(exclude)*.pdf' ':(exclude)*.png' ':(exclude)*.jpeg' ':(exclude)*.jpg' ':(exclude)*.gif' ':(exclude)*.json' ':(exclude)*.ico' ':(exclude)*.svg' ':(exclude)*.tiff'"
git fetch
-RE="FATAL: your file did not get passed through"
-
-for file in $(git diff --name-only origin/$GERRIT_BRANCH); do
+for file in $(echo ${exception_list} | xargs git diff --name-only origin/$GERRIT_BRANCH -- . ); do
+ license="No Apache license found"
if [ -f $file ]; then
if [ -s $file ]; then
- licnse=$(curl -s -X POST -H 'Accept: text' -H 'Cache-Control: no-cache' -H 'Connection: keep-alive' -H 'Content-Type: multipart/form-data' -H 'cache-control: no-cache' -F "file_input=@\"$file\"" -F 'showheader=1' https://fossology-osm.etsi.org/?mod=agent_nomos_once |grep "A one shot license analysis shows the following license(s) in file"|sed -n 's:.*\(.*\).*:\1:p' |xargs)
- result=$(echo $licnse | grep "$RE")
- if [ -n "$result" ]; then
- # possibly we have exceeded the post rate
- sleep 10
- licnse=$(curl -s -X POST -H 'Accept: text' -H 'Cache-Control: no-cache' -H 'Connection: keep-alive' -H 'Content-Type: multipart/form-data' -H 'cache-control: no-cache' -F "file_input=@\"$file\"" -F 'showheader=1' https://fossology-osm.etsi.org/?mod=agent_nomos_once |grep "A one shot license analysis shows the following license(s) in file"|sed -n 's:.*\(.*\).*:\1:p' |xargs)
+ if [ $(grep -c "http://www.apache.org/licenses/LICENSE-2.0" $file) -ge 1 ] ; then
+ license="Apache-2.0"
fi
- else
- licnse="No_license_found"
fi
else
- licnse="DELETED"
+ license="DELETED"
fi
- echo "$file $licnse"
- case "$licnse" in
+ echo "$file $license"
+ case "$license" in
"Apache-2.0")
apache=$((apache + 1))
;;
- "No_license_found")
+ No*)
nolicense=$((nolicense + 1))
;;
"DELETED")
;;
- "FATAL:*")
- ;;
*)
echo "BAD LICENSE ON FILE $file"
other=$((other + 1))
@@ -68,13 +49,10 @@ for file in $(git diff --name-only origin/$GERRIT_BRANCH); do
esac
done
-if [ $other -gt 0 ]; then
- echo "FATAL: Non-apache licenses detected"
- exit 2
-fi
if [ $nolicense -gt 0 ]; then
- echo "WARNING: Unlicensed files found"
+ echo "FATAL: Files without apache license found"
+ exit 2
fi
exit 0