installsub.in 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395
  1. #!/bin/bash
  2. MY_PATH="`dirname \"$0\"`" # relative
  3. # echo "1"$MY_PATH
  4. MY_PATH="`( cd \"$MY_PATH\" && pwd )`" # absolutized and normalized
  5. installType=@INSTALLSCRIPT_TYPE@
  6. echo 安装脚本模式: $installType
  7. curr_timestamp=`date "+%Y%m%d-%H%M%S.%3N"`
  8. lightdm_file=/etc/lightdm/lightdm.conf
  9. rvc_pkg_rvc=${MY_PATH}/rvc
  10. rvc_install_path_root="/opt"
  11. rvc_install_path_rvc_dir=${rvc_install_path_root}/rvc
  12. rvc_install_path_Run_dir=${rvc_install_path_root}/Run
  13. rvc_install_path_hardware_dir=${rvc_install_path_Run_dir}/hardwarecfg
  14. rvc_install_path_versions_dir=${rvc_install_path_Run_dir}/version
  15. res=0
  16. #设置开机自动登录用户(有做冗余判断)
  17. setup_autologin()
  18. {
  19. given_user=$1
  20. given_sudoers_file=$2
  21. ret=0
  22. if [ ! -f "$given_sudoers_file" ]; then
  23. echo "[Seat:*]" > $given_sudoers_file
  24. # echo "autologin-guest=false" >> $given_sudoers_file
  25. echo "autologin-user=$given_user" >> $given_sudoers_file
  26. echo "autologin-user-timeout=0" >> $given_sudoers_file
  27. fi
  28. if [ "$(grep -c "^\\s*autologin-user=${given_user}" $given_sudoers_file)" -gt 0 ]; then
  29. echo "[WARN] autologin-user is already setted in ^lightdm.conf^"
  30. else
  31. echo "[INFO] setting autologin-user in ^$given_sudoers_file^"
  32. #sed -i.bak -E "s|^#(autologin-user=).*|\\1$given_user|;s|^#(autologin-user-timeout=).*|\\0|" $given_sudoers_file
  33. sed -i "s/^\s*#\s*autologin-user=/autologin-user=/g;s/autologin-user=.*$/autologin-user=$given_user/g" $given_sudoers_file
  34. #sed -i "s/^#autologin-user=$/autologin-user=${given_user}/" $given_sudoers_file
  35. #sed -i "s/^#autologin-user-timeout=$/autologin-user-timeout=0/" $given_sudoers_file
  36. sed -i "s/^\s*#\s*autologin-user-timeout=/autologin-user-timeout=/g;s/autologin-user-timeout=.*$/autologin-user-timeout=0/g" $given_sudoers_file
  37. fi
  38. return $ret
  39. }
  40. #设置免密使用root权限(有做冗余判断)
  41. sudo_priviledge()
  42. {
  43. given_user=$1
  44. given_sudoers_file=$2
  45. if [ -e ${given_sudoers_file}.tmp -o "$(pidof visudo)" ]; then
  46. echo "[ERROR] ${given_sudoers_file} is working now, wait a little and then try again later"
  47. return 2
  48. fi
  49. #pkexec chmod 0440 /etc/sudoers
  50. ret=0
  51. echo "[INFO] to process editing sudoers file..."
  52. cp ${given_sudoers_file} ${given_sudoers_file}.tmp
  53. chmod 0640 ${given_sudoers_file}.tmp
  54. cat ${given_sudoers_file}.tmp | grep 'includedir /etc/sudoers.d' > /dev/null
  55. if [ $? = 0 ]; then
  56. echo "[INFO] '#includedir /etc/sudoers.d' already exists in /etc/sudoers file"
  57. else
  58. echo "#includedir /etc/sudoers.d" >> ${given_sudoers_file}.tmp
  59. ret=1
  60. fi
  61. if [ "`cat /etc/sudoers | grep ${given_user} | grep ALL=\(ALL\)`" != "" ]; then
  62. echo "[WARN]: sudoers file has been loaded up all(all) config"
  63. else
  64. new_entry="${given_user} ALL=(ALL) ALL"
  65. echo "${new_entry}" >> ${given_sudoers_file}.tmp
  66. ret=1
  67. fi
  68. if [ "`cat /etc/sudoers|grep ${given_user}|grep /opt/Run/version/v2`" != "" ]; then
  69. echo "[WARN]: sudoers file has been loaded up rvc config"
  70. else
  71. new_entry="${given_user} ALL=(ALL) NOPASSWD: ALL, NOPASSWD: /opt/Run/version/v2"
  72. echo "[INFO] update sudoers file with all no need password"
  73. echo "${new_entry}" >> ${given_sudoers_file}.tmp
  74. ret=1
  75. fi
  76. chmod 0440 ${given_sudoers_file}.tmp
  77. if visudo -c -f ${given_sudoers_file}.tmp ; then
  78. echo check syntax correct on ${given_sudoers_file}.tmp
  79. else
  80. echo "[ERROR] syntax check failed on file ${given_sudoers_file}"
  81. rm ${given_sudoers_file}.tmp
  82. #if [ -f "${given_sudoers_file}.backup" ]; then
  83. #fi
  84. return 3
  85. fi
  86. if [ $ret -eq 1 ]; then
  87. echo "[SUCCESS]: config file has been change !!"
  88. cp ${given_sudoers_file} ${given_sudoers_file}.backup
  89. mv ${given_sudoers_file}.tmp ${given_sudoers_file}
  90. ret=0
  91. else
  92. echo "[WARN]: config file not change"
  93. rm ${given_sudoers_file}.tmp
  94. ret=0
  95. fi
  96. return $ret
  97. }
  98. # check root priviledge
  99. if [ $(id -u) != 0 ]; then
  100. #红底白字
  101. echo -e "\033[41;37m [ERROR] === 该安装脚本需要以ROOT权限启动,请在命令行窗口添加sudo指令执行 'sudo bash $0',如果无法执行相关指令,请先确认系统已开启开发者模式 === \033[0m"
  102. timoutsecs=10
  103. for i in $(seq ${timoutsecs} -1 1)
  104. do
  105. echo [INFO] ${i}s 后退出当前执行脚本
  106. sleep 1
  107. done
  108. exit 1
  109. fi
  110. #生产环境要求先安装浏览器再执行安装
  111. if [ $installType -eq 1 ]; then
  112. if [ "`dpkg -l | grep org.deepin.browser | awk '{print $3}'`" == "" ]; then
  113. echo -e "\033[41;37m [ERROR] 未安装指定的浏览器,请至下载站点下载并安装UOS浏览器后再执行此安装脚本! \033[0m"
  114. exit 1
  115. fi
  116. fi
  117. echo "[INFO] 清理可视柜台相关进程……"
  118. chromium_pid=$(ps -aux | grep mod_chromium | grep sphost | awk 'NR==1{print $2}')
  119. echo "[DEBUG] chromium_pid=$chromium_pid"
  120. timoutsecs4chromium=5
  121. if [ "${chromium_pid}" != "" ]; then
  122. echo "[INFO] has mod_chromium pid to SIGTERM it and wait"
  123. sudo kill -s 15 ${chromium_pid}
  124. for i in $(seq ${timoutsecs4chromium} -1 1)
  125. do
  126. echo "[DEBUG] wait chrmoium process exit"
  127. sleep 1
  128. chromium_pid=$(ps -aux | grep mod_chromium | grep sphost | awk 'NR==1{print $2}')
  129. if [ "${chromium_pid}" == "" ]; then
  130. echo "[INFO] chrmoium process has been exit"
  131. break
  132. fi
  133. done
  134. fi
  135. killall -9 spshell > /dev/null 2>&1
  136. killall -9 sphost > /dev/null 2>&1
  137. killall -9 guardian > /dev/null 2>&1
  138. killall -9 uosbrowser > /dev/null 2>&1
  139. killall -9 browser > /dev/null 2>&1
  140. killall -s 9 `ps -aux | grep browser | awk '{print $2}'` > /dev/null 2>&1
  141. echo "[INFO] 清理可视柜台相关进程OK!"
  142. #获取当前登录的用户名称,这里可以考虑用另外一种优化的方法
  143. echo [INFO] 获取当前登录的用户名
  144. user1=$(ps -o user= -p $$ | awk '{print $1}')
  145. echo "[DEBUG] user1: $user1"
  146. user2=$(whoami)
  147. echo "[DEBUG] user2: $user2"
  148. rvc_user=$USER
  149. if [ -z "$rvc_user" -o "$rvc_user" = "root" ]; then
  150. users=$(cat /etc/passwd | awk -F: '$3>=500' | cut -f 1 -d :)
  151. echo "[DEBUG] user list: $users"
  152. cnt=0
  153. for var in $(echo ${users} | awk '{split($0,arr,",");for(i in arr) print arr[i]}')
  154. do
  155. if [ ${var} != 'nobody' -a ${var} != 'systemd-coredump' -a ${var} != 'liuwt' -a ${var} != 'deepin-anything-server' ]; then
  156. cnt=$((${cnt}+1))
  157. rvc_user=${var}
  158. fi
  159. done
  160. if [ $cnt -ne 1 ]; then
  161. echo "[WARN] too many users: $cnt"
  162. rvc_user=''
  163. else
  164. echo "[DEBUG] aim user: $rvc_user"
  165. fi
  166. fi
  167. #上保险,即另外一种优化的方法
  168. if [ -z "$rvc_user" -o "$rvc_user" = "root" ]; then
  169. name=$(whoami)
  170. pid=$(pgrep startdde)
  171. . <(xargs -0 bash -c 'printf "export %q\n" "$@"' -- </proc/$pid/environ)
  172. name=$(ps -o uname= -p "${pid}")
  173. echo "[DEBUG] new fetch name: $name"
  174. rvc_user=$name
  175. fi
  176. if [ -z "$rvc_user" ]; then
  177. echo -e "\033[41;37m [ERROR] 无法获取当前用户名称(用户名为空),退出程序 \033[0m"
  178. exit 1
  179. elif [ "$rvc_user" = "root" ]; then
  180. echo -e "\033[41;37m [ERROR] 无法获取当前用户名称(用户名无效),退出程序 \033[0m"
  181. exit 2
  182. fi
  183. echo [INFO] 获取当前登录的用户名OK! 用户名:$rvc_user
  184. # 如果版本中有root.ini,移除测试的root.ini文件
  185. if [ -f ${MY_PATH}/Run/hardwarecfg/root.ini ]; then
  186. sudo rm ${MY_PATH}/Run/hardwarecfg/root.ini
  187. fi
  188. if [ -d ${MY_PATH}/Run/runinfo ]; then
  189. sudo rm -rf ${MY_PATH}/Run/runinfo
  190. fi
  191. echo 【0/1】拷贝RVC目录...
  192. if [ ! -d $rvc_install_path_rvc_dir ]; then
  193. sudo mkdir -p ${rvc_install_path_rvc_dir}
  194. fi
  195. if [ ! -d $rvc_install_path_rvc_dir/adData ]; then
  196. sudo mkdir -p ${rvc_install_path_rvc_dir}/adData
  197. fi
  198. if [ ! -d $rvc_install_path_rvc_dir/Resources ]; then
  199. sudo mkdir -p ${rvc_install_path_rvc_dir}/Resources
  200. fi
  201. sudo cp -rf ${rvc_pkg_rvc}/adData/Audio ${rvc_install_path_rvc_dir}/adData > /dev/null 2>&1
  202. sudo cp -rf ${rvc_pkg_rvc}/Resources ${rvc_install_path_rvc_dir}
  203. echo 【1/1】拷贝RVC目录OK!
  204. echo 【1/2】拷贝终端版本,文件数量较多,部分终端拷贝时间比较长,请稍加等候......
  205. if [ ! -d $rvc_install_path_Run_dir ]; then
  206. sudo mkdir -p ${rvc_install_path_Run_dir}
  207. fi
  208. sudo cp -rf $MY_PATH/Run ${rvc_install_path_root}
  209. echo 【2/2】拷贝终端版本OK!
  210. echo [INFO] 赋予应用相关文件执行权限
  211. echo [DEBUG] rvc_install_path_rvc_dir=${rvc_install_path_rvc_dir}
  212. echo [DEBUG] ${rvc_install_path_root}/${rel_version_dir}
  213. sudo chmod 777 ${rvc_install_path_root}
  214. sudo chmod a+rw -R ${rvc_install_path_rvc_dir}
  215. sudo chmod a+rw -R ${rvc_install_path_hardware_dir}
  216. sudo chmod 777 -R ${rvc_install_path_root}/${rel_version_dir}
  217. sudo chmod 777 ${rvc_install_path_versions_dir}/spexplorer.sh > /dev/null 2>&1
  218. sudo chmod a+rw ${rvc_install_path_versions_dir}/active.txt
  219. sudo chmod a+rw ${rvc_install_path_versions_dir}
  220. sudo chmod a+rw ${rvc_install_path_Run_dir}
  221. echo [INFO] 赋予应用相关文件执行权限OK!
  222. echo 【2/3】拷贝系统桌面壁纸,用于后续安装
  223. papers_dir=/usr/share/wallpapers/deepin
  224. papers_bak_dir=/usr/share/wallpapers/deepin_bak
  225. WallpaperPath=${rvc_pkg_rvc}/Resources/WallPaper1920.png
  226. if [ -f "${papers_dir}/WallPaper1920.png" ]; then
  227. echo [DEBUG] 指定壁纸已存在系统目录
  228. WallpaperPath=${papers_dir}/WallPaper1920.png
  229. rm ${papers_dir}/WallPaper1280.png > /dev/null 2>&1
  230. else
  231. if [ ! -d $papers_bak_dir ]; then
  232. mkdir -p ${papers_bak_dir}
  233. cp $papers_dir/* $papers_bak_dir
  234. fi
  235. rm -rf $papers_dir/* > /dev/null 2>&1
  236. cp ${rvc_pkg_rvc}/Resources/WallPaper1920.png ${papers_dir}
  237. WallpaperPath=${papers_dir}/WallPaper1920.png
  238. fi
  239. echo [DEBUG] WallpaperPath=$WallpaperPath
  240. echo [WARN] 清理桌面文件内容
  241. rm -rf /home/$rvc_user/Desktop/* > /dev/null 2>&1
  242. echo [INFO] 清理桌面文件内容OK!
  243. echo 【3/3】拷贝系统桌面壁纸OK!
  244. echo 【3/4】设置可视柜台应用程序开机自启动
  245. echo [INFO] 设置用户免密使用ROOT权限
  246. sudoers_file=/etc/sudoers
  247. echo "[INFO] Going to add entry into /etc/sudoers file for user: $rvc_user"
  248. if [ ! -d '/etc/sudoers.d' ]; then
  249. mkidr /etc/sudoers.d
  250. chmod 750 /etc/sudoers.d
  251. fi
  252. sudo_priviledge ${rvc_user} ${sudoers_file}
  253. res=$?
  254. if [ $res -eq 0 ]; then
  255. echo [INFO] 设置用户免密使用ROOT权限OK!
  256. else
  257. echo -e "\033[41;37m [ERROR] 设置用户免密使用ROOT权限失败!! \033[0m"
  258. exit 1
  259. fi
  260. echo [INFO] 设置用户自动登录
  261. setup_autologin ${rvc_user} ${lightdm_file}
  262. res=$?
  263. if [ $res -eq 0 ]; then
  264. echo [INFO] 设置用户自动登录OK!
  265. else
  266. echo -e "\033[41;37m [ERROR] 设置用户自动登录失败!! \033[0m"
  267. exit 1
  268. fi
  269. echo [INFO] 设置应用自启动和桌面图标
  270. echo "[INFO] Copy application shortkeys to menu tools..."
  271. cp ${rvc_pkg_rvc}/Resources/spexplorerauto.desktop /usr/share/applications
  272. echo "[INFO] Active application icon autorun after boot..."
  273. cp ${rvc_pkg_rvc}/Resources/spexplorerauto.desktop /etc/xdg/autostart/
  274. echo "[INFO] Copy application icon to desktop..."
  275. cp ${rvc_pkg_rvc}/Resources/spexplorerauto.desktop /home/$rvc_user/Desktop
  276. echo 【4/4】设置可视柜台应用程序开机自启动OK!
  277. #去掉密钥环,之前出现过这种问题,统信指示移除该文件即可
  278. keyring_file=/home/$rvc_user/.local/share/keyrings/login.keyring
  279. if [ -f "$keyring_file" ]; then
  280. rm $keyring_file
  281. echo "[INFO] remove keyring file."
  282. fi
  283. browserDownURLDEV="http://99.12.23.78/uos/uosbrowser_5.3.52-1.zip"
  284. fileManagerURLDEV="http://99.12.23.78/uos/dde-file-manager-5.2.11.2-arm64_fixed.zip"
  285. launcherURLDEV="http://99.12.23.78/uos/dde-launcher_5.3.0.45_arm64.zip"
  286. browserDownURL=${browserDownURLDEV}
  287. #测试环境才生效,生产环境无法确认下载链接地址
  288. if [ $installType -eq 0 ]; then
  289. echo -e "\033[43;37m [WARN] 开发测试环境检测和安装UOS浏览器和输入法补丁 \033[0m"
  290. if [ "`dpkg -l | grep org.deepin.browser | awk '{print $3}'`" == "" ]; then
  291. echo "[WARN] 未安装最新的UOS浏览器,将自动下载安装UOS浏览器"
  292. echo 下载最新的UOS浏览器...
  293. rm -rf ${MY_PATH}/Tmp > /dev/null 2>&1
  294. mkdir -p ${MY_PATH}/Tmp > /dev/null 2>&1
  295. mkdir -p ${MY_PATH}/Tmp/Extra > /dev/null 2>&1
  296. wget -nv ${browserDownURL} -O ${MY_PATH}/Tmp/UOSBrowser.zip
  297. if [ $? -ne 0 ]; then
  298. echo "[WARN]下载最新的UOS浏览器失败"
  299. else
  300. echo "[DEBUG] 下载最新的UOS浏览器 完成!"
  301. unzip -q ${MY_PATH}/Tmp/UOSBrowser.zip -d ${MY_PATH}/Tmp/Extra
  302. chmod 777 -R ${MY_PATH}/Tmp/Extra
  303. sudo dpkg -i ${MY_PATH}/Tmp/Extra/**/*.deb
  304. fi
  305. rm -rf ${MY_PATH}/Tmp > /dev/null 2>&1
  306. else
  307. echo "[INFO] 已安装最新的UOS浏览器"
  308. fi
  309. if [ "`dpkg -l | grep libdde-file-manager`" != "" ]; then
  310. currentInstallVersion=$(dpkg -l | grep libdde-file-manager | awk '{print $3}')
  311. echo "[INFO] Current libdde-file-manager version: $currentInstallVersion"
  312. if [ "$currentInstallVersion" = "5.2.11.2-1" ]; then
  313. echo "[INFO] 已安装最新输入法补丁"
  314. else
  315. echo "[WARN] 未安装最新输入法补丁,将自动下载安装"
  316. echo "[DEBUG] 下载最新输入法补丁..."
  317. rm -rf ${MY_PATH}/Tmp > /dev/null 2>&1
  318. mkdir -p ${MY_PATH}/Tmp > /dev/null 2>&1
  319. mkdir -p ${MY_PATH}/Tmp/Extra > /dev/null 2>&1
  320. wget -nv ${fileManagerURLDEV} -O ${MY_PATH}/Tmp/SogouFileManager.zip
  321. if [ $? -ne 0 ]; then
  322. echo "[WARN]下载最新输入法补丁失败"
  323. else
  324. echo "[DEBUG] 下载最新输入法补丁 完成!"
  325. unzip -q ${MY_PATH}/Tmp/SogouFileManager.zip -d ${MY_PATH}/Tmp/Extra
  326. chmod 777 -R ${MY_PATH}/Tmp/Extra
  327. sudo dpkg -i ${MY_PATH}/Tmp/Extra/**/*.deb
  328. fi
  329. rm -rf ${MY_PATH}/Tmp > /dev/null 2>&1
  330. fi
  331. fi
  332. if [ "`dpkg -l | grep dde-launcher`" != "" ]; then
  333. currentInstallVersion=$(dpkg -l | grep dde-launcher | awk '{print $3}')
  334. echo "[INFO] Current dde-launcher version: $currentInstallVersion"
  335. if [ "$currentInstallVersion" = "5.3.0.45+203445.2-1" ]; then
  336. echo "[INFO] 已安装最新输入法补丁(文件启动器)"
  337. else
  338. echo "[WARN] 未安装最新输入法补丁(文件启动器),将自动下载安装"
  339. echo "[DEBUG] 下载最新输入法补丁(文件启动器)..."
  340. rm -rf ${MY_PATH}/Tmp > /dev/null 2>&1
  341. mkdir -p ${MY_PATH}/Tmp > /dev/null 2>&1
  342. mkdir -p ${MY_PATH}/Tmp/Extra > /dev/null 2>&1
  343. wget -nv ${launcherURLDEV} -O ${MY_PATH}/Tmp/SogouLauncherMng.zip
  344. if [ $? -ne 0 ]; then
  345. echo "[WARN]下载最新输入法补丁(文件启动器)失败"
  346. else
  347. echo "[DEBUG] 下载最新输入法补丁(文件启动器) 完成!"
  348. unzip -q ${MY_PATH}/Tmp/SogouLauncherMng.zip -d ${MY_PATH}/Tmp/Extra
  349. chmod 777 -R ${MY_PATH}/Tmp/Extra
  350. sudo dpkg -i ${MY_PATH}/Tmp/Extra/**/*.deb
  351. fi
  352. rm -rf ${MY_PATH}/Tmp > /dev/null 2>&1
  353. fi
  354. fi
  355. fi
  356. #执行完删除自身
  357. rm -f $0
  358. exit 0