Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add: android-sdk install scripts #16

Merged
merged 2 commits into from
Jul 28, 2019
Merged
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
38 changes: 38 additions & 0 deletions installers/android-sdk/installer.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
#!/bin/sh

YUM_CMD=$(which yum) # yum package manager for RHEL & CentOS
DNF_CMD=$(which dnf) # dnf package manager for new RHEL & CentOS
APT_GET_CMD=$(which apt-get) # apt package manager for Ubuntu & other Debian based distributions
PACMAN_CMD=$(which pacman) # pacman package manager for ArchLinux
APK_CMD=$(which apk) # apk package manager for Alpine

if [ ! -z $APT_GET_CMD ]; then
sudo apt-get update
sudo apt-get install android-sdk
elif [ ! -z $APK_CMD ]; then
sudo apk add --no-cache bash unzip libstdc++
mkdir -p /opt/android-sdk && cd /opt/android-sdk
&& wget -q http://dl.google.com/android/repository/tools_r27.0.0-linux.zip -O android-sdk-tools.zip
&& unzip -q android-sdk-tools.zip -d /opt/android-sdk
&& rm -f android-sdk-tools.zip
&& chmod 777 /opt/android-sdk/*
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

setting to 777 is dangerous, right?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Oh, yes sure. I just changed it to 755.

&& echo y | android update sdk -a --no-ui --filter build-tools-25.0.2
elif [ ! -z $PACMAN_CMD ]; then
sudo pacman -S --needed base-devel git wget yajl
cd /tmp && git clone https://aur.archlinux.org/package-query.git
cd package-query/ && makepkg -si
cd /tmp/ && git clone https://aur.archlinux.org/yaourt.git
cd yaourt/ && makepkg si
yaourt -S android-sdk android-sdk-platform-tools android-sdk-build-tools
sudo touch /tmp/script.sh
cat <<EOF > /tmp/script.sh
export ANDROID_HOME=/opt/android-sdk
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We exporting these here is not permanent, right? I think we should be adding these to a permanent place, right?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

It will be permanent, I sourced the variable to the bash profile in the very next line

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is how we set the environment variables for Java, maybe we can do the same.

cat >> /etc/environment <<EOL
JAVA_HOME=/usr/lib/jvm/java-8-oracle
JRE_HOME=/usr/lib/jvm/java-8-oracle/jre
EOL

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@agentmilindu yes, I read about this. Linux requires direct changes to the environment file. However, that would mean logging in as sudo. We should run the entire script as sudo then.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

No, We'll put the sudo command where necessary, the user will be prompted to enter the password then and there.

export PATH=$PATH:$ANDROID_HOME/tools
export PATH=$PATH:$ANDROID_HOME/platform-tools
EOF
source /tmp/script.sh
sudo rm /tmp/script.sh
else
echo "Couldn't install package"
exit 1;
fi