@striae-org/striae 5.2.1 → 5.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (117) hide show
  1. package/.env.example +2 -10
  2. package/README.md +5 -46
  3. package/app/components/actions/case-export/core-export.ts +5 -174
  4. package/app/components/actions/case-export/download-handlers.ts +84 -751
  5. package/app/components/actions/case-export/index.ts +6 -30
  6. package/app/components/actions/case-export/metadata-helpers.ts +0 -78
  7. package/app/components/actions/case-export/types-constants.ts +0 -43
  8. package/app/components/actions/case-import/confirmation-import.ts +75 -36
  9. package/app/components/actions/case-import/confirmation-package.ts +68 -1
  10. package/app/components/actions/case-import/index.ts +1 -1
  11. package/app/components/actions/case-import/orchestrator.ts +78 -53
  12. package/app/components/actions/case-import/zip-processing.ts +160 -330
  13. package/app/components/actions/generate-pdf.ts +3 -2
  14. package/app/components/audit/user-audit-viewer.tsx +0 -19
  15. package/app/components/audit/viewer/audit-viewer-header.tsx +0 -33
  16. package/app/components/navbar/case-modals/archive-case-modal.tsx +1 -1
  17. package/app/components/navbar/case-modals/export-case-modal.module.css +27 -0
  18. package/app/components/navbar/case-modals/export-case-modal.tsx +132 -0
  19. package/app/components/navbar/case-modals/export-confirmations-modal.module.css +24 -0
  20. package/app/components/navbar/case-modals/export-confirmations-modal.tsx +108 -0
  21. package/app/components/navbar/navbar.tsx +1 -1
  22. package/app/components/sidebar/case-import/case-import.module.css +35 -0
  23. package/app/components/sidebar/case-import/components/CasePreviewSection.tsx +51 -3
  24. package/app/components/sidebar/case-import/components/ConfirmationDialog.tsx +2 -4
  25. package/app/components/sidebar/case-import/components/ConfirmationPreviewSection.tsx +36 -5
  26. package/app/components/sidebar/case-import/hooks/useFilePreview.ts +5 -9
  27. package/app/components/sidebar/case-import/index.ts +1 -4
  28. package/app/components/sidebar/notes/class-details-shared.ts +2 -2
  29. package/app/components/toast/toast.module.css +36 -0
  30. package/app/components/toast/toast.tsx +6 -2
  31. package/app/components/user/manage-profile.tsx +4 -3
  32. package/app/config-example/config.json +1 -2
  33. package/app/root.tsx +0 -7
  34. package/app/routes/_index.tsx +1 -1
  35. package/app/routes/auth/login.example.tsx +22 -103
  36. package/app/routes/auth/login.tsx +22 -103
  37. package/app/routes/auth/route.ts +1 -1
  38. package/app/routes/striae/striae.tsx +117 -59
  39. package/app/services/firebase/index.ts +0 -3
  40. package/app/types/case.ts +1 -0
  41. package/app/types/export.ts +2 -2
  42. package/app/types/import.ts +10 -0
  43. package/app/utils/auth/index.ts +0 -1
  44. package/app/utils/data/permissions.ts +3 -2
  45. package/package.json +9 -16
  46. package/public/_headers +0 -4
  47. package/public/_routes.json +0 -1
  48. package/worker-configuration.d.ts +20 -17
  49. package/workers/audit-worker/src/audit-worker.example.ts +9 -806
  50. package/workers/audit-worker/src/config.ts +7 -0
  51. package/workers/audit-worker/src/crypto/data-at-rest.ts +410 -0
  52. package/workers/audit-worker/src/handlers/audit-routes.ts +125 -0
  53. package/workers/audit-worker/src/storage/audit-storage.ts +99 -0
  54. package/workers/audit-worker/src/types.ts +56 -0
  55. package/workers/audit-worker/worker-configuration.d.ts +1 -1
  56. package/workers/audit-worker/wrangler.jsonc.example +1 -1
  57. package/workers/data-worker/src/config.ts +11 -0
  58. package/workers/data-worker/src/data-worker.example.ts +21 -942
  59. package/workers/data-worker/src/handlers/decrypt-export.ts +118 -0
  60. package/workers/data-worker/src/handlers/signing.ts +174 -0
  61. package/workers/data-worker/src/handlers/storage-routes.ts +129 -0
  62. package/workers/data-worker/src/registry/key-registry.ts +368 -0
  63. package/workers/data-worker/src/types.ts +46 -0
  64. package/workers/data-worker/worker-configuration.d.ts +1 -1
  65. package/workers/data-worker/wrangler.jsonc.example +1 -1
  66. package/workers/image-worker/worker-configuration.d.ts +1 -1
  67. package/workers/image-worker/wrangler.jsonc.example +1 -1
  68. package/workers/pdf-worker/worker-configuration.d.ts +2 -3
  69. package/workers/pdf-worker/wrangler.jsonc.example +1 -1
  70. package/workers/user-worker/src/auth.ts +30 -0
  71. package/workers/user-worker/src/cleanup/account-deletion.ts +337 -0
  72. package/workers/user-worker/src/config.ts +4 -0
  73. package/workers/user-worker/src/encryption-utils.ts +25 -0
  74. package/workers/user-worker/src/firebase/admin.ts +152 -0
  75. package/workers/user-worker/src/handlers/user-routes.ts +242 -0
  76. package/workers/user-worker/src/registry/user-kv.ts +172 -0
  77. package/workers/user-worker/src/storage/user-records.ts +34 -0
  78. package/workers/user-worker/src/types.ts +106 -0
  79. package/workers/user-worker/src/user-worker.example.ts +18 -964
  80. package/workers/user-worker/worker-configuration.d.ts +4 -2
  81. package/workers/user-worker/wrangler.jsonc.example +12 -1
  82. package/wrangler.toml.example +1 -1
  83. package/app/components/actions/case-export/data-processing.ts +0 -223
  84. package/app/components/sidebar/case-export/case-export.module.css +0 -418
  85. package/app/components/sidebar/case-export/case-export.tsx +0 -310
  86. package/app/types/exceljs-bare.d.ts +0 -9
  87. package/app/utils/auth/auth.ts +0 -11
  88. package/public/.well-known/security.txt +0 -6
  89. package/public/favicon.ico +0 -0
  90. package/public/icon-256.png +0 -0
  91. package/public/icon-512.png +0 -0
  92. package/public/manifest.json +0 -39
  93. package/public/shortcut.png +0 -0
  94. package/public/social-image.png +0 -0
  95. package/public/vendor/exceljs.LICENSE +0 -22
  96. package/public/vendor/exceljs.bare.min.js +0 -45
  97. package/scripts/deploy-all.sh +0 -166
  98. package/scripts/deploy-config/modules/env-utils.sh +0 -322
  99. package/scripts/deploy-config/modules/keys.sh +0 -404
  100. package/scripts/deploy-config/modules/prompt.sh +0 -372
  101. package/scripts/deploy-config/modules/scaffolding.sh +0 -344
  102. package/scripts/deploy-config/modules/validation.sh +0 -365
  103. package/scripts/deploy-config.sh +0 -236
  104. package/scripts/deploy-pages-secrets.sh +0 -231
  105. package/scripts/deploy-pages.sh +0 -34
  106. package/scripts/deploy-primershear-emails.sh +0 -167
  107. package/scripts/deploy-worker-secrets.sh +0 -374
  108. package/scripts/dev.cjs +0 -23
  109. package/scripts/install-workers.sh +0 -88
  110. package/scripts/run-eslint.cjs +0 -43
  111. package/scripts/update-compatibility-dates.cjs +0 -124
  112. package/scripts/update-markdown-versions.cjs +0 -43
  113. package/workers/keys-worker/package.json +0 -18
  114. package/workers/keys-worker/src/keys.example.ts +0 -67
  115. package/workers/keys-worker/src/keys.ts +0 -67
  116. package/workers/keys-worker/worker-configuration.d.ts +0 -7447
  117. package/workers/keys-worker/wrangler.jsonc.example +0 -15
@@ -1,231 +0,0 @@
1
- #!/bin/bash
2
-
3
- # ======================================
4
- # STRIAE PAGES SECRETS DEPLOYMENT SCRIPT
5
- # ======================================
6
- # This script deploys required secrets to Cloudflare Pages environments.
7
-
8
- set -e
9
- set -o pipefail
10
-
11
- # Colors for output
12
- RED='\033[0;31m'
13
- GREEN='\033[0;32m'
14
- YELLOW='\033[1;33m'
15
- BLUE='\033[0;34m'
16
- NC='\033[0m' # No Color
17
-
18
- echo -e "${BLUE}🔐 Striae Pages Secrets Deployment Script${NC}"
19
- echo "=========================================="
20
-
21
- SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
22
- PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
23
- cd "$PROJECT_ROOT"
24
-
25
- trap 'echo -e "\n${RED}❌ deploy-pages-secrets.sh failed near line ${LINENO}${NC}"' ERR
26
-
27
- show_help=false
28
- deploy_production=true
29
- deploy_preview=true
30
-
31
- for arg in "$@"; do
32
- case "$arg" in
33
- -h|--help)
34
- show_help=true
35
- ;;
36
- --production-only)
37
- deploy_production=true
38
- deploy_preview=false
39
- ;;
40
- --preview-only)
41
- deploy_production=false
42
- deploy_preview=true
43
- ;;
44
- *)
45
- echo -e "${RED}❌ Unknown option: $arg${NC}"
46
- echo "Use --help to see supported options."
47
- exit 1
48
- ;;
49
- esac
50
- done
51
-
52
- if [ "$show_help" = "true" ]; then
53
- echo "Usage: bash ./scripts/deploy-pages-secrets.sh [--production-only|--preview-only]"
54
- echo ""
55
- echo "Options:"
56
- echo " --production-only Deploy secrets only to the production Pages environment"
57
- echo " --preview-only Deploy secrets only to the preview Pages environment"
58
- echo " -h, --help Show this help message"
59
- exit 0
60
- fi
61
-
62
- if [ "$deploy_production" != "true" ] && [ "$deploy_preview" != "true" ]; then
63
- echo -e "${RED}❌ No target environment selected${NC}"
64
- exit 1
65
- fi
66
-
67
- require_command() {
68
- local cmd=$1
69
- if ! command -v "$cmd" > /dev/null 2>&1; then
70
- echo -e "${RED}❌ Error: required command '$cmd' is not installed or not in PATH${NC}"
71
- exit 1
72
- fi
73
- }
74
-
75
- strip_carriage_returns() {
76
- printf '%s' "$1" | tr -d '\r'
77
- }
78
-
79
- is_placeholder() {
80
- local value="$1"
81
- local normalized
82
-
83
- normalized=$(echo "$value" | tr '[:upper:]' '[:lower:]')
84
-
85
- if [ -z "$normalized" ]; then
86
- return 0
87
- fi
88
-
89
- [[ "$normalized" == your_*_here ]]
90
- }
91
-
92
- load_required_project_id() {
93
- local admin_service_path="app/config/admin-service.json"
94
- local service_project_id
95
-
96
- if [ ! -f "$admin_service_path" ]; then
97
- echo -e "${RED}❌ Error: Required Firebase admin service file not found: $admin_service_path${NC}"
98
- echo -e "${YELLOW} Create app/config/admin-service.json before deploying Pages secrets.${NC}"
99
- exit 1
100
- fi
101
-
102
- if ! service_project_id=$(node -e "const fs=require('fs'); const data=JSON.parse(fs.readFileSync(process.argv[1], 'utf8')); process.stdout.write(data.project_id || '');" "$admin_service_path"); then
103
- echo -e "${RED}❌ Error: Could not parse project_id from $admin_service_path${NC}"
104
- exit 1
105
- fi
106
-
107
- service_project_id=$(strip_carriage_returns "$service_project_id")
108
-
109
- if [ -z "$service_project_id" ] || is_placeholder "$service_project_id"; then
110
- echo -e "${RED}❌ Error: project_id in $admin_service_path is missing or placeholder${NC}"
111
- exit 1
112
- fi
113
-
114
- PROJECT_ID="$service_project_id"
115
- export PROJECT_ID
116
-
117
- echo -e "${GREEN}✅ Loaded PROJECT_ID from $admin_service_path${NC}"
118
- }
119
-
120
- get_required_value() {
121
- local var_name=$1
122
- local value="${!var_name}"
123
-
124
- value=$(strip_carriage_returns "$value")
125
-
126
- if [ -z "$value" ] || is_placeholder "$value"; then
127
- echo -e "${RED}❌ Error: required value for $var_name is missing or placeholder${NC}" >&2
128
- exit 1
129
- fi
130
-
131
- printf '%s' "$value"
132
- }
133
-
134
- get_optional_value() {
135
- local var_name=$1
136
- local value="${!var_name}"
137
-
138
- value=$(strip_carriage_returns "$value")
139
-
140
- if [ -z "$value" ] || is_placeholder "$value"; then
141
- printf ''
142
- return 0
143
- fi
144
-
145
- printf '%s' "$value"
146
- }
147
-
148
- set_pages_secret() {
149
- local secret_name=$1
150
- local secret_value=$2
151
- local pages_env=$3
152
-
153
- echo -e "${YELLOW} Setting $secret_name for $pages_env...${NC}"
154
-
155
- if [ "$pages_env" = "production" ]; then
156
- printf '%s' "$secret_value" | wrangler pages secret put "$secret_name" --project-name "$PAGES_PROJECT_NAME"
157
- return 0
158
- fi
159
-
160
- printf '%s' "$secret_value" | wrangler pages secret put "$secret_name" --project-name "$PAGES_PROJECT_NAME" --env "$pages_env"
161
- }
162
-
163
- deploy_pages_environment_secrets() {
164
- local pages_env=$1
165
- local secret
166
- local secret_value
167
-
168
- echo -e "\n${BLUE}🔧 Deploying Pages secrets to $pages_env...${NC}"
169
-
170
- for secret in "${required_pages_secrets[@]}"; do
171
- secret_value=$(get_required_value "$secret")
172
- set_pages_secret "$secret" "$secret_value" "$pages_env"
173
- done
174
-
175
- local optional_primershear_emails
176
- optional_primershear_emails=$(get_optional_value "PRIMERSHEAR_EMAILS")
177
- if [ -n "$optional_primershear_emails" ]; then
178
- set_pages_secret "PRIMERSHEAR_EMAILS" "$optional_primershear_emails" "$pages_env"
179
- fi
180
-
181
- echo -e "${GREEN}✅ Pages secrets deployed to $pages_env${NC}"
182
- }
183
-
184
- require_command wrangler
185
- require_command node
186
-
187
- if [ ! -f ".env" ]; then
188
- echo -e "${RED}❌ Error: .env file not found${NC}"
189
- echo -e "${YELLOW} Run deploy-config first to generate and populate .env.${NC}"
190
- exit 1
191
- fi
192
-
193
- echo -e "${YELLOW}📖 Loading environment variables from .env...${NC}"
194
- source .env
195
-
196
- load_required_project_id
197
-
198
- PAGES_PROJECT_NAME=$(strip_carriage_returns "$PAGES_PROJECT_NAME")
199
- if [ -z "$PAGES_PROJECT_NAME" ] || is_placeholder "$PAGES_PROJECT_NAME"; then
200
- echo -e "${RED}❌ Error: PAGES_PROJECT_NAME is missing or placeholder in .env${NC}"
201
- exit 1
202
- fi
203
-
204
- required_pages_secrets=(
205
- "AUDIT_WORKER_DOMAIN"
206
- "DATA_WORKER_DOMAIN"
207
- "IMAGES_API_TOKEN"
208
- "IMAGES_WORKER_DOMAIN"
209
- "PDF_WORKER_AUTH"
210
- "PDF_WORKER_DOMAIN"
211
- "PROJECT_ID"
212
- "R2_KEY_SECRET"
213
- "USER_DB_AUTH"
214
- "USER_WORKER_DOMAIN"
215
- )
216
-
217
- echo -e "${YELLOW}🔍 Validating required Pages secret values...${NC}"
218
- for secret in "${required_pages_secrets[@]}"; do
219
- get_required_value "$secret" > /dev/null
220
- done
221
- echo -e "${GREEN}✅ Required Pages secret values found${NC}"
222
-
223
- if [ "$deploy_production" = "true" ]; then
224
- deploy_pages_environment_secrets "production"
225
- fi
226
-
227
- if [ "$deploy_preview" = "true" ]; then
228
- deploy_pages_environment_secrets "preview"
229
- fi
230
-
231
- echo -e "\n${GREEN}🎉 Pages secrets deployment completed!${NC}"
@@ -1,34 +0,0 @@
1
- #!/bin/bash
2
-
3
- # ======================================
4
- # STRIAE PAGES DEPLOYMENT SCRIPT
5
- # ======================================
6
- # This script deploys the Striae frontend to Cloudflare Pages
7
-
8
- set -e
9
-
10
- # Colors for output
11
- RED='\033[0;31m'
12
- GREEN='\033[0;32m'
13
- YELLOW='\033[1;33m'
14
- BLUE='\033[0;34m'
15
- NC='\033[0m' # No Color
16
-
17
- echo -e "${BLUE}📄 Striae Pages Deployment Script${NC}"
18
- echo "=================================="
19
-
20
- # Deploy to Cloudflare Pages (includes build step)
21
- echo -e "${YELLOW}🚀 Building and deploying to Cloudflare Pages...${NC}"
22
- if ! npm run deploy; then
23
- echo -e "${RED}❌ Deployment failed!${NC}"
24
- exit 1
25
- fi
26
-
27
- echo -e "${GREEN}✅ Pages deployment completed successfully${NC}"
28
-
29
- echo -e "\n${BLUE}💡 Next Steps:${NC}"
30
- echo " 1. Test your application"
31
- echo " 2. Configure custom domain (optional)"
32
- echo " 3. Verify Pages environment variables in Cloudflare dashboard"
33
-
34
- echo -e "\n${GREEN}✨ Pages deployment complete!${NC}"
@@ -1,167 +0,0 @@
1
- #!/bin/bash
2
-
3
- # ============================================
4
- # PRIMERSHEAR EMAIL LIST DEPLOYMENT SCRIPT
5
- # ============================================
6
- # Reads primershear.emails, updates PRIMERSHEAR_EMAILS in .env,
7
- # then deploys that secret directly to Cloudflare Pages.
8
- #
9
- # Usage:
10
- # bash ./scripts/deploy-primershear-emails.sh [--production-only|--preview-only|--env-only]
11
- #
12
- # Options:
13
- # --production-only Deploy to production Pages environment only
14
- # --preview-only Deploy to preview Pages environment only
15
- # --env-only Update .env only; do not deploy to Cloudflare
16
- # -h, --help Show this help message
17
-
18
- set -e
19
- set -o pipefail
20
-
21
- RED='\033[0;31m'
22
- GREEN='\033[0;32m'
23
- YELLOW='\033[1;33m'
24
- BLUE='\033[0;34m'
25
- NC='\033[0m'
26
-
27
- echo -e "${BLUE}📧 PrimerShear Email List Deployment${NC}"
28
- echo "======================================"
29
-
30
- SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
31
- PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
32
- cd "$PROJECT_ROOT"
33
-
34
- trap 'echo -e "\n${RED}❌ deploy-primershear-emails.sh failed near line ${LINENO}${NC}"' ERR
35
-
36
- # ── Argument parsing ─────────────────────────────────────────────────────────
37
-
38
- deploy_production=true
39
- deploy_preview=true
40
- env_only=false
41
-
42
- for arg in "$@"; do
43
- case "$arg" in
44
- -h|--help)
45
- echo "Usage: bash ./scripts/deploy-primershear-emails.sh [--production-only|--preview-only|--env-only]"
46
- echo ""
47
- echo "Options:"
48
- echo " --production-only Deploy to production Pages environment only"
49
- echo " --preview-only Deploy to preview Pages environment only"
50
- echo " --env-only Update .env only; do not deploy to Cloudflare"
51
- echo " -h, --help Show this help message"
52
- exit 0
53
- ;;
54
- --production-only)
55
- deploy_production=true
56
- deploy_preview=false
57
- ;;
58
- --preview-only)
59
- deploy_production=false
60
- deploy_preview=true
61
- ;;
62
- --env-only)
63
- env_only=true
64
- ;;
65
- *)
66
- echo -e "${RED}❌ Unknown option: $arg${NC}"
67
- echo "Use --help to see supported options."
68
- exit 1
69
- ;;
70
- esac
71
- done
72
-
73
- # ── Read emails file ──────────────────────────────────────────────────────────
74
-
75
- EMAILS_FILE="$PROJECT_ROOT/primershear.emails"
76
-
77
- if [ ! -f "$EMAILS_FILE" ]; then
78
- echo -e "${RED}❌ primershear.emails not found at: $EMAILS_FILE${NC}"
79
- echo -e "${YELLOW} Create it with one email address per line.${NC}"
80
- exit 1
81
- fi
82
-
83
- # Strip comment lines and blank lines, then join with commas
84
- # Use || true to avoid failure if paste gets no input (handles empty file gracefully)
85
- PRIMERSHEAR_EMAILS=$(grep -v '^[[:space:]]*#' "$EMAILS_FILE" | grep -v '^[[:space:]]*$' | paste -sd ',' - || true)
86
-
87
- if [ -z "$PRIMERSHEAR_EMAILS" ]; then
88
- echo -e "${YELLOW}⚠️ primershear.emails contains no active email addresses.${NC}"
89
- echo -e "${YELLOW} The secret will be set to an empty string, disabling the feature.${NC}"
90
- fi
91
-
92
- EMAIL_COUNT=$(echo "$PRIMERSHEAR_EMAILS" | tr ',' '\n' | grep -c '[^[:space:]]' || true)
93
- echo -e "${GREEN}✅ Loaded $EMAIL_COUNT email address(es) from primershear.emails${NC}"
94
-
95
- # ── Update .env ───────────────────────────────────────────────────────────────
96
-
97
- ENV_FILE="$PROJECT_ROOT/.env"
98
-
99
- if [ ! -f "$ENV_FILE" ]; then
100
- echo -e "${RED}❌ .env not found. Run deploy-config first.${NC}"
101
- exit 1
102
- fi
103
-
104
- # Replace the PRIMERSHEAR_EMAILS= line in .env (handles both empty and populated values)
105
- if grep -q '^PRIMERSHEAR_EMAILS=' "$ENV_FILE"; then
106
- # Use a temp file to avoid sed -i portability issues across macOS/Linux
107
- local_tmp=$(mktemp)
108
- sed "s|^PRIMERSHEAR_EMAILS=.*|PRIMERSHEAR_EMAILS=${PRIMERSHEAR_EMAILS}|" "$ENV_FILE" > "$local_tmp"
109
- mv "$local_tmp" "$ENV_FILE"
110
- echo -e "${GREEN}✅ Updated PRIMERSHEAR_EMAILS in .env${NC}"
111
- else
112
- echo "" >> "$ENV_FILE"
113
- echo "PRIMERSHEAR_EMAILS=${PRIMERSHEAR_EMAILS}" >> "$ENV_FILE"
114
- echo -e "${GREEN}✅ Appended PRIMERSHEAR_EMAILS to .env${NC}"
115
- fi
116
-
117
- if [ "$env_only" = "true" ]; then
118
- echo -e "\n${GREEN}🎉 .env updated. Skipping Cloudflare deployment (--env-only).${NC}"
119
- exit 0
120
- fi
121
-
122
- # ── Deploy to Cloudflare Pages ────────────────────────────────────────────────
123
-
124
- if ! command -v wrangler > /dev/null 2>&1; then
125
- echo -e "${RED}❌ wrangler is not installed or not in PATH${NC}"
126
- exit 1
127
- fi
128
-
129
- source "$ENV_FILE"
130
-
131
- PAGES_PROJECT_NAME=$(echo "$PAGES_PROJECT_NAME" | tr -d '\r')
132
- if [ -z "$PAGES_PROJECT_NAME" ]; then
133
- echo -e "${RED}❌ PAGES_PROJECT_NAME is missing from .env${NC}"
134
- exit 1
135
- fi
136
-
137
- set_secret() {
138
- local pages_env=$1
139
- echo -e "${YELLOW} Setting PRIMERSHEAR_EMAILS for $pages_env...${NC}"
140
- if [ "$pages_env" = "production" ]; then
141
- printf '%s' "$PRIMERSHEAR_EMAILS" | wrangler pages secret put PRIMERSHEAR_EMAILS \
142
- --project-name "$PAGES_PROJECT_NAME"
143
- else
144
- printf '%s' "$PRIMERSHEAR_EMAILS" | wrangler pages secret put PRIMERSHEAR_EMAILS \
145
- --project-name "$PAGES_PROJECT_NAME" --env "$pages_env"
146
- fi
147
- }
148
-
149
- if [ "$deploy_production" = "true" ]; then
150
- set_secret "production"
151
- echo -e "${GREEN}✅ PRIMERSHEAR_EMAILS deployed to production${NC}"
152
- fi
153
-
154
- if [ "$deploy_preview" = "true" ]; then
155
- set_secret "preview"
156
- echo -e "${GREEN}✅ PRIMERSHEAR_EMAILS deployed to preview${NC}"
157
- fi
158
-
159
- # Deploy Pages so the new secret takes effect immediately
160
- echo -e "\n${YELLOW}🚀 Building and deploying Pages to activate new secret...${NC}"
161
- if ! npm run deploy; then
162
- echo -e "${RED}❌ Pages deployment failed${NC}"
163
- exit 1
164
- fi
165
- echo -e "${GREEN}✅ Pages deployment complete${NC}"
166
-
167
- echo -e "\n${GREEN}🎉 PrimerShear email list deployment complete!${NC}"