-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathpublish.sh
181 lines (144 loc) · 5.26 KB
/
publish.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
#!/bin/bash
# Function to check the last command for errors
check_last_command() {
if [ $? -ne 0 ]; then
echo "An error occurred. Exiting."
exit 1
fi
}
# Ensure GITHUB_TOKEN is set
if [ -z "$GITHUB_TOKEN" ]; then
echo "GITHUB_TOKEN is not set. Please set it and try again."
exit 1
fi
# Ensure jq is installed
if ! command -v jq &> /dev/null; then
echo "jq could not be found. Please install jq and try again."
exit 1
fi
# Set your repository information
GITHUB_USER="mernjs"
REPO_NAME="create-mern-app"
# # Step 1: Run the sh-cleanup-projects.sh script to clean up before creating the zip file for projects
# echo "Ensuring src/app/sh-cleanup-projects.sh is executable..."
# chmod +x src/app/sh-cleanup-projects.sh
# check_last_command
# echo "Running src/app/sh-cleanup-projects.sh to clean up..."
# (cd src/app && sh sh-cleanup-projects.sh)
# check_last_command
# # Step 2: Run the sh-zip-projects.sh script to create the zip file for projects
# echo "Ensuring src/app/sh-zip-projects.sh is executable..."
# chmod +x src/app/sh-zip-projects.sh
# check_last_command
# echo "Running src/app/sh-zip-projects.sh to create the zip file..."
# (cd src/app && sh sh-zip-projects.sh)
# check_last_command
# # Step 3: Run the sh-cleanup-projects.sh script to clean up before creating the zip file for libraries
# echo "Ensuring src/library/sh-cleanup-projects.sh is executable..."
# chmod +x src/library/sh-cleanup-projects.sh
# check_last_command
# echo "Running src/library/sh-cleanup-projects.sh to clean up..."
# (cd src/library && sh sh-cleanup-projects.sh)
# check_last_command
# # Step 4: Run the sh-zip-projects.sh script to create the zip file for libraries
# echo "Ensuring src/library/sh-zip-projects.sh is executable..."
# chmod +x src/library/sh-zip-projects.sh
# check_last_command
# echo "Running src/library/sh-zip-projects.sh to create the zip file..."
# (cd src/library && sh sh-zip-projects.sh)
# check_last_command
# Step 5: Navigate to the package directory
echo "Navigating to package directory 'packages/create-mernjs-app'..."
cd templates/packages/create-mernjs-app
check_last_command
# Confirm package.json exists
PACKAGE_JSON_PATH="package.json"
if [ ! -f "$PACKAGE_JSON_PATH" ]; then
echo "package.json not found in the directory $(pwd). Exiting."
exit 1
fi
# Step 6: Bump the version (patch, minor, or major)
# Update the version here as per your need
echo "Updating the package version..."
NEW_VERSION=$(npm version patch) # Use npm version minor or npm version major as needed
check_last_command
# Extract the new version tag
NEW_VERSION_TAG=$(echo $NEW_VERSION | tr -d 'v')
# Step 7: Add all changes and commit
echo "Adding all changes..."
git add .
check_last_command
echo "Committing changes with message 'Y2024'..."
git commit -am "Y2024"
check_last_command
# Step 8: Push changes to the master branch
echo "Pushing changes to the master branch..."
git push origin master
check_last_command
# Step 9: Get the latest commit ID
echo "Getting the latest commit ID..."
LATEST_COMMIT_ID=$(git rev-parse HEAD)
check_last_command
echo "Latest commit ID is $LATEST_COMMIT_ID"
# Step 10: Update the commit ID in package.json
echo "Updating commit ID in $PACKAGE_JSON_PATH..."
jq --arg commit_id "$LATEST_COMMIT_ID" '.dependencies.mernjs |= "github:mernjs/create-mern-app#" + $commit_id' $PACKAGE_JSON_PATH > tmp.$$.json && mv tmp.$$.json $PACKAGE_JSON_PATH
check_last_command
# Debug: Check if the jq command worked
echo "Checking if the commit ID was updated correctly in package.json..."
grep "github:mernjs/create-mern-app#$LATEST_COMMIT_ID" $PACKAGE_JSON_PATH
check_last_command
# Step 11: Add all changes and commit
echo "Adding all changes..."
git add .
check_last_command
echo "Committing changes with message 'Y2024'..."
git commit -am "Y2024"
check_last_command
# Step 12: Push changes to the master branch
echo "Pushing changes to the master branch..."
git push origin master
check_last_command
# Step 13: Ensure you are logged into npm
echo "Checking npm login status..."
npm whoami &> /dev/null
if [ $? -ne 0 ]; then
echo "You are not logged in to npm. Please login:"
npm login
check_last_command
fi
# Step 14: Publish the package
echo "Publishing the package to npm..."
npm publish --access public
check_last_command
echo "Package published successfully!"
# Step 15: Create and push the version tag to GitHub
echo "Creating a new Git tag for the version $NEW_VERSION_TAG..."
git tag -a "v$NEW_VERSION_TAG" -m "Release version $NEW_VERSION_TAG"
check_last_command
echo "Pushing the tag to GitHub..."
git push origin "v$NEW_VERSION_TAG"
check_last_command
# Step 16: Push the version bump commit and tag to the remote repository
echo "Pushing version bump commit and tag to the remote repository..."
git push origin master --follow-tags
check_last_command
# Step 17: Create a release on GitHub
echo "Creating a release on GitHub..."
RELEASE_DATA=$(cat <<EOF
{
"tag_name": "v$NEW_VERSION_TAG",
"name": "v$NEW_VERSION_TAG",
"body": "Release version $NEW_VERSION_TAG",
"draft": false,
"prerelease": false
}
EOF
)
RELEASE_RESPONSE=$(curl -s -H "Authorization: token $GITHUB_TOKEN" \
-H "Content-Type: application/json" \
-d "$RELEASE_DATA" \
"https://api.github.com/repos/$GITHUB_USER/$REPO_NAME/releases")
check_last_command
echo "Release created on GitHub!"
echo "All done!"