forked from EC-CUBE/ec-cube
-
Notifications
You must be signed in to change notification settings - Fork 0
/
eccube_install.sh
265 lines (224 loc) · 7.86 KB
/
eccube_install.sh
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
#!/bin/sh
######################################################################
#
# EC-CUBE のインストールを行う shell スクリプト
#
#
# 処理内容
# 1. パーミッション変更
# 2. app/config以下に設定ファイルを生成
# 3. データベースの作成
# 4. データベーススキーマ生成・初期データ投入
# 5. app/cache以下をクリア
#
# 使い方
# Configurationの内容を自分の環境に併せて修正
# PostgreSQLの場合は、DBユーザーを予め作成しておいて
# > ./eccube_install.sh pgsql
# MySQLはMYSQLのRoot以外のユーザーで実行する場合は、128行目をコメントアウトして
# > ./eccube_install.sh mysql
# SQLiteの場合は、以下を実行
# > ./eccube_install.sh sqlite3
# composerを実行しない場合は, 第2引数に"none"を指定するとスキップできる
# > ./eccube_install.sh mysql none
#
# 開発コミュニティの関連スレッド
# http://xoops.ec-cube.net/modules/newbb/viewtopic.php?topic_id=4918&forum=14&post_id=23090#forumpost23090
#
#######################################################################
# ---------------------------------------------------------------------
# Constants
# ---------------------------------------------------------------------
BASE_DIR=${BASE_DIR:-$(cd $(dirname $0) && pwd)}
CONFIG_DIR="${BASE_DIR}/app/config/eccube"
DIST_DIR="${BASE_DIR}/src/Eccube/Resource/config"
SQL_DIR="${BASE_DIR}/src/Eccube/Resource/sql"
# config.yml
CONFIG_YML="${CONFIG_DIR}/config.yml"
CONFIG_YML_DIST="${DIST_DIR}/config.yml.dist"
# db.yml
DATABASE_YML="${CONFIG_DIR}/database.yml"
DATABASE_YML_DIST="${DIST_DIR}/database.yml.dist"
# mail.yml
MAIL_YML="${CONFIG_DIR}/mail.yml"
MAIL_YML_DIST="${DIST_DIR}/mail.yml.dist"
# path.yml
PATH_YML="${CONFIG_DIR}/path.yml"
PATH_YML_DIST="${DIST_DIR}/path.yml.dist"
# constant.yml
CONSTANT_YML="${CONFIG_DIR}/constant.yml"
CONSTANT_YML_DIST="${DIST_DIR}/constant.yml.dist"
# ---------------------------------------------------------------------
# Configuration
# ---------------------------------------------------------------------
export ADMIN_MAIL=${ADMIN_MAIL:-"admin@example.com"}
export SHOP_NAME=${SHOP_NAME:-"EC-CUBE SHOP"}
export ROOT_DIR=${BASE_DIR}
export ROOT_URLPATH=${ROOT_URLPATH:-"/ec-cube/html"}
export ROOT_PUBLIC_URLPATH=${ROOT_URLPATH}
export ADMIN_ROUTE=${ADMIN_ROUTE:-"admin"}
export USER_DATA_ROUTE=${USER_DATA_ROUTE:-"user_data"}
export TEMPLATE_CODE=${TEMPLATE_CODE:-"default"}
export FORCE_SSL=${FORCE_SSL:-"0"}
export ADMINPASS="f6b126507a5d00dbdbb0f326fe855ddf84facd57c5603ffdf7e08fbb46bd633c"
export AUTH_MAGIC="droucliuijeanamiundpnoufrouphudrastiokec"
export DBSERVER=${DBSERVER-"127.0.0.1"}
export DBNAME=${DBNAME:-"cube3_dev"}
export DBUSER=${DBUSER:-"cube3_dev_user"}
export DBPASS=${DBPASS:-"password"}
export MAIL_BACKEND=${MAILER_BACKEND:-"smtp"}
export MAIL_HOST=${MAIL_HOST:-"localhost"}
export MAIL_PORT=${MAIL_PORT:-"25"}
export MAIL_USER=${MAIL_USER:-""}
export MAIL_PASS=${MAIL_PASS:-""}
DBTYPE=$1;
GET_COMPOSER=$2;
case "${DBTYPE}" in
"pgsql" )
#-- DB Seting Postgres
PSQL=psql
PGUSER=postgres
export DBPORT=5432
export DBDRIVER=pdo_pgsql
;;
"mysql" )
#-- DB Seting MySQL
DBPASS=`echo $DBPASS | tr -d " "`
MYSQL=mysql
ROOTUSER=root
ROOTPASS=${DBPASS}
DBSERVER=${DBSERVER}
export DBPORT=3306
export DBDRIVER=pdo_mysql
;;
"sqlite3" )
#-- DB Seting sqlite3
SQLITE3=sqlite3
DATABASE_YML_DIST="${DIST_DIR}/database.yml.sqlite3.dist"
export DBPATH=${CONFIG_DIR}/eccube.db
export DBPORT=
export DBDRIVER=pdo_sqlite
;;
"sqlite3-in-memory" )
#-- DB Seting sqlite3
SQLITE3=sqlite3
DATABASE_YML_DIST="${DIST_DIR}/database.yml.sqlite3-in-memory.dist"
export DBDRIVER=pdo_sqlite
;;
* )
echo "argument is invaid."
echo ""
echo "Usage: $0 [mysql|pgsql]"
exit
;;
esac
# ---------------------------------------------------------------------
# Functions
# ---------------------------------------------------------------------
adjust_directory_permissions()
{
chmod -R go+w "./html"
chmod go+w "./app"
chmod -R go+w "./app/template"
chmod -R go+w "./app/cache"
chmod -R go+w "./app/config"
chmod go+w "./app/log"
chmod go+w "./app/Plugin"
}
get_optional_sql()
{
echo "INSERT INTO dtb_member (member_id, login_id, password, salt, work, del_flg, authority, creator_id, rank, update_date, create_date,name,department) VALUES (2, 'admin', '${ADMINPASS}', '${AUTH_MAGIC}', 1, 0, 0, 1, 1, current_timestamp, current_timestamp,'管理者','EC-CUBE SHOP');"
echo "INSERT INTO dtb_base_info (id, shop_name, email01, email02, email03, email04, update_date, option_product_tax_rule) VALUES (1, '${SHOP_NAME}', '${ADMIN_MAIL}', '${ADMIN_MAIL}', '${ADMIN_MAIL}', '${ADMIN_MAIL}', current_timestamp, 0);"
}
render_config_template()
{
printf "cat <<EOL\n`cat ${1}`\nEOL\n" | sh
}
# ---------------------------------------------------------------------
# Install
# ---------------------------------------------------------------------
# ---------------------------------
# Update Permissions
# ---------------------------------
echo "update permissions..."
adjust_directory_permissions
# ---------------------------------
# Create Configs
# ---------------------------------
echo "creating ${CONFIG_YML}"
render_config_template ${CONFIG_YML_DIST} > ${CONFIG_YML}
echo "eccube_install: 1" >> ${CONFIG_YML}
echo "creating ${DATABASE_YML}"
render_config_template ${DATABASE_YML_DIST} > ${DATABASE_YML}
echo "creating ${MAIL_YML}"
render_config_template ${MAIL_YML_DIST} > ${MAIL_YML}
echo "creating ${PATH_YML}"
render_config_template ${PATH_YML_DIST} > ${PATH_YML}
#echo "creating ${CONSTANT_YML}"
#echo "# overwrite or define new constant. " > ${CONSTANT_YML}
#echo "# see also ${CONSTANT_YML_DIST} " >> ${CONSTANT_YML}
# ---------------------------------
# Install Composer
# ---------------------------------
case "${GET_COMPOSER}" in
"none" )
echo "not get composer..."
;;
* )
echo "get composer..."
curl -sS https://getcomposer.org/installer | php
echo "install composer..."
php ./composer.phar install --dev --no-interaction
;;
esac
# ---------------------------------
# Setup Database
# ---------------------------------
case "${DBTYPE}" in
"pgsql" )
# PostgreSQL
echo "dropdb..."
${PSQL} -U ${PGUSER} -c "drop database ${DBNAME}"
echo "createdb..."
${PSQL} -U ${PGUSER} -c "create database ${DBNAME} owner ${DBUSER}"
echo "create table..."
./vendor/bin/doctrine orm:schema-tool:create || exit 1
echo "migration..."
php app/console migrations:migrate --no-interaction || exit 1
echo "execute optional SQL..."
get_optional_sql | ${PSQL} -U ${DBUSER} -q ${DBNAME} || exit 1
;;
"mysql" )
if [ -n ${DBPASS} ]; then
PASSOPT="--password=$DBPASS"
CONFIGPASS=$DBPASS
fi
# MySQL
echo "dropdb..."
${MYSQL} -u ${ROOTUSER} ${PASSOPT} -e "drop database \`${DBNAME}\`"
echo "createdb..."
${MYSQL} -u ${ROOTUSER} ${PASSOPT} -e "create database \`${DBNAME}\` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;"
#echo "grant user..."
${MYSQL} -u ${ROOTUSER} ${PASSOPT} -e "GRANT ALL ON \`${DBNAME}\`.* TO '${DBUSER}'@'%' IDENTIFIED BY '${DBPASS}'"
echo "create table..."
./vendor/bin/doctrine orm:schema-tool:create || exit 1
echo "migration..."
php app/console migrations:migrate --no-interaction || exit 1
echo "execute optional SQL..."
get_optional_sql | ${MYSQL} -u ${DBUSER} ${PASSOPT} ${DBNAME} || exit 1
;;
"sqlite3" )
# sqlite3
echo "removedb..."
rm -v ${DBPATH}
echo "create table..."
./vendor/bin/doctrine orm:schema-tool:create || exit 1
echo "migration..."
php app/console migrations:migrate --no-interaction || exit 1
echo "execute optional SQL..."
get_optional_sql | ${SQLITE3} ${DBPATH} || exit 1
;;
esac
# Application cache clear
php app/console cache:clear --all
echo "Finished Successful!"