deploy that shit
This commit is contained in:
parent
f034373406
commit
d001fba764
@ -9,4 +9,4 @@ node_modules
|
|||||||
/.cache
|
/.cache
|
||||||
/public/build
|
/public/build
|
||||||
/build
|
/build
|
||||||
server.js
|
/server/index.js
|
74
.github/workflows/main.yml
vendored
74
.github/workflows/main.yml
vendored
@ -15,53 +15,9 @@ jobs:
|
|||||||
- run: npm ci
|
- run: npm ci
|
||||||
- run: npm run lint
|
- run: npm run lint
|
||||||
|
|
||||||
e2e:
|
|
||||||
name: E2E tests
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
services:
|
|
||||||
postgres:
|
|
||||||
image: postgres:13-alpine
|
|
||||||
options: >-
|
|
||||||
--health-cmd pg_isready
|
|
||||||
--health-interval 10s
|
|
||||||
--health-timeout 5s
|
|
||||||
--health-retries 5
|
|
||||||
env:
|
|
||||||
POSTGRES_USER: pgremixtape
|
|
||||||
POSTGRES_PASSWORD: pgpassword
|
|
||||||
POSTGRES_DB: remixtape
|
|
||||||
ports:
|
|
||||||
- "5432:5432"
|
|
||||||
redis:
|
|
||||||
image: redis:6-alpine
|
|
||||||
options: >-
|
|
||||||
--health-cmd "redis-cli ping"
|
|
||||||
--health-interval 10s
|
|
||||||
--health-timeout 5s
|
|
||||||
--health-retries 5
|
|
||||||
ports:
|
|
||||||
- "6379:6379"
|
|
||||||
env:
|
|
||||||
DATABASE_URL: postgresql://pgremixtape:pgpassword@localhost:5432/remixtape
|
|
||||||
REDIS_URL: redis://localhost:6379
|
|
||||||
CI: true
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- run: cp .env.example .env
|
|
||||||
- uses: actions/setup-node@v2
|
|
||||||
with:
|
|
||||||
node-version: 16
|
|
||||||
cache: "npm"
|
|
||||||
- run: npm ci
|
|
||||||
- run: npm run db:setup
|
|
||||||
- run: npm run build
|
|
||||||
- run: npx dotenv npm run e2e:ci
|
|
||||||
|
|
||||||
typecheck:
|
typecheck:
|
||||||
name: Typecheck
|
name: Typecheck
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
env:
|
|
||||||
HUSKY_SKIP_INSTALL: 1
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
- uses: actions/setup-node@v2
|
- uses: actions/setup-node@v2
|
||||||
@ -70,10 +26,29 @@ jobs:
|
|||||||
- run: npm ci
|
- run: npm ci
|
||||||
- run: npx tsc
|
- run: npx tsc
|
||||||
|
|
||||||
deploy:
|
deploy_development:
|
||||||
if: github.ref == 'refs/heads/master'
|
if: github.ref == 'refs/heads/master'
|
||||||
needs: [lint, e2e, typecheck]
|
needs: [lint, typecheck]
|
||||||
name: Deploy to Fly.io
|
name: Deploy development environment
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
- uses: superfly/flyctl-actions@master
|
||||||
|
env:
|
||||||
|
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }}
|
||||||
|
with:
|
||||||
|
args: "deploy --strategy rolling -c ./fly.dev.toml"
|
||||||
|
- uses: appleboy/discord-action@master
|
||||||
|
with:
|
||||||
|
webhook_id: ${{ secrets.DISCORD_WEBHOOK_ID }}
|
||||||
|
webhook_token: ${{ secrets.DISCORD_WEBHOOK_TOKEN }}
|
||||||
|
args: "https://dev.shellphone.app deployed with commit `${{ github.event.head_commit.message }}` (`${{ github.sha }}`) from branch `${{ github.ref }}`"
|
||||||
|
|
||||||
|
|
||||||
|
deploy_production:
|
||||||
|
if: github.ref == 'refs/heads/production'
|
||||||
|
needs: [lint, typecheck]
|
||||||
|
name: Deploy production environment
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v2
|
- uses: actions/checkout@v2
|
||||||
@ -82,3 +57,8 @@ jobs:
|
|||||||
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }}
|
FLY_API_TOKEN: ${{ secrets.FLY_API_TOKEN }}
|
||||||
with:
|
with:
|
||||||
args: "deploy --strategy rolling"
|
args: "deploy --strategy rolling"
|
||||||
|
- uses: appleboy/discord-action@master
|
||||||
|
with:
|
||||||
|
webhook_id: ${{ secrets.DISCORD_WEBHOOK_ID }}
|
||||||
|
webhook_token: ${{ secrets.DISCORD_WEBHOOK_TOKEN }}
|
||||||
|
args: "https://www.shellphone.app deployed with commit `${{ github.event.head_commit.message }}` (`${{ github.sha }}`) from branch `${{ github.ref }}`"
|
||||||
|
@ -51,7 +51,7 @@ COPY --from=production-deps /app/node_modules /app/node_modules
|
|||||||
COPY --from=build /app/node_modules/.prisma /app/node_modules/.prisma
|
COPY --from=build /app/node_modules/.prisma /app/node_modules/.prisma
|
||||||
COPY --from=build /app/build /app/build
|
COPY --from=build /app/build /app/build
|
||||||
COPY --from=build /app/public /app/public
|
COPY --from=build /app/public /app/public
|
||||||
COPY --from=build /app/server.js /app/server.js
|
COPY --from=build /app/server/index.js /app/server/index.js
|
||||||
ADD . .
|
ADD . .
|
||||||
|
|
||||||
CMD ["npm", "run", "start"]
|
CMD ["npm", "run", "start"]
|
||||||
|
@ -20,10 +20,6 @@ invariant(
|
|||||||
`Please define the "AWS_SES_FROM_EMAIL" environment variable`,
|
`Please define the "AWS_SES_FROM_EMAIL" environment variable`,
|
||||||
);
|
);
|
||||||
invariant(typeof process.env.REDIS_URL === "string", `Please define the "REDIS_URL" environment variable`);
|
invariant(typeof process.env.REDIS_URL === "string", `Please define the "REDIS_URL" environment variable`);
|
||||||
invariant(
|
|
||||||
typeof process.env.TWILIO_AUTH_TOKEN === "string",
|
|
||||||
`Please define the "TWILIO_AUTH_TOKEN" environment variable`,
|
|
||||||
);
|
|
||||||
invariant(
|
invariant(
|
||||||
typeof process.env.MASTER_ENCRYPTION_KEY === "string",
|
typeof process.env.MASTER_ENCRYPTION_KEY === "string",
|
||||||
`Please define the "MASTER_ENCRYPTION_KEY" environment variable`,
|
`Please define the "MASTER_ENCRYPTION_KEY" environment variable`,
|
||||||
@ -65,9 +61,6 @@ export default {
|
|||||||
sentry: {
|
sentry: {
|
||||||
dsn: process.env.SENTRY_DSN,
|
dsn: process.env.SENTRY_DSN,
|
||||||
},
|
},
|
||||||
twilio: {
|
|
||||||
authToken: process.env.TWILIO_AUTH_TOKEN,
|
|
||||||
},
|
|
||||||
webPush: {
|
webPush: {
|
||||||
privateKey: process.env.WEB_PUSH_VAPID_PRIVATE_KEY,
|
privateKey: process.env.WEB_PUSH_VAPID_PRIVATE_KEY,
|
||||||
publicKey: process.env.WEB_PUSH_VAPID_PUBLIC_KEY,
|
publicKey: process.env.WEB_PUSH_VAPID_PUBLIC_KEY,
|
||||||
|
@ -23,11 +23,11 @@ export const voiceUrl = `${serverConfig.app.baseUrl}/webhook/call`;
|
|||||||
|
|
||||||
export function getTwiMLName() {
|
export function getTwiMLName() {
|
||||||
switch (serverConfig.app.baseUrl) {
|
switch (serverConfig.app.baseUrl) {
|
||||||
case "local.shellphone.app":
|
case "https://local.shellphone.app":
|
||||||
return "Shellphone LOCAL";
|
return "Shellphone LOCAL";
|
||||||
case "dev.shellphone.app":
|
case "https://dev.shellphone.app":
|
||||||
return "Shellphone DEV";
|
return "Shellphone DEV";
|
||||||
case "www.shellphone.app":
|
case "https://www.shellphone.app":
|
||||||
return "Shellphone";
|
return "Shellphone";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
53
fly.dev.toml
Normal file
53
fly.dev.toml
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
app = "shellphone-dev"
|
||||||
|
kill_signal = "SIGINT"
|
||||||
|
kill_timeout = 5
|
||||||
|
processes = []
|
||||||
|
|
||||||
|
[deploy]
|
||||||
|
release_command = "npx prisma migrate deploy"
|
||||||
|
|
||||||
|
[env]
|
||||||
|
APP_BASE_URL = "https://dev.shellphone.app"
|
||||||
|
AWS_SES_FROM_EMAIL = "\"Mokhtar from Shellphone\" <mokhtar@shellphone.app>"
|
||||||
|
AWS_SES_REGION = "eu-central-1"
|
||||||
|
NODE_ENV = "production"
|
||||||
|
PORT = "8080"
|
||||||
|
|
||||||
|
[experimental]
|
||||||
|
allowed_public_ports = []
|
||||||
|
auto_rollback = true
|
||||||
|
|
||||||
|
[[services]]
|
||||||
|
internal_port = 8080
|
||||||
|
processes = ["app"]
|
||||||
|
protocol = "tcp"
|
||||||
|
script_checks = []
|
||||||
|
[services.concurrency]
|
||||||
|
hard_limit = 25
|
||||||
|
soft_limit = 20
|
||||||
|
type = "connections"
|
||||||
|
|
||||||
|
[[services.http_checks]]
|
||||||
|
grace_period = "5s"
|
||||||
|
interval = 10000
|
||||||
|
method = "get"
|
||||||
|
path = "/healthcheck"
|
||||||
|
protocol = "http"
|
||||||
|
timeout = 2000
|
||||||
|
tls_skip_verify = false
|
||||||
|
[services.http_checks.headers]
|
||||||
|
|
||||||
|
[[services.ports]]
|
||||||
|
force_https = true
|
||||||
|
handlers = ["http"]
|
||||||
|
port = 80
|
||||||
|
|
||||||
|
[[services.ports]]
|
||||||
|
handlers = ["tls", "http"]
|
||||||
|
port = 443
|
||||||
|
|
||||||
|
[[services.tcp_checks]]
|
||||||
|
grace_period = "1s"
|
||||||
|
interval = "15s"
|
||||||
|
restart_limit = 0
|
||||||
|
timeout = "2s"
|
@ -1,18 +1,18 @@
|
|||||||
app = "shellphoneappremixed-redis"
|
app = "shellphone-redis"
|
||||||
kill_signal = "SIGINT"
|
kill_signal = "SIGINT"
|
||||||
kill_timeout = 5
|
kill_timeout = 5
|
||||||
processes = [ ]
|
processes = []
|
||||||
|
|
||||||
[build]
|
[build]
|
||||||
image = "flyio/redis:6.2.6"
|
image = "flyio/redis:6.2.6"
|
||||||
|
|
||||||
[experimental]
|
[experimental]
|
||||||
allowed_public_ports = [ ]
|
allowed_public_ports = []
|
||||||
auto_rollback = true
|
auto_rollback = true
|
||||||
|
|
||||||
[[mounts]]
|
[[mounts]]
|
||||||
destination = "/data"
|
destination = "/data"
|
||||||
source = "shellphoneappremixed_redis_data"
|
source = "shellphone_redis_data"
|
||||||
|
|
||||||
[metrics]
|
[metrics]
|
||||||
port = 9_091
|
port = 9_091
|
||||||
|
85
fly.toml
85
fly.toml
@ -1,54 +1,53 @@
|
|||||||
app = "shellphoneappremixed"
|
app = "shellphone-prod"
|
||||||
kill_signal = "SIGINT"
|
kill_signal = "SIGINT"
|
||||||
kill_timeout = 5
|
kill_timeout = 5
|
||||||
processes = [ ]
|
processes = []
|
||||||
|
|
||||||
[env]
|
|
||||||
APP_BASE_URL = "https://shellphoneappremixed.fly.dev"
|
|
||||||
AWS_SES_FROM_EMAIL = "remixtape@fake.app"
|
|
||||||
AWS_SES_REGION = "eu-central-1"
|
|
||||||
NODE_ENV = "production"
|
|
||||||
PORT = "8080"
|
|
||||||
|
|
||||||
[deploy]
|
[deploy]
|
||||||
release_command = "npx prisma migrate deploy"
|
release_command = "npx prisma migrate deploy"
|
||||||
|
|
||||||
|
[env]
|
||||||
|
APP_BASE_URL = "https://www.shellphone.app"
|
||||||
|
AWS_SES_FROM_EMAIL = "\"Mokhtar from Shellphone\" <mokhtar@shellphone.app>"
|
||||||
|
AWS_SES_REGION = "eu-central-1"
|
||||||
|
NODE_ENV = "production"
|
||||||
|
PORT = "8080"
|
||||||
|
|
||||||
[experimental]
|
[experimental]
|
||||||
allowed_public_ports = [ ]
|
allowed_public_ports = []
|
||||||
auto_rollback = true
|
auto_rollback = true
|
||||||
|
|
||||||
[[services]]
|
[[services]]
|
||||||
internal_port = 8_080
|
internal_port = 8080
|
||||||
processes = [ "app" ]
|
processes = ["app"]
|
||||||
protocol = "tcp"
|
protocol = "tcp"
|
||||||
script_checks = [ ]
|
script_checks = []
|
||||||
|
|
||||||
[services.concurrency]
|
[services.concurrency]
|
||||||
hard_limit = 25
|
hard_limit = 25
|
||||||
soft_limit = 20
|
soft_limit = 20
|
||||||
type = "connections"
|
type = "connections"
|
||||||
|
|
||||||
[[services.ports]]
|
|
||||||
handlers = [ "http" ]
|
|
||||||
port = 80
|
|
||||||
force_https = true
|
|
||||||
|
|
||||||
[[services.ports]]
|
|
||||||
handlers = [ "tls", "http" ]
|
|
||||||
port = 443
|
|
||||||
|
|
||||||
[[services.tcp_checks]]
|
|
||||||
grace_period = "1s"
|
|
||||||
interval = "15s"
|
|
||||||
restart_limit = 0
|
|
||||||
timeout = "2s"
|
|
||||||
|
|
||||||
[[services.http_checks]]
|
[[services.http_checks]]
|
||||||
interval = 10_000
|
grace_period = "5s"
|
||||||
grace_period = "5s"
|
interval = 10000
|
||||||
method = "get"
|
method = "get"
|
||||||
path = "/healthcheck"
|
path = "/healthcheck"
|
||||||
protocol = "http"
|
protocol = "http"
|
||||||
timeout = 2_000
|
timeout = 2000
|
||||||
tls_skip_verify = false
|
tls_skip_verify = false
|
||||||
headers = { }
|
[services.http_checks.headers]
|
||||||
|
|
||||||
|
[[services.ports]]
|
||||||
|
force_https = true
|
||||||
|
handlers = ["http"]
|
||||||
|
port = 80
|
||||||
|
|
||||||
|
[[services.ports]]
|
||||||
|
handlers = ["tls", "http"]
|
||||||
|
port = 443
|
||||||
|
|
||||||
|
[[services.tcp_checks]]
|
||||||
|
grace_period = "1s"
|
||||||
|
interval = "15s"
|
||||||
|
restart_limit = 0
|
||||||
|
timeout = "2s"
|
||||||
|
Loading…
Reference in New Issue
Block a user