first commit
This commit is contained in:
commit
ce95ce5856
2
.dockerignore
Normal file
2
.dockerignore
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
.build/
|
||||||
|
.swiftpm/
|
9
.gitignore
vendored
Normal file
9
.gitignore
vendored
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
Packages
|
||||||
|
.build
|
||||||
|
xcuserdata
|
||||||
|
*.xcodeproj
|
||||||
|
DerivedData/
|
||||||
|
.DS_Store
|
||||||
|
db.sqlite
|
||||||
|
.swiftpm
|
||||||
|
|
65
Dockerfile
Normal file
65
Dockerfile
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
# ================================
|
||||||
|
# Build image
|
||||||
|
# ================================
|
||||||
|
FROM swift:5.4-focal 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
|
||||||
|
|
||||||
|
# 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 any resouces 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 swift:5.4-focal-slim
|
||||||
|
|
||||||
|
# Make sure all system packages are up to date.
|
||||||
|
RUN export DEBIAN_FRONTEND=noninteractive DEBCONF_NONINTERACTIVE_SEEN=true && \
|
||||||
|
apt-get -q update && apt-get -q dist-upgrade -y && 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"]
|
32
Package.swift
Normal file
32
Package.swift
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
// swift-tools-version:5.2
|
||||||
|
import PackageDescription
|
||||||
|
|
||||||
|
let package = Package(
|
||||||
|
name: "FestivalServer",
|
||||||
|
platforms: [
|
||||||
|
.macOS(.v10_15)
|
||||||
|
],
|
||||||
|
dependencies: [
|
||||||
|
// 💧 A server-side Swift web framework.
|
||||||
|
.package(url: "https://github.com/vapor/vapor.git", from: "4.0.0"),
|
||||||
|
],
|
||||||
|
targets: [
|
||||||
|
.target(
|
||||||
|
name: "App",
|
||||||
|
dependencies: [
|
||||||
|
.product(name: "Vapor", package: "vapor")
|
||||||
|
],
|
||||||
|
swiftSettings: [
|
||||||
|
// Enable better optimizations when building in Release configuration. Despite the use of
|
||||||
|
// the `.unsafeFlags` construct required by SwiftPM, this flag is recommended for Release
|
||||||
|
// builds. See <https://github.com/swift-server/guides/blob/main/docs/building.md#building-for-production> for details.
|
||||||
|
.unsafeFlags(["-cross-module-optimization"], .when(configuration: .release))
|
||||||
|
]
|
||||||
|
),
|
||||||
|
.target(name: "Run", dependencies: [.target(name: "App")]),
|
||||||
|
.testTarget(name: "AppTests", dependencies: [
|
||||||
|
.target(name: "App"),
|
||||||
|
.product(name: "XCTVapor", package: "vapor"),
|
||||||
|
])
|
||||||
|
]
|
||||||
|
)
|
0
Sources/App/Controllers/.gitkeep
Normal file
0
Sources/App/Controllers/.gitkeep
Normal file
10
Sources/App/configure.swift
Normal file
10
Sources/App/configure.swift
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
import Vapor
|
||||||
|
|
||||||
|
// configures your application
|
||||||
|
public func configure(_ app: Application) throws {
|
||||||
|
// uncomment to serve files from /Public folder
|
||||||
|
// app.middleware.use(FileMiddleware(publicDirectory: app.directory.publicDirectory))
|
||||||
|
|
||||||
|
// register routes
|
||||||
|
try routes(app)
|
||||||
|
}
|
11
Sources/App/routes.swift
Normal file
11
Sources/App/routes.swift
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import Vapor
|
||||||
|
|
||||||
|
func routes(_ app: Application) throws {
|
||||||
|
app.get { req in
|
||||||
|
return "It works!"
|
||||||
|
}
|
||||||
|
|
||||||
|
app.get("hello") { req -> String in
|
||||||
|
return "Hello, world!"
|
||||||
|
}
|
||||||
|
}
|
9
Sources/Run/main.swift
Normal file
9
Sources/Run/main.swift
Normal file
@ -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()
|
15
Tests/AppTests/AppTests.swift
Normal file
15
Tests/AppTests/AppTests.swift
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
@testable import App
|
||||||
|
import XCTVapor
|
||||||
|
|
||||||
|
final class AppTests: XCTestCase {
|
||||||
|
func testHelloWorld() throws {
|
||||||
|
let app = Application(.testing)
|
||||||
|
defer { app.shutdown() }
|
||||||
|
try configure(app)
|
||||||
|
|
||||||
|
try app.test(.GET, "hello", afterResponse: { res in
|
||||||
|
XCTAssertEqual(res.status, .ok)
|
||||||
|
XCTAssertEqual(res.body.string, "Hello, world!")
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
30
docker-compose.yml
Normal file
30
docker-compose.yml
Normal file
@ -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: festival-server:latest
|
||||||
|
build:
|
||||||
|
context: .
|
||||||
|
environment:
|
||||||
|
<<: *shared_environment
|
||||||
|
ports:
|
||||||
|
- '8080:8080'
|
||||||
|
# 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", "8080"]
|
Loading…
Reference in New Issue
Block a user