-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathsetup-docker.sh
More file actions
executable file
·236 lines (206 loc) · 7.8 KB
/
Copy pathsetup-docker.sh
File metadata and controls
executable file
·236 lines (206 loc) · 7.8 KB
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
#!/bin/bash
echo "Choose the CMS (numbers):"
select CMS_TYPE in "sitecore" "contentful" "wordpress" "aem" "drupal"; do
case $CMS_TYPE in
sitecore)
EXAMPLE_FILE="sitecore.zip"
break
;;
contentful)
EXAMPLE_FILE="contentful.json"
break
;;
wordpress)
EXAMPLE_FILE="wordpress.xml"
break
;;
aem)
EXAMPLE_FILE="aem_data_structure"
break
;;
drupal)
EXAMPLE_FILE="drupal.sql"
break
;;
*)
echo "Invalid option. Please select 1, 2, 3, 4, or 5."
;;
esac
done
ENV_PATH="./upload-api/.env"
set_env_var() {
VAR_NAME="$1"
VAR_VALUE="$2"
# Create directory if it doesn't exist
mkdir -p "$(dirname "$ENV_PATH")"
if grep -q "^${VAR_NAME}=" "$ENV_PATH" 2>/dev/null; then
# Update existing variable - escape special characters for sed
ESCAPED_VALUE=$(printf '%s\n' "$VAR_VALUE" | sed 's/[[\.*^$()+?{|&]/\\&/g')
sed -i.bak "s|^${VAR_NAME}=.*|${VAR_NAME}=${ESCAPED_VALUE}|" "$ENV_PATH"
rm -f "$ENV_PATH.bak"
else
# Append new variable
echo "${VAR_NAME}=${VAR_VALUE}" >> "$ENV_PATH"
fi
}
# Drupal uses MySQL connection instead of a data file
if [[ "$CMS_TYPE" == "drupal" ]]; then
echo ""
echo "Drupal uses a MySQL database connection. Please provide your database details:"
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
read -rp "MySQL Host [host.docker.internal] (use this when MySQL runs on your Mac/PC, not inside Docker): " MYSQL_HOST
MYSQL_HOST="${MYSQL_HOST:-host.docker.internal}"
read -rp "MySQL User: " MYSQL_USER
read -rsp "MySQL Password: " MYSQL_PASSWORD
echo ""
read -rp "MySQL Database: " MYSQL_DATABASE
read -rp "MySQL Port [3306]: " MYSQL_PORT
MYSQL_PORT="${MYSQL_PORT:-3306}"
echo ""
echo "Drupal assets configuration (for resolving media/file URLs):"
read -rp "Assets Base URL (e.g. https://example.com): " DRUPAL_ASSETS_BASE_URL
read -rp "Assets Public Path (e.g. sites/default/files): " DRUPAL_ASSETS_PUBLIC_PATH
# Drupal doesn't mount a data file; use a placeholder for Docker volume
ORIGINAL_PATH="$(pwd)"
DOCKER_MOUNT_PATH="$(pwd)"
CONTAINER_PATH="/data/drupal"
CMS_LOCAL_PATH="sql"
export CMS_TYPE
export CMS_DATA_PATH="$ORIGINAL_PATH"
export CONTAINER_PATH
export CMS_LOCAL_PATH
export MYSQL_HOST
export MYSQL_USER
export MYSQL_PASSWORD
export MYSQL_DATABASE
export MYSQL_PORT
export DRUPAL_ASSETS_BASE_URL
export DRUPAL_ASSETS_PUBLIC_PATH
set_env_var "CMS_TYPE" "$CMS_TYPE"
set_env_var "CMS_DATA_PATH" "$ORIGINAL_PATH"
set_env_var "DOCKER_MOUNT_PATH" "$DOCKER_MOUNT_PATH"
set_env_var "CONTAINER_PATH" "$CONTAINER_PATH"
set_env_var "CMS_LOCAL_PATH" "$CMS_LOCAL_PATH"
set_env_var "NODE_BACKEND_API" "http://migration-api:5001"
set_env_var "MYSQL_HOST" "$MYSQL_HOST"
set_env_var "MYSQL_USER" "$MYSQL_USER"
set_env_var "MYSQL_PASSWORD" "$MYSQL_PASSWORD"
set_env_var "MYSQL_DATABASE" "$MYSQL_DATABASE"
set_env_var "MYSQL_PORT" "$MYSQL_PORT"
set_env_var "DRUPAL_ASSETS_BASE_URL" "$DRUPAL_ASSETS_BASE_URL"
set_env_var "DRUPAL_ASSETS_PUBLIC_PATH" "$DRUPAL_ASSETS_PUBLIC_PATH"
else
# Non-Drupal CMS types: prompt for data file/folder path
echo "Enter the path to your $CMS_TYPE data:"
if [[ "$CMS_TYPE" == "aem" ]]; then
echo "(Path should contain a 'templates' folder with JSON files, or provide direct path to templates folder)"
fi
read -r CMS_DATA_PATH
# Store original path for Docker (Windows paths work with Docker Desktop)
ORIGINAL_PATH="$CMS_DATA_PATH"
DOCKER_MOUNT_PATH="$CMS_DATA_PATH" # Path to mount in Docker
# Convert Windows path to Unix format for Git Bash file operations ONLY
UNIX_PATH="$CMS_DATA_PATH"
if [[ "$CMS_DATA_PATH" =~ ^[A-Za-z]:\\ ]]; then
UNIX_PATH=$(echo "$CMS_DATA_PATH" | sed 's/\\/\//g')
UNIX_PATH=$(echo "$UNIX_PATH" | sed 's/^\([A-Za-z]\):/\/\L\1/')
fi
# Check if file/directory exists using the converted path
if [[ "$CMS_TYPE" == "aem" ]]; then
if [ ! -d "$UNIX_PATH" ]; then
echo "❌ Directory does not exist: $UNIX_PATH"
echo "Please provide the path to your AEM data structure folder"
exit 1
fi
if [[ "$(basename "$UNIX_PATH")" == "templates" ]]; then
TEMPLATES_PATH="$UNIX_PATH"
UNIX_MOUNT_PATH="$(dirname "$UNIX_PATH")"
DOCKER_MOUNT_PATH="$(dirname "$ORIGINAL_PATH")"
echo "ℹ️ Detected direct templates path, using parent folder for Docker mounting"
else
TEMPLATES_PATH="$UNIX_PATH/templates"
UNIX_MOUNT_PATH="$UNIX_PATH"
if [ ! -d "$TEMPLATES_PATH" ]; then
echo "❌ 'templates' folder not found in: $UNIX_PATH"
echo "Expected structure: your-folder/templates/*.json"
echo "Or provide the direct path to the templates folder"
exit 1
fi
fi
JSON_COUNT=$(find "$TEMPLATES_PATH" -maxdepth 1 -name "*.json" -type f 2>/dev/null | wc -l)
if [ "$JSON_COUNT" -eq 0 ]; then
echo "❌ No JSON files found in templates folder: $TEMPLATES_PATH"
echo "Please ensure your templates folder contains template JSON files"
exit 1
fi
echo "✅ Found $JSON_COUNT JSON template file(s) in templates folder"
FILENAME=$(basename "$UNIX_MOUNT_PATH")
CONTAINER_PATH="/data/$FILENAME"
else
if [ ! -f "$UNIX_PATH" ]; then
echo "❌ File does not exist: $UNIX_PATH"
exit 1
fi
FILENAME=$(basename "$UNIX_PATH")
CONTAINER_PATH="/data/$FILENAME"
fi
export CMS_TYPE
export CMS_DATA_PATH="$ORIGINAL_PATH"
export CONTAINER_PATH
set_env_var "CMS_TYPE" "$CMS_TYPE"
set_env_var "CMS_DATA_PATH" "$ORIGINAL_PATH"
set_env_var "DOCKER_MOUNT_PATH" "$DOCKER_MOUNT_PATH"
set_env_var "CONTAINER_PATH" "$CONTAINER_PATH"
set_env_var "NODE_BACKEND_API" "http://migration-api:5001"
# Set AEM-specific environment variables
if [[ "$CMS_TYPE" == "aem" ]]; then
set_env_var "AEM_TEMPLATES_DIR" "templates"
echo "ℹ️ Set AEM_TEMPLATES_DIR to: templates"
fi
fi
# Check for app.json (required by API for org + OAuth; mounted into the API container)
if [ ! -f "app.json" ]; then
echo "❌ app.json not found in the repository root."
echo " Run your Contentstack / OAuth setup so app.json exists, then retry Docker."
exit 1
fi
# Check if docker-compose.yml exists before running
if [ ! -f "docker-compose.yml" ]; then
echo "❌ docker-compose.yml not found in current directory"
echo "Current directory: $(pwd)"
echo "Available files:"
ls -la
exit 1
fi
# Check if Docker is running
if ! docker info > /dev/null 2>&1; then
echo ""
echo "❌ Docker is not running!"
echo "Please start Docker Desktop and try again."
exit 1
fi
echo ""
echo "✅ Starting Docker Compose with the following configuration:"
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo "CMS_TYPE: $CMS_TYPE"
if [[ "$CMS_TYPE" == "drupal" ]]; then
echo "MySQL Host: $MYSQL_HOST"
echo "MySQL User: $MYSQL_USER"
echo "MySQL Database: $MYSQL_DATABASE"
echo "MySQL Port: $MYSQL_PORT"
echo "Assets Base URL: $DRUPAL_ASSETS_BASE_URL"
echo "Assets Public Path: $DRUPAL_ASSETS_PUBLIC_PATH"
elif [[ "$CMS_TYPE" == "aem" ]]; then
echo "CMS_DATA_PATH: $ORIGINAL_PATH"
echo "DOCKER_MOUNT_PATH: $DOCKER_MOUNT_PATH"
echo "CONTAINER_PATH: $CONTAINER_PATH"
echo "Templates accessible at: $CONTAINER_PATH/templates"
else
echo "CMS_DATA_PATH: $ORIGINAL_PATH"
echo "CONTAINER_PATH: $CONTAINER_PATH"
fi
echo "━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━"
echo ""
# Export for docker-compose
export DOCKER_MOUNT_PATH
MSYS_NO_PATHCONV=1 docker compose up --build