From a36fbd53126697eefefe565199febf2b554c1b16 Mon Sep 17 00:00:00 2001 From: Dax Raad Date: Wed, 22 Nov 2023 18:46:03 -0500 Subject: [PATCH] fix --- cmd/sst/main.go | 29 +++++++++++++++---- internal/components/package.json | 3 ++ internal/components/pnpm-lock.yaml | 7 +++-- .../components/src/components/ssr-site.ts | 25 ++++++++-------- pkg/project/stack.go | 4 +++ 5 files changed, 48 insertions(+), 20 deletions(-) diff --git a/cmd/sst/main.go b/cmd/sst/main.go index aa55ba771..970715664 100644 --- a/cmd/sst/main.go +++ b/cmd/sst/main.go @@ -21,8 +21,8 @@ var version = "dev" func main() { app := &cli.App{ - Name: "sst", - Usage: "deploy anything", + Name: "sst", + Description: "deploy anything", Flags: []cli.Flag{ &cli.BoolFlag{ Name: "verbose", @@ -53,7 +53,6 @@ func main() { Commands: []*cli.Command{ { Name: "deploy", - Usage: "Deploy", Flags: []cli.Flag{}, Action: func(cli *cli.Context) error { p, err := initProject() @@ -136,7 +135,6 @@ func main() { }, { Name: "remove", - Usage: "Remove", Flags: []cli.Flag{}, Action: func(cli *cli.Context) error { p, err := initProject() @@ -156,9 +154,29 @@ func main() { return nil }, }, + { + Name: "refresh", + Flags: []cli.Flag{}, + Action: func(cli *cli.Context) error { + p, err := initProject() + if err != nil { + return err + } + events, err := p.Stack.Refresh() + if err != nil { + return err + } + + for evt := range events { + if evt.ResourcePreEvent != nil { + slog.Info("got op", "op", evt.ResourcePreEvent.Metadata.Op) + } + } + return nil + }, + }, { Name: "create", - Usage: "Create", Flags: []cli.Flag{}, Action: func(cli *cli.Context) error { err := project.Create() @@ -171,7 +189,6 @@ func main() { }, { Name: "cancel", - Usage: "Cancel", Flags: []cli.Flag{}, Action: func(cli *cli.Context) error { p, err := initProject() diff --git a/internal/components/package.json b/internal/components/package.json index de4a09848..fec77ab89 100644 --- a/internal/components/package.json +++ b/internal/components/package.json @@ -6,5 +6,8 @@ "@aws-sdk/client-sts": "^3.454.0", "@pulumi/aws": "5.43.0", "@pulumi/pulumi": "3.94.2" + }, + "devDependencies": { + "@types/node": "^20.9.4" } } diff --git a/internal/components/pnpm-lock.yaml b/internal/components/pnpm-lock.yaml index 9a7da6a62..c7bc74c12 100644 --- a/internal/components/pnpm-lock.yaml +++ b/internal/components/pnpm-lock.yaml @@ -18,6 +18,11 @@ dependencies: specifier: 3.94.2 version: 3.94.2 +devDependencies: + '@types/node': + specifier: ^20.9.4 + version: 20.9.4 + packages: /@aws-crypto/crc32@3.0.0: @@ -1140,7 +1145,6 @@ packages: resolution: {integrity: sha512-wmyg8HUhcn6ACjsn8oKYjkN/zUzQeNtMy44weTJSM6p4MMzEOuKbA3OjJ267uPCOW7Xex9dyrNTful8XTQYoDA==} dependencies: undici-types: 5.26.5 - dev: false /ansi-regex@5.0.1: resolution: {integrity: sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==} @@ -2303,7 +2307,6 @@ packages: /undici-types@5.26.5: resolution: {integrity: sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==} - dev: false /upath@1.2.0: resolution: {integrity: sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==} diff --git a/internal/components/src/components/ssr-site.ts b/internal/components/src/components/ssr-site.ts index baedc7e87..7fada1209 100644 --- a/internal/components/src/components/ssr-site.ts +++ b/internal/components/src/components/ssr-site.ts @@ -2,6 +2,7 @@ import * as fs from "fs"; import * as path from "path"; import { execSync } from "child_process"; import pulumi from "@pulumi/pulumi"; +import * as aws from "@pulumi/aws"; import { Function } from "./function"; export interface SsrSiteArgs extends pulumi.ComponentResourceOptions { @@ -90,7 +91,7 @@ export class SsrSite extends pulumi.ComponentResource { function createCloudFrontOriginAccessIdentity() { return new aws.cloudfront.OriginAccessIdentity( `${name}-origin-access-identity`, - {} + {}, ); } @@ -106,7 +107,7 @@ export class SsrSite extends pulumi.ComponentResource { return request; }`, }, - { parent: _this } + { parent: _this }, ); } @@ -189,7 +190,7 @@ export class SsrSite extends pulumi.ComponentResource { queryStringBehavior: "all", }, }, - } + }, ); return new aws.cloudfront.Distribution(`${name}-distribution`, { @@ -341,7 +342,7 @@ export class SsrSite extends pulumi.ComponentResource { const bucket = new aws.s3.BucketV2( `${name}-bucket`, {}, - { parent: _this } + { parent: _this }, ); new aws.s3.BucketPublicAccessBlock("exampleBucketPublicAccessBlock", { bucket: bucket.id, @@ -397,7 +398,7 @@ export class SsrSite extends pulumi.ComponentResource { }, ], }) - .then((doc) => doc.json) + .then((doc) => doc.json), ), }, ], @@ -429,7 +430,7 @@ export class SsrSite extends pulumi.ComponentResource { }, ], }) - .then((doc) => doc.json) + .then((doc) => doc.json), ), }, ], @@ -442,7 +443,7 @@ export class SsrSite extends pulumi.ComponentResource { description: "Next.js server", handler: "index.handler", code: new pulumi.asset.FileArchive( - path.join(sitePath, ".open-next", "image-optimization-function") + path.join(sitePath, ".open-next", "image-optimization-function"), ), runtime: "nodejs18.x", memorySize: 1536, @@ -482,33 +483,33 @@ export class SsrSite extends pulumi.ComponentResource { }, ], }) - .then((doc) => doc.json) + .then((doc) => doc.json), ), }, ], managedPolicyArns: [ "arn:aws:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole", ], - } + }, ); const consumer = new aws.lambda.Function( `${name}-revalidation-consumer`, { handler: "index.handler", code: new pulumi.asset.FileArchive( - path.join(sitePath, ".open-next", "revalidation-function") + path.join(sitePath, ".open-next", "revalidation-function"), ), runtime: "nodejs18.x", timeout: 30, role: consumerRole.arn, - } + }, ); new aws.lambda.EventSourceMapping( `${name}-revalidation-consumer-event-source`, { functionName: consumer.name, eventSourceArn: queue.arn, - } + }, ); } } diff --git a/pkg/project/stack.go b/pkg/project/stack.go index 15eb5bd3f..5a5cbaf06 100644 --- a/pkg/project/stack.go +++ b/pkg/project/stack.go @@ -152,3 +152,7 @@ func (s *stack) Cancel() (StackEventStream, error) { func (s *stack) Remove() (StackEventStream, error) { return s.run("destroy") } + +func (s *stack) Refresh() (StackEventStream, error) { + return s.run("refresh") +}