From 07a19be4b356c1d2563b427547bd9b67d08d32cd Mon Sep 17 00:00:00 2001 From: Stephen Parkinson Date: Fri, 5 Jul 2024 10:09:18 -0700 Subject: [PATCH] switch back to docker --- Dockerfile | 77 +++ .../Package.resolved => Package.resolved | 110 ++--- Package.swift | 39 ++ {smparkin/Public => Public}/css/404style.css | 0 {smparkin/Public => Public}/images/bg.jpg | Bin {smparkin/Public => Public}/images/me.jpg | Bin {smparkin/Public => Public}/images/trees.jpg | Bin {smparkin/Public => Public}/media/gif.gif | Bin {smparkin/Public => Public}/media/gif2.gif | Bin {smparkin/Public => Public}/media/song.mp3 | Bin README.md | 1 + {smparkin => Resources}/Views/404.leaf | 0 {smparkin => Resources}/Views/home.leaf | 39 +- {smparkin => Resources}/Views/privacy.leaf | 0 {smparkin => Resources}/Views/welcome.leaf | 0 Sources/App/configure.swift | 15 + .../Routes.swift => Sources/App/routes.swift | 0 Sources/Run/main.swift | 9 + Tests/AppTests/AppTests.swift | 12 + Tests/LinuxMain.swift | 11 + docker-compose.yml | 30 ++ smparkin.xcodeproj/project.pbxproj | 439 ------------------ .../contents.xcworkspacedata | 7 - .../xcshareddata/IDEWorkspaceChecks.plist | 8 - .../UserInterfaceState.xcuserstate | Bin 54573 -> 0 bytes .../xcschemes/xcschememanagement.plist | 14 - .../AccentColor.colorset/Contents.json | 11 - .../AppIcon.appiconset/Contents.json | 13 - smparkin/Assets.xcassets/Contents.json | 6 - smparkin/ContentView.swift | 29 -- smparkin/Log.swift | 23 - .../Preview Assets.xcassets/Contents.json | 6 - smparkin/Server.swift | 58 --- smparkin/smparkinApp.swift | 17 - 34 files changed, 259 insertions(+), 715 deletions(-) create mode 100644 Dockerfile rename smparkin.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved => Package.resolved (62%) create mode 100644 Package.swift rename {smparkin/Public => Public}/css/404style.css (100%) rename {smparkin/Public => Public}/images/bg.jpg (100%) rename {smparkin/Public => Public}/images/me.jpg (100%) rename {smparkin/Public => Public}/images/trees.jpg (100%) rename {smparkin/Public => Public}/media/gif.gif (100%) rename {smparkin/Public => Public}/media/gif2.gif (100%) rename {smparkin/Public => Public}/media/song.mp3 (100%) create mode 100644 README.md rename {smparkin => Resources}/Views/404.leaf (100%) rename {smparkin => Resources}/Views/home.leaf (77%) rename {smparkin => Resources}/Views/privacy.leaf (100%) rename {smparkin => Resources}/Views/welcome.leaf (100%) create mode 100644 Sources/App/configure.swift rename smparkin/Routes.swift => Sources/App/routes.swift (100%) create mode 100644 Sources/Run/main.swift create mode 100644 Tests/AppTests/AppTests.swift create mode 100644 Tests/LinuxMain.swift create mode 100644 docker-compose.yml delete mode 100644 smparkin.xcodeproj/project.pbxproj delete mode 100644 smparkin.xcodeproj/project.xcworkspace/contents.xcworkspacedata delete mode 100644 smparkin.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist delete mode 100644 smparkin.xcodeproj/project.xcworkspace/xcuserdata/smparkin.xcuserdatad/UserInterfaceState.xcuserstate delete mode 100644 smparkin.xcodeproj/xcuserdata/smparkin.xcuserdatad/xcschemes/xcschememanagement.plist delete mode 100644 smparkin/Assets.xcassets/AccentColor.colorset/Contents.json delete mode 100644 smparkin/Assets.xcassets/AppIcon.appiconset/Contents.json delete mode 100644 smparkin/Assets.xcassets/Contents.json delete mode 100644 smparkin/ContentView.swift delete mode 100644 smparkin/Log.swift delete mode 100644 smparkin/Preview Content/Preview Assets.xcassets/Contents.json delete mode 100644 smparkin/Server.swift delete mode 100644 smparkin/smparkinApp.swift diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..f51eba7 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,77 @@ +# ================================ +# Build image +# ================================ +FROM swift:5.10.1-jammy AS build + +# Install OS updates and, if needed, sqlite3 +RUN export DEBIAN_FRONTEND=noninteractive DEBCONF_NONINTERACTIVE_SEEN=true \ + && apt-get -q update \ + && apt-get -q dist-upgrade -y\ + && rm -rf /var/lib/apt/lists/* + +# Set up a build area +WORKDIR /build + +# First just resolve dependencies. +# This creates a cached layer that can be reused +# as long as your Package.swift/Package.resolved +# files do not change. +COPY ./Package.* ./ +RUN swift package resolve + +# Copy entire repo into container +COPY . . + +# Build everything, with optimizations +RUN swift build -c release --static-swift-stdlib + +# Switch to the staging area +WORKDIR /staging + +# Copy main executable to staging area +RUN cp "$(swift build --package-path /build -c release --show-bin-path)/Run" ./ + +# Copy resources bundled by SPM to staging area +RUN find -L "$(swift build --package-path /build -c release --show-bin-path)/" -regex '.*\.resources$' -exec cp -Ra {} ./ \; + +# Copy any resources from the public directory and views directory if the directories exist +# Ensure that by default, neither the directory nor any of its contents are writable. +RUN [ -d /build/Public ] && { mv /build/Public ./Public && chmod -R a-w ./Public; } || true +RUN [ -d /build/Resources ] && { mv /build/Resources ./Resources && chmod -R a-w ./Resources; } || true + +# ================================ +# Run image +# ================================ +FROM ubuntu:jammy + +# Make sure all system packages are up to date, and install only essential packages. +RUN export DEBIAN_FRONTEND=noninteractive DEBCONF_NONINTERACTIVE_SEEN=true \ + && apt-get -q update \ + && apt-get -q dist-upgrade -y \ + && apt-get -q install -y \ + ca-certificates \ + tzdata \ +# If your app or its dependencies import FoundationNetworking, also install `libcurl4`. + # libcurl4 \ +# If your app or its dependencies import FoundationXML, also install `libxml2`. + # libxml2 \ + && rm -r /var/lib/apt/lists/* + +# Create a vapor user and group with /app as its home directory +RUN useradd --user-group --create-home --system --skel /dev/null --home-dir /app vapor + +# Switch to the new home directory +WORKDIR /app + +# Copy built executable and any staged resources from builder +COPY --from=build --chown=vapor:vapor /staging /app + +# Ensure all further commands run as the vapor user +USER vapor:vapor + +# Let Docker bind to port 8080 +EXPOSE 8080 + +# Start the Vapor service when the image is run, default to listening on 8080 in production environment +ENTRYPOINT ["./Run"] +CMD ["serve", "--env", "production", "--hostname", "0.0.0.0", "--port", "8080"] diff --git a/smparkin.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved b/Package.resolved similarity index 62% rename from smparkin.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved rename to Package.resolved index 5a731c2..c902b82 100644 --- a/smparkin.xcodeproj/project.xcworkspace/xcshareddata/swiftpm/Package.resolved +++ b/Package.resolved @@ -1,13 +1,12 @@ { - "originHash" : "72522807f64a92bdddb842babbc3889aa60e931be5959af76e1c0e4b69bca532", "pins" : [ { "identity" : "async-http-client", "kind" : "remoteSourceControl", "location" : "https://github.com/swift-server/async-http-client.git", "state" : { - "revision" : "a22083713ee90808d527d0baa290c2fb13ca3096", - "version" : "1.21.1" + "revision" : "864c8d9e0ead5de7ba70b61c8982f89126710863", + "version" : "1.15.0" } }, { @@ -15,8 +14,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/async-kit.git", "state" : { - "revision" : "7ece208cd401687641c88367a00e3ea2b04311f1", - "version" : "1.19.0" + "revision" : "9acea4c92f51a5885c149904f0d11db4712dda80", + "version" : "1.16.0" } }, { @@ -24,8 +23,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/console-kit.git", "state" : { - "revision" : "9c24ac496c97cfb49c1bd5e7162008bb50abafc8", - "version" : "4.14.2" + "revision" : "447f1046fb4e9df40973fe426ecb24a6f0e8d3b4", + "version" : "4.6.0" } }, { @@ -33,8 +32,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/leaf.git", "state" : { - "revision" : "0be8765af9991823c854d97faa4a97db1cfa2643", - "version" : "4.3.0" + "revision" : "6fe0e843c6599f5189e45c7b08739ebc5c410c3b", + "version" : "4.2.4" } }, { @@ -42,8 +41,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/leaf-kit.git", "state" : { - "revision" : "547e48cc5f8d98380dd8a7226ce630d3aa3b2245", - "version" : "1.10.6" + "revision" : "62169b44cc79734e11bf44b8d7154865dee5936b", + "version" : "1.10.1" } }, { @@ -51,8 +50,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/multipart-kit.git", "state" : { - "revision" : "12ee56f25bd3fc4c2d09c2aa16e69de61dc786e8", - "version" : "4.6.0" + "revision" : "0d55c35e788451ee27222783c7d363cb88092fab", + "version" : "4.5.2" } }, { @@ -60,8 +59,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/routing-kit.git", "state" : { - "revision" : "8c9a227476555c55837e569be71944e02a056b72", - "version" : "4.9.1" + "revision" : "ffac7b3a127ce1e85fb232f1a6271164628809ad", + "version" : "4.6.0" } }, { @@ -69,8 +68,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-algorithms.git", "state" : { - "revision" : "f6919dfc309e7f1b56224378b11e28bab5bccc42", - "version" : "1.2.0" + "revision" : "b14b7f4c528c942f121c8b860b9410b2bf57825e", + "version" : "1.0.0" } }, { @@ -78,8 +77,17 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-atomics.git", "state" : { - "revision" : "cd142fd2f64be2100422d658e7411e39489da985", - "version" : "1.2.0" + "revision" : "ff3d2212b6b093db7f177d0855adbc4ef9c5f036", + "version" : "1.0.3" + } + }, + { + "identity" : "swift-backtrace", + "kind" : "remoteSourceControl", + "location" : "https://github.com/swift-server/swift-backtrace.git", + "state" : { + "revision" : "f25620d5d05e2f1ba27154b40cafea2b67566956", + "version" : "1.3.3" } }, { @@ -87,8 +95,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-collections.git", "state" : { - "revision" : "94cf62b3ba8d4bed62680a282d4c25f9c63c2efb", - "version" : "1.1.0" + "revision" : "937e904258d22af6e447a0b72c0bc67583ef64a2", + "version" : "1.0.4" } }, { @@ -96,17 +104,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-crypto.git", "state" : { - "revision" : "bc1c29221f6dfeb0ebbfbc98eb95cd3d4967868e", - "version" : "3.4.0" - } - }, - { - "identity" : "swift-http-types", - "kind" : "remoteSourceControl", - "location" : "https://github.com/apple/swift-http-types", - "state" : { - "revision" : "9bee2fdb79cc740081abd8ebd80738063d632286", - "version" : "1.1.0" + "revision" : "da0fe44138ab86e380f40a2acbd8a611b07d3f64", + "version" : "2.4.0" } }, { @@ -114,8 +113,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-log.git", "state" : { - "revision" : "e97a6fcb1ab07462881ac165fdbb37f067e205d5", - "version" : "1.5.4" + "revision" : "32e8d724467f8fe623624570367e3d50c5638e46", + "version" : "1.5.2" } }, { @@ -123,8 +122,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-metrics.git", "state" : { - "revision" : "eb18581491dfb266a2342f74e0bdd42c14798297", - "version" : "2.4.2" + "revision" : "e8bced74bc6d747745935e469f45d03f048d6cbd", + "version" : "2.3.4" } }, { @@ -132,8 +131,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-nio.git", "state" : { - "revision" : "359c461e5561d22c6334828806cc25d759ca7aa6", - "version" : "2.65.0" + "revision" : "45167b8006448c79dda4b7bd604e07a034c15c49", + "version" : "2.48.0" } }, { @@ -141,8 +140,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-nio-extras.git", "state" : { - "revision" : "a3b640d7dc567225db7c94386a6e71aded1bfa63", - "version" : "1.22.0" + "revision" : "d75ed708d00353acf173ca23018b6bd46f949464", + "version" : "1.17.0" } }, { @@ -150,8 +149,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-nio-http2.git", "state" : { - "revision" : "c6afe04165c865faaa687b42c32ed76dfcc91076", - "version" : "1.31.0" + "revision" : "38feec96bcd929028939107684073554bf01abeb", + "version" : "1.25.2" } }, { @@ -159,8 +158,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-nio-ssl.git", "state" : { - "revision" : "7c381eb6083542b124a6c18fae742f55001dc2b5", - "version" : "2.26.0" + "revision" : "4fb7ead803e38949eb1d6fabb849206a72c580f3", + "version" : "2.23.0" } }, { @@ -168,8 +167,8 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/apple/swift-nio-transport-services.git", "state" : { - "revision" : "38ac8221dd20674682148d6451367f89c2652980", - "version" : "1.21.0" + "revision" : "c0d9a144cfaec8d3d596aadde3039286a266c15c", + "version" : "1.15.0" } }, { @@ -181,22 +180,13 @@ "version" : "1.0.2" } }, - { - "identity" : "swift-system", - "kind" : "remoteSourceControl", - "location" : "https://github.com/apple/swift-system.git", - "state" : { - "revision" : "025bcb1165deab2e20d4eaba79967ce73013f496", - "version" : "1.2.1" - } - }, { "identity" : "vapor", "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/vapor.git", "state" : { - "revision" : "5bc1dfa47e533ed1d20151ebdaff372e900472d9", - "version" : "4.99.3" + "revision" : "bac0fe31e3b186537eb750d44fae048681e2b773", + "version" : "4.74.0" } }, { @@ -204,10 +194,10 @@ "kind" : "remoteSourceControl", "location" : "https://github.com/vapor/websocket-kit.git", "state" : { - "revision" : "4232d34efa49f633ba61afde365d3896fc7f8740", - "version" : "2.15.0" + "revision" : "2b8885974e8d9f522e787805000553f4f7cce8a0", + "version" : "2.7.0" } } ], - "version" : 3 + "version" : 2 } diff --git a/Package.swift b/Package.swift new file mode 100644 index 0000000..7fe7054 --- /dev/null +++ b/Package.swift @@ -0,0 +1,39 @@ +// swift-tools-version:5.7 +import PackageDescription + +let package = Package( + name: "smparkin", + platforms: [ + .macOS(.v13) + ], + dependencies: [ + .package(url: "https://github.com/vapor/vapor.git", .upToNextMajor(from: "4.0.0")), + .package(url: "https://github.com/vapor/leaf.git", .upToNextMajor(from: "4.0.0")), + ], + targets: [ + .target( + name: "App", + dependencies: [ + .product(name: "Vapor", package: "vapor"), + .product(name: "Leaf", package: "leaf") + ], + swiftSettings: [ + .unsafeFlags(["-cross-module-optimization"], .when(configuration: .release)) + ] + ), + .executableTarget( + name: "Run", + dependencies: [ + .target(name: "App") + ] + ), + .testTarget( + name: "AppTests", + dependencies: [ + .target(name: "App"), + .product(name: "XCTVapor", package: "vapor") + ] + ) + ] +) + diff --git a/smparkin/Public/css/404style.css b/Public/css/404style.css similarity index 100% rename from smparkin/Public/css/404style.css rename to Public/css/404style.css diff --git a/smparkin/Public/images/bg.jpg b/Public/images/bg.jpg similarity index 100% rename from smparkin/Public/images/bg.jpg rename to Public/images/bg.jpg diff --git a/smparkin/Public/images/me.jpg b/Public/images/me.jpg similarity index 100% rename from smparkin/Public/images/me.jpg rename to Public/images/me.jpg diff --git a/smparkin/Public/images/trees.jpg b/Public/images/trees.jpg similarity index 100% rename from smparkin/Public/images/trees.jpg rename to Public/images/trees.jpg diff --git a/smparkin/Public/media/gif.gif b/Public/media/gif.gif similarity index 100% rename from smparkin/Public/media/gif.gif rename to Public/media/gif.gif diff --git a/smparkin/Public/media/gif2.gif b/Public/media/gif2.gif similarity index 100% rename from smparkin/Public/media/gif2.gif rename to Public/media/gif2.gif diff --git a/smparkin/Public/media/song.mp3 b/Public/media/song.mp3 similarity index 100% rename from smparkin/Public/media/song.mp3 rename to Public/media/song.mp3 diff --git a/README.md b/README.md new file mode 100644 index 0000000..cc2ec01 --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +smpark.in diff --git a/smparkin/Views/404.leaf b/Resources/Views/404.leaf similarity index 100% rename from smparkin/Views/404.leaf rename to Resources/Views/404.leaf diff --git a/smparkin/Views/home.leaf b/Resources/Views/home.leaf similarity index 77% rename from smparkin/Views/home.leaf rename to Resources/Views/home.leaf index e449a3d..6657c4b 100644 --- a/smparkin/Views/home.leaf +++ b/Resources/Views/home.leaf @@ -15,37 +15,32 @@ background-color: #1e1e1e; padding: 20px; text-align: center; - border-bottom: 2px solid #9370db; + border-bottom: 2px solid #9370db !important; } header h1 { margin: 0; - color: #9370db; + color: #9370db !important; } header img { max-width: 150px; height: auto; border-radius: 50%; - border: 2px solid #9370db; + border: 2px solid #9370db !important; margin: 10px 0; } - nav { - display: flex; - justify-content: center; - flex-wrap: wrap; - margin: 20px 0; - } - nav a { - color: #9370db; + a:link, + a:visited { + color: #9370db !important; text-decoration: none; - margin: 5px 15px; - padding: 10px 20px; - border: 1px solid #9370db; - border-radius: 5px; transition: background-color 0.3s, color 0.3s; } - nav a:hover { - background-color: #9370db; - color: #ffffff; + a:hover { + background-color: #9370db !important; + color: #ffffff !important; + } + a:active { + background-color: #9370db !important; + color: #ffffff !important; } section { max-width: 800px; @@ -61,13 +56,13 @@ display: block; margin: 0 auto 20px auto; border-radius: 10px; - border: 2px solid #9370db; + border: 2px solid #9370db !important; } footer { text-align: center; padding: 20px; background-color: #1e1e1e; - border-top: 2px solid #9370db; + border-top: 2px solid #9370db !important; } @@ -80,10 +75,6 @@

Stephen Parkinson

Systems Development Engineer

-

About Me

I'm doing a lot of stuff with computers right now.

diff --git a/smparkin/Views/privacy.leaf b/Resources/Views/privacy.leaf similarity index 100% rename from smparkin/Views/privacy.leaf rename to Resources/Views/privacy.leaf diff --git a/smparkin/Views/welcome.leaf b/Resources/Views/welcome.leaf similarity index 100% rename from smparkin/Views/welcome.leaf rename to Resources/Views/welcome.leaf diff --git a/Sources/App/configure.swift b/Sources/App/configure.swift new file mode 100644 index 0000000..746898b --- /dev/null +++ b/Sources/App/configure.swift @@ -0,0 +1,15 @@ +import Leaf +import Vapor + +// Called before your application initializes. +public func configure(_ app: Application) throws { + //leaf + app.views.use(.leaf) + + //Register middleware + app.middleware.use(FileMiddleware(publicDirectory: app.directory.publicDirectory)) + app.middleware.use(ErrorMiddleware.default(environment: app.environment)) + + //routes + try routes(app) +} diff --git a/smparkin/Routes.swift b/Sources/App/routes.swift similarity index 100% rename from smparkin/Routes.swift rename to Sources/App/routes.swift diff --git a/Sources/Run/main.swift b/Sources/Run/main.swift new file mode 100644 index 0000000..373be5f --- /dev/null +++ b/Sources/Run/main.swift @@ -0,0 +1,9 @@ +import App +import Vapor + +var env = try Environment.detect() +try LoggingSystem.bootstrap(from: &env) +let app = Application(env) +defer { app.shutdown() } +try configure(app) +try app.run() diff --git a/Tests/AppTests/AppTests.swift b/Tests/AppTests/AppTests.swift new file mode 100644 index 0000000..d915e80 --- /dev/null +++ b/Tests/AppTests/AppTests.swift @@ -0,0 +1,12 @@ +import XCTest +@testable import App + +class AppTests: XCTestCase { + func testStub() throws { + XCTAssert(true) + } + + static let allTests = [ + ("testStub", testStub), + ] +} diff --git a/Tests/LinuxMain.swift b/Tests/LinuxMain.swift new file mode 100644 index 0000000..f78cb77 --- /dev/null +++ b/Tests/LinuxMain.swift @@ -0,0 +1,11 @@ +#if os(Linux) + +import XCTest +@testable import AppTests + +XCTMain([ + // AppTests + testCase(AppTests.allTests), +]) + +#endif diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 0000000..c46e129 --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,30 @@ +# Docker Compose file for Vapor +# +# Install Docker on your system to run and test +# your Vapor app in a production-like environment. +# +# Note: This file is intended for testing and does not +# implement best practices for a production deployment. +# +# Learn more: https://docs.docker.com/compose/reference/ +# +# Build images: docker-compose build +# Start app: docker-compose up app +# Stop all: docker-compose down +# +version: '3.7' + +x-shared_environment: &shared_environment + LOG_LEVEL: ${LOG_LEVEL:-debug} + +services: + app: + image: smparkin:latest + build: + context: . + environment: + <<: *shared_environment + ports: + - '8888:8888' + # user: '0' # uncomment to run as root for testing purposes even though Dockerfile defines 'vapor' user. + command: ["serve", "--env", "production", "--hostname", "0.0.0.0", "--port", "8888"] diff --git a/smparkin.xcodeproj/project.pbxproj b/smparkin.xcodeproj/project.pbxproj deleted file mode 100644 index dd6d023..0000000 --- a/smparkin.xcodeproj/project.pbxproj +++ /dev/null @@ -1,439 +0,0 @@ -// !$*UTF8*$! -{ - archiveVersion = 1; - classes = { - }; - objectVersion = 56; - objects = { - -/* Begin PBXBuildFile section */ - C041F2C22AB021E30011752C /* smparkinApp.swift in Sources */ = {isa = PBXBuildFile; fileRef = C041F2C12AB021E30011752C /* smparkinApp.swift */; }; - C041F2C42AB021E30011752C /* ContentView.swift in Sources */ = {isa = PBXBuildFile; fileRef = C041F2C32AB021E30011752C /* ContentView.swift */; }; - C041F2C62AB021E40011752C /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = C041F2C52AB021E40011752C /* Assets.xcassets */; }; - C041F2C92AB021E40011752C /* Preview Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = C041F2C82AB021E40011752C /* Preview Assets.xcassets */; }; - C041F2D22AB0238F0011752C /* Vapor in Frameworks */ = {isa = PBXBuildFile; productRef = C041F2D12AB0238F0011752C /* Vapor */; }; - C041F2D72AB023CA0011752C /* Leaf in Frameworks */ = {isa = PBXBuildFile; productRef = C041F2D62AB023CA0011752C /* Leaf */; }; - C041F2DA2AB0243C0011752C /* Public in Resources */ = {isa = PBXBuildFile; fileRef = C041F2D82AB0243C0011752C /* Public */; }; - C041F2DD2AB024510011752C /* Routes.swift in Sources */ = {isa = PBXBuildFile; fileRef = C041F2DC2AB024510011752C /* Routes.swift */; }; - C041F2DF2AB0246C0011752C /* Server.swift in Sources */ = {isa = PBXBuildFile; fileRef = C041F2DE2AB0246C0011752C /* Server.swift */; }; - C0C8E2BE2AB0304D00E809B4 /* home.leaf in Resources */ = {isa = PBXBuildFile; fileRef = C0C8E2BB2AB02B6C00E809B4 /* home.leaf */; }; - C0C8E2BF2AB0304D00E809B4 /* privacy.leaf in Resources */ = {isa = PBXBuildFile; fileRef = C0C8E2BC2AB02B6C00E809B4 /* privacy.leaf */; }; - C0C8E2C02AB0304D00E809B4 /* welcome.leaf in Resources */ = {isa = PBXBuildFile; fileRef = C0C8E2BD2AB02B6C00E809B4 /* welcome.leaf */; }; - C0C8E2C12AB0304D00E809B4 /* 404.leaf in Resources */ = {isa = PBXBuildFile; fileRef = C0C8E2BA2AB02B6C00E809B4 /* 404.leaf */; }; - C0C8E2C52AB03D6200E809B4 /* Log.swift in Sources */ = {isa = PBXBuildFile; fileRef = C0C8E2C42AB03D6200E809B4 /* Log.swift */; }; -/* End PBXBuildFile section */ - -/* Begin PBXFileReference section */ - C041F2BE2AB021E30011752C /* smparkin.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = smparkin.app; sourceTree = BUILT_PRODUCTS_DIR; }; - C041F2C12AB021E30011752C /* smparkinApp.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = smparkinApp.swift; sourceTree = ""; }; - C041F2C32AB021E30011752C /* ContentView.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = ContentView.swift; sourceTree = ""; }; - C041F2C52AB021E40011752C /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; - C041F2C82AB021E40011752C /* Preview Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = "Preview Assets.xcassets"; sourceTree = ""; }; - C041F2D82AB0243C0011752C /* Public */ = {isa = PBXFileReference; lastKnownFileType = folder; path = Public; sourceTree = ""; }; - C041F2DC2AB024510011752C /* Routes.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Routes.swift; sourceTree = ""; }; - C041F2DE2AB0246C0011752C /* Server.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Server.swift; sourceTree = ""; }; - C0C8E2BA2AB02B6C00E809B4 /* 404.leaf */ = {isa = PBXFileReference; lastKnownFileType = text; path = 404.leaf; sourceTree = ""; }; - C0C8E2BB2AB02B6C00E809B4 /* home.leaf */ = {isa = PBXFileReference; lastKnownFileType = text; path = home.leaf; sourceTree = ""; }; - C0C8E2BC2AB02B6C00E809B4 /* privacy.leaf */ = {isa = PBXFileReference; lastKnownFileType = text; path = privacy.leaf; sourceTree = ""; }; - C0C8E2BD2AB02B6C00E809B4 /* welcome.leaf */ = {isa = PBXFileReference; lastKnownFileType = text; path = welcome.leaf; sourceTree = ""; }; - C0C8E2C42AB03D6200E809B4 /* Log.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = Log.swift; sourceTree = ""; }; -/* End PBXFileReference section */ - -/* Begin PBXFrameworksBuildPhase section */ - C041F2BB2AB021E30011752C /* Frameworks */ = { - isa = PBXFrameworksBuildPhase; - buildActionMask = 2147483647; - files = ( - C041F2D72AB023CA0011752C /* Leaf in Frameworks */, - C041F2D22AB0238F0011752C /* Vapor in Frameworks */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXFrameworksBuildPhase section */ - -/* Begin PBXGroup section */ - C041F2B52AB021E30011752C = { - isa = PBXGroup; - children = ( - C041F2C02AB021E30011752C /* smparkin */, - C041F2BF2AB021E30011752C /* Products */, - ); - sourceTree = ""; - }; - C041F2BF2AB021E30011752C /* Products */ = { - isa = PBXGroup; - children = ( - C041F2BE2AB021E30011752C /* smparkin.app */, - ); - name = Products; - sourceTree = ""; - }; - C041F2C02AB021E30011752C /* smparkin */ = { - isa = PBXGroup; - children = ( - C041F2C12AB021E30011752C /* smparkinApp.swift */, - C041F2C32AB021E30011752C /* ContentView.swift */, - C041F2DE2AB0246C0011752C /* Server.swift */, - C041F2DC2AB024510011752C /* Routes.swift */, - C0C8E2C42AB03D6200E809B4 /* Log.swift */, - C0C8E2B92AB02B6C00E809B4 /* Views */, - C041F2D82AB0243C0011752C /* Public */, - C041F2C52AB021E40011752C /* Assets.xcassets */, - C041F2C72AB021E40011752C /* Preview Content */, - ); - path = smparkin; - sourceTree = ""; - }; - C041F2C72AB021E40011752C /* Preview Content */ = { - isa = PBXGroup; - children = ( - C041F2C82AB021E40011752C /* Preview Assets.xcassets */, - ); - path = "Preview Content"; - sourceTree = ""; - }; - C0C8E2B92AB02B6C00E809B4 /* Views */ = { - isa = PBXGroup; - children = ( - C0C8E2BA2AB02B6C00E809B4 /* 404.leaf */, - C0C8E2BB2AB02B6C00E809B4 /* home.leaf */, - C0C8E2BC2AB02B6C00E809B4 /* privacy.leaf */, - C0C8E2BD2AB02B6C00E809B4 /* welcome.leaf */, - ); - path = Views; - sourceTree = ""; - }; -/* End PBXGroup section */ - -/* Begin PBXNativeTarget section */ - C041F2BD2AB021E30011752C /* smparkin */ = { - isa = PBXNativeTarget; - buildConfigurationList = C041F2CC2AB021E40011752C /* Build configuration list for PBXNativeTarget "smparkin" */; - buildPhases = ( - C041F2BA2AB021E30011752C /* Sources */, - C041F2BB2AB021E30011752C /* Frameworks */, - C041F2BC2AB021E30011752C /* Resources */, - ); - buildRules = ( - ); - dependencies = ( - ); - name = smparkin; - packageProductDependencies = ( - C041F2D12AB0238F0011752C /* Vapor */, - C041F2D62AB023CA0011752C /* Leaf */, - ); - productName = smparkin; - productReference = C041F2BE2AB021E30011752C /* smparkin.app */; - productType = "com.apple.product-type.application"; - }; -/* End PBXNativeTarget section */ - -/* Begin PBXProject section */ - C041F2B62AB021E30011752C /* Project object */ = { - isa = PBXProject; - attributes = { - BuildIndependentTargetsInParallel = 1; - LastSwiftUpdateCheck = 1500; - LastUpgradeCheck = 1500; - TargetAttributes = { - C041F2BD2AB021E30011752C = { - CreatedOnToolsVersion = 15.0; - }; - }; - }; - buildConfigurationList = C041F2B92AB021E30011752C /* Build configuration list for PBXProject "smparkin" */; - compatibilityVersion = "Xcode 14.0"; - developmentRegion = en; - hasScannedForEncodings = 0; - knownRegions = ( - en, - Base, - ); - mainGroup = C041F2B52AB021E30011752C; - packageReferences = ( - C041F2D02AB0238F0011752C /* XCRemoteSwiftPackageReference "vapor" */, - C041F2D52AB023CA0011752C /* XCRemoteSwiftPackageReference "leaf" */, - ); - productRefGroup = C041F2BF2AB021E30011752C /* Products */; - projectDirPath = ""; - projectRoot = ""; - targets = ( - C041F2BD2AB021E30011752C /* smparkin */, - ); - }; -/* End PBXProject section */ - -/* Begin PBXResourcesBuildPhase section */ - C041F2BC2AB021E30011752C /* Resources */ = { - isa = PBXResourcesBuildPhase; - buildActionMask = 2147483647; - files = ( - C0C8E2BE2AB0304D00E809B4 /* home.leaf in Resources */, - C0C8E2C12AB0304D00E809B4 /* 404.leaf in Resources */, - C041F2C92AB021E40011752C /* Preview Assets.xcassets in Resources */, - C041F2DA2AB0243C0011752C /* Public in Resources */, - C041F2C62AB021E40011752C /* Assets.xcassets in Resources */, - C0C8E2C02AB0304D00E809B4 /* welcome.leaf in Resources */, - C0C8E2BF2AB0304D00E809B4 /* privacy.leaf in Resources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXResourcesBuildPhase section */ - -/* Begin PBXSourcesBuildPhase section */ - C041F2BA2AB021E30011752C /* Sources */ = { - isa = PBXSourcesBuildPhase; - buildActionMask = 2147483647; - files = ( - C041F2DF2AB0246C0011752C /* Server.swift in Sources */, - C041F2C42AB021E30011752C /* ContentView.swift in Sources */, - C0C8E2C52AB03D6200E809B4 /* Log.swift in Sources */, - C041F2C22AB021E30011752C /* smparkinApp.swift in Sources */, - C041F2DD2AB024510011752C /* Routes.swift in Sources */, - ); - runOnlyForDeploymentPostprocessing = 0; - }; -/* End PBXSourcesBuildPhase section */ - -/* Begin XCBuildConfiguration section */ - C041F2CA2AB021E40011752C /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - ALWAYS_SEARCH_USER_PATHS = NO; - ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; - CLANG_ANALYZER_NONNULL = YES; - CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; - CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; - CLANG_ENABLE_MODULES = YES; - CLANG_ENABLE_OBJC_ARC = YES; - CLANG_ENABLE_OBJC_WEAK = YES; - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; - CLANG_WARN_BOOL_CONVERSION = YES; - CLANG_WARN_COMMA = YES; - CLANG_WARN_CONSTANT_CONVERSION = YES; - CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; - CLANG_WARN_DOCUMENTATION_COMMENTS = YES; - CLANG_WARN_EMPTY_BODY = YES; - CLANG_WARN_ENUM_CONVERSION = YES; - CLANG_WARN_INFINITE_RECURSION = YES; - CLANG_WARN_INT_CONVERSION = YES; - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; - CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; - CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; - CLANG_WARN_STRICT_PROTOTYPES = YES; - CLANG_WARN_SUSPICIOUS_MOVE = YES; - CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; - CLANG_WARN_UNREACHABLE_CODE = YES; - CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; - COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = dwarf; - ENABLE_STRICT_OBJC_MSGSEND = YES; - ENABLE_TESTABILITY = YES; - ENABLE_USER_SCRIPT_SANDBOXING = YES; - GCC_C_LANGUAGE_STANDARD = gnu17; - GCC_DYNAMIC_NO_PIC = NO; - GCC_NO_COMMON_BLOCKS = YES; - GCC_OPTIMIZATION_LEVEL = 0; - GCC_PREPROCESSOR_DEFINITIONS = ( - "DEBUG=1", - "$(inherited)", - ); - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; - GCC_WARN_UNDECLARED_SELECTOR = YES; - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; - GCC_WARN_UNUSED_FUNCTION = YES; - GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 17.0; - LOCALIZATION_PREFERS_STRING_CATALOGS = YES; - MTL_ENABLE_DEBUG_INFO = INCLUDE_SOURCE; - MTL_FAST_MATH = YES; - ONLY_ACTIVE_ARCH = YES; - SDKROOT = iphoneos; - SWIFT_ACTIVE_COMPILATION_CONDITIONS = "DEBUG $(inherited)"; - SWIFT_OPTIMIZATION_LEVEL = "-Onone"; - }; - name = Debug; - }; - C041F2CB2AB021E40011752C /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - ALWAYS_SEARCH_USER_PATHS = NO; - ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; - CLANG_ANALYZER_NONNULL = YES; - CLANG_ANALYZER_NUMBER_OBJECT_CONVERSION = YES_AGGRESSIVE; - CLANG_CXX_LANGUAGE_STANDARD = "gnu++20"; - CLANG_ENABLE_MODULES = YES; - CLANG_ENABLE_OBJC_ARC = YES; - CLANG_ENABLE_OBJC_WEAK = YES; - CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; - CLANG_WARN_BOOL_CONVERSION = YES; - CLANG_WARN_COMMA = YES; - CLANG_WARN_CONSTANT_CONVERSION = YES; - CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; - CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; - CLANG_WARN_DOCUMENTATION_COMMENTS = YES; - CLANG_WARN_EMPTY_BODY = YES; - CLANG_WARN_ENUM_CONVERSION = YES; - CLANG_WARN_INFINITE_RECURSION = YES; - CLANG_WARN_INT_CONVERSION = YES; - CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; - CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; - CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; - CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; - CLANG_WARN_QUOTED_INCLUDE_IN_FRAMEWORK_HEADER = YES; - CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; - CLANG_WARN_STRICT_PROTOTYPES = YES; - CLANG_WARN_SUSPICIOUS_MOVE = YES; - CLANG_WARN_UNGUARDED_AVAILABILITY = YES_AGGRESSIVE; - CLANG_WARN_UNREACHABLE_CODE = YES; - CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; - COPY_PHASE_STRIP = NO; - DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; - ENABLE_NS_ASSERTIONS = NO; - ENABLE_STRICT_OBJC_MSGSEND = YES; - ENABLE_USER_SCRIPT_SANDBOXING = YES; - GCC_C_LANGUAGE_STANDARD = gnu17; - GCC_NO_COMMON_BLOCKS = YES; - GCC_WARN_64_TO_32_BIT_CONVERSION = YES; - GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; - GCC_WARN_UNDECLARED_SELECTOR = YES; - GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; - GCC_WARN_UNUSED_FUNCTION = YES; - GCC_WARN_UNUSED_VARIABLE = YES; - IPHONEOS_DEPLOYMENT_TARGET = 17.0; - LOCALIZATION_PREFERS_STRING_CATALOGS = YES; - MTL_ENABLE_DEBUG_INFO = NO; - MTL_FAST_MATH = YES; - SDKROOT = iphoneos; - SWIFT_COMPILATION_MODE = wholemodule; - VALIDATE_PRODUCT = YES; - }; - name = Release; - }; - C041F2CD2AB021E40011752C /* Debug */ = { - isa = XCBuildConfiguration; - buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; - ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor; - CODE_SIGN_IDENTITY = "Apple Development"; - CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 1; - DEVELOPMENT_ASSET_PATHS = "\"smparkin/Preview Content\""; - DEVELOPMENT_TEAM = QR825BQSTL; - ENABLE_PREVIEWS = YES; - GENERATE_INFOPLIST_FILE = YES; - INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES; - INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; - INFOPLIST_KEY_UILaunchScreen_Generation = YES; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - IPHONEOS_DEPLOYMENT_TARGET = 15.0; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/Frameworks", - ); - MARKETING_VERSION = 1.0; - PRODUCT_BUNDLE_IDENTIFIER = in.smpark.smparkin; - PRODUCT_NAME = "$(TARGET_NAME)"; - PROVISIONING_PROFILE_SPECIFIER = ""; - SWIFT_EMIT_LOC_STRINGS = YES; - SWIFT_VERSION = 5.0; - TARGETED_DEVICE_FAMILY = "1,2"; - }; - name = Debug; - }; - C041F2CE2AB021E40011752C /* Release */ = { - isa = XCBuildConfiguration; - buildSettings = { - ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; - ASSETCATALOG_COMPILER_GLOBAL_ACCENT_COLOR_NAME = AccentColor; - CODE_SIGN_IDENTITY = "Apple Development"; - CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 1; - DEVELOPMENT_ASSET_PATHS = "\"smparkin/Preview Content\""; - DEVELOPMENT_TEAM = QR825BQSTL; - ENABLE_PREVIEWS = YES; - GENERATE_INFOPLIST_FILE = YES; - INFOPLIST_KEY_UIApplicationSceneManifest_Generation = YES; - INFOPLIST_KEY_UIApplicationSupportsIndirectInputEvents = YES; - INFOPLIST_KEY_UILaunchScreen_Generation = YES; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPad = "UIInterfaceOrientationPortrait UIInterfaceOrientationPortraitUpsideDown UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - INFOPLIST_KEY_UISupportedInterfaceOrientations_iPhone = "UIInterfaceOrientationPortrait UIInterfaceOrientationLandscapeLeft UIInterfaceOrientationLandscapeRight"; - IPHONEOS_DEPLOYMENT_TARGET = 15.0; - LD_RUNPATH_SEARCH_PATHS = ( - "$(inherited)", - "@executable_path/Frameworks", - ); - MARKETING_VERSION = 1.0; - PRODUCT_BUNDLE_IDENTIFIER = in.smpark.smparkin; - PRODUCT_NAME = "$(TARGET_NAME)"; - PROVISIONING_PROFILE_SPECIFIER = ""; - SWIFT_EMIT_LOC_STRINGS = YES; - SWIFT_VERSION = 5.0; - TARGETED_DEVICE_FAMILY = "1,2"; - }; - name = Release; - }; -/* End XCBuildConfiguration section */ - -/* Begin XCConfigurationList section */ - C041F2B92AB021E30011752C /* Build configuration list for PBXProject "smparkin" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - C041F2CA2AB021E40011752C /* Debug */, - C041F2CB2AB021E40011752C /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; - C041F2CC2AB021E40011752C /* Build configuration list for PBXNativeTarget "smparkin" */ = { - isa = XCConfigurationList; - buildConfigurations = ( - C041F2CD2AB021E40011752C /* Debug */, - C041F2CE2AB021E40011752C /* Release */, - ); - defaultConfigurationIsVisible = 0; - defaultConfigurationName = Release; - }; -/* End XCConfigurationList section */ - -/* Begin XCRemoteSwiftPackageReference section */ - C041F2D02AB0238F0011752C /* XCRemoteSwiftPackageReference "vapor" */ = { - isa = XCRemoteSwiftPackageReference; - repositoryURL = "https://github.com/vapor/vapor.git"; - requirement = { - kind = upToNextMajorVersion; - minimumVersion = 4.81.0; - }; - }; - C041F2D52AB023CA0011752C /* XCRemoteSwiftPackageReference "leaf" */ = { - isa = XCRemoteSwiftPackageReference; - repositoryURL = "https://github.com/vapor/leaf.git"; - requirement = { - kind = upToNextMajorVersion; - minimumVersion = 4.2.4; - }; - }; -/* End XCRemoteSwiftPackageReference section */ - -/* Begin XCSwiftPackageProductDependency section */ - C041F2D12AB0238F0011752C /* Vapor */ = { - isa = XCSwiftPackageProductDependency; - package = C041F2D02AB0238F0011752C /* XCRemoteSwiftPackageReference "vapor" */; - productName = Vapor; - }; - C041F2D62AB023CA0011752C /* Leaf */ = { - isa = XCSwiftPackageProductDependency; - package = C041F2D52AB023CA0011752C /* XCRemoteSwiftPackageReference "leaf" */; - productName = Leaf; - }; -/* End XCSwiftPackageProductDependency section */ - }; - rootObject = C041F2B62AB021E30011752C /* Project object */; -} diff --git a/smparkin.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/smparkin.xcodeproj/project.xcworkspace/contents.xcworkspacedata deleted file mode 100644 index 919434a..0000000 --- a/smparkin.xcodeproj/project.xcworkspace/contents.xcworkspacedata +++ /dev/null @@ -1,7 +0,0 @@ - - - - - diff --git a/smparkin.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/smparkin.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist deleted file mode 100644 index 18d9810..0000000 --- a/smparkin.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist +++ /dev/null @@ -1,8 +0,0 @@ - - - - - IDEDidComputeMac32BitWarning - - - diff --git a/smparkin.xcodeproj/project.xcworkspace/xcuserdata/smparkin.xcuserdatad/UserInterfaceState.xcuserstate b/smparkin.xcodeproj/project.xcworkspace/xcuserdata/smparkin.xcuserdatad/UserInterfaceState.xcuserstate deleted file mode 100644 index 5418b25da93cbb3ceefefe2a1391fa623affa52f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 54573 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 - - - - SchemeUserState - - smparkin.xcscheme_^#shared#^_ - - orderHint - 0 - - - - diff --git a/smparkin/Assets.xcassets/AccentColor.colorset/Contents.json b/smparkin/Assets.xcassets/AccentColor.colorset/Contents.json deleted file mode 100644 index eb87897..0000000 --- a/smparkin/Assets.xcassets/AccentColor.colorset/Contents.json +++ /dev/null @@ -1,11 +0,0 @@ -{ - "colors" : [ - { - "idiom" : "universal" - } - ], - "info" : { - "author" : "xcode", - "version" : 1 - } -} diff --git a/smparkin/Assets.xcassets/AppIcon.appiconset/Contents.json b/smparkin/Assets.xcassets/AppIcon.appiconset/Contents.json deleted file mode 100644 index 13613e3..0000000 --- a/smparkin/Assets.xcassets/AppIcon.appiconset/Contents.json +++ /dev/null @@ -1,13 +0,0 @@ -{ - "images" : [ - { - "idiom" : "universal", - "platform" : "ios", - "size" : "1024x1024" - } - ], - "info" : { - "author" : "xcode", - "version" : 1 - } -} diff --git a/smparkin/Assets.xcassets/Contents.json b/smparkin/Assets.xcassets/Contents.json deleted file mode 100644 index 73c0059..0000000 --- a/smparkin/Assets.xcassets/Contents.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "info" : { - "author" : "xcode", - "version" : 1 - } -} diff --git a/smparkin/ContentView.swift b/smparkin/ContentView.swift deleted file mode 100644 index 166fd04..0000000 --- a/smparkin/ContentView.swift +++ /dev/null @@ -1,29 +0,0 @@ -// -// ContentView.swift -// smparkin -// -// Created by Stephen Parkinson on 9/11/23. -// - -import SwiftUI - -struct ContentView: View { - @StateObject var server: Server = Server(port: 8080) - - var body: some View { - VStack { - Text(ProcessInfo().hostName + ":\(server.port)") - List(server.logs.reversed(), id: \.self) { log in - Text(log) - } - } - .padding() - .onAppear { - server.start() - } - } -} - -#Preview { - ContentView() -} diff --git a/smparkin/Log.swift b/smparkin/Log.swift deleted file mode 100644 index 6d3e552..0000000 --- a/smparkin/Log.swift +++ /dev/null @@ -1,23 +0,0 @@ -// -// Log.swift -// smparkin -// -// Created by Stephen Parkinson on 9/11/23. -// - -import Vapor - -struct LogMiddleware: Middleware { - let server: Server - - init(server: Server) { - self.server = server - } - - func respond(to request: Request, chainingTo next: Responder) -> EventLoopFuture { - DispatchQueue.main.async { - server.logs.append("\(server.dateFormatter.string(from: Date.now)) \(request.url.path)") - } - return next.respond(to: request) - } -} diff --git a/smparkin/Preview Content/Preview Assets.xcassets/Contents.json b/smparkin/Preview Content/Preview Assets.xcassets/Contents.json deleted file mode 100644 index 73c0059..0000000 --- a/smparkin/Preview Content/Preview Assets.xcassets/Contents.json +++ /dev/null @@ -1,6 +0,0 @@ -{ - "info" : { - "author" : "xcode", - "version" : 1 - } -} diff --git a/smparkin/Server.swift b/smparkin/Server.swift deleted file mode 100644 index 4e5a9c8..0000000 --- a/smparkin/Server.swift +++ /dev/null @@ -1,58 +0,0 @@ -import Leaf -import Vapor -import SwiftUI - -class Server: ObservableObject { - @Published var logs: [String] = [String]() - let dateFormatter = ISO8601DateFormatter() - var app: Application - let port: Int - - init(port: Int) { - self.port = port - app = Application(.production) - configure(app) - } - - // Called before your application initializes. - private func configure(_ app: Application) { - app.http.server.configuration.hostname = "0.0.0.0" - app.http.server.configuration.port = port - - //leaf - app.views.use(.leaf) - app.leaf.cache.isEnabled = app.environment.isRelease - app.leaf.configuration.rootDirectory = Bundle.main.bundlePath - - //Register middleware - app.middleware.use(FileMiddleware(publicDirectory: "\(Bundle.main.bundlePath)/\(app.directory.publicDirectory)")) - app.middleware.use(ErrorMiddleware.default(environment: app.environment)) - app.middleware.use(LogMiddleware.init(server: self)) - - //routes - do { - try routes(app) - } catch { - fatalError(error.localizedDescription) - } - } - - func start() { - Task(priority: .userInitiated) { - do { - try app.start() - } catch { - fatalError(error.localizedDescription) - } - } - } - - func stop() { - app.shutdown() - } - - func restart() { - stop() - start() - } -} diff --git a/smparkin/smparkinApp.swift b/smparkin/smparkinApp.swift deleted file mode 100644 index fcd6cd6..0000000 --- a/smparkin/smparkinApp.swift +++ /dev/null @@ -1,17 +0,0 @@ -// -// smparkinApp.swift -// smparkin -// -// Created by Stephen Parkinson on 9/11/23. -// - -import SwiftUI - -@main -struct smparkinApp: App { - var body: some Scene { - WindowGroup { - ContentView() - } - } -}