From ca0e34401d8a69c28e1b33f65c4105eb3896b93c Mon Sep 17 00:00:00 2001 From: Honza Dvorsky Date: Fri, 8 Dec 2023 14:12:37 +0100 Subject: [PATCH] [Examples] Auth middlewares: client and server (#440) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit [Examples] Auth middlewares: client and server ### Motivation Show auth client and server middlewares. ### Modifications Added those two examples. ### Result Auth examples in place. ### Test Plan Tested manually together. Reviewed by: simonjbeaumont Builds: ✔︎ pull request validation (5.10) - Build finished. ✔︎ pull request validation (5.9) - Build finished. ✔︎ pull request validation (5.9.0) - Build finished. ✔︎ pull request validation (compatibility test) - Build finished. ✔︎ pull request validation (docc test) - Build finished. ✔︎ pull request validation (examples) - Build finished. ✔︎ pull request validation (integration test) - Build finished. ✔︎ pull request validation (nightly) - Build finished. ✔︎ pull request validation (soundness) - Build finished. https://github.com/apple/swift-openapi-generator/pull/440 --- .../AuthenticationClientMiddleware/.gitignore | 11 ++++ .../Package.swift | 43 ++++++++++++ .../AuthenticationClientMiddleware/README.md | 27 ++++++++ .../AuthenticationClientMiddleware.swift | 42 ++++++++++++ .../HelloWorldURLSessionClient.swift | 37 +++++++++++ .../openapi-generator-config.yaml | 4 ++ .../HelloWorldURLSessionClient/openapi.yaml | 38 +++++++++++ .../AuthenticationServerMiddleware/.gitignore | 11 ++++ .../Package.swift | 41 ++++++++++++ .../AuthenticationServerMiddleware/README.md | 30 +++++++++ .../AuthenticationServerMiddleware.swift | 65 +++++++++++++++++++ .../HelloWorldVaporServer.swift | 63 ++++++++++++++++++ .../openapi-generator-config.yaml | 4 ++ .../HelloWorldVaporServer/openapi.yaml | 38 +++++++++++ .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 5 +- .../MockGreetingService.swift | 2 +- .../openapi-generator-config.yaml | 5 +- .../MockGreetingService.swift | 2 +- .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + .../openapi-generator-config.yaml | 1 + 32 files changed, 476 insertions(+), 6 deletions(-) create mode 100644 Examples/AuthenticationClientMiddleware/.gitignore create mode 100644 Examples/AuthenticationClientMiddleware/Package.swift create mode 100644 Examples/AuthenticationClientMiddleware/README.md create mode 100644 Examples/AuthenticationClientMiddleware/Sources/AuthenticationClientMiddleware/AuthenticationClientMiddleware.swift create mode 100644 Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/HelloWorldURLSessionClient.swift create mode 100644 Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml create mode 100644 Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi.yaml create mode 100644 Examples/AuthenticationServerMiddleware/.gitignore create mode 100644 Examples/AuthenticationServerMiddleware/Package.swift create mode 100644 Examples/AuthenticationServerMiddleware/README.md create mode 100644 Examples/AuthenticationServerMiddleware/Sources/AuthenticationServerMiddleware/AuthenticationServerMiddleware.swift create mode 100644 Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/HelloWorldVaporServer.swift create mode 100644 Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi-generator-config.yaml create mode 100644 Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi.yaml diff --git a/Examples/AuthenticationClientMiddleware/.gitignore b/Examples/AuthenticationClientMiddleware/.gitignore new file mode 100644 index 00000000..f6f5465e --- /dev/null +++ b/Examples/AuthenticationClientMiddleware/.gitignore @@ -0,0 +1,11 @@ +.DS_Store +.build +/Packages +/*.xcodeproj +xcuserdata/ +DerivedData/ +.swiftpm/xcode/package.xcworkspace/contents.xcworkspacedata +.vscode +/Package.resolved +.ci/ +.docc-build/ diff --git a/Examples/AuthenticationClientMiddleware/Package.swift b/Examples/AuthenticationClientMiddleware/Package.swift new file mode 100644 index 00000000..84c65297 --- /dev/null +++ b/Examples/AuthenticationClientMiddleware/Package.swift @@ -0,0 +1,43 @@ +// swift-tools-version:5.9 +//===----------------------------------------------------------------------===// +// +// This source file is part of the SwiftOpenAPIGenerator open source project +// +// Copyright (c) 2023 Apple Inc. and the SwiftOpenAPIGenerator project authors +// Licensed under Apache License v2.0 +// +// See LICENSE.txt for license information +// See CONTRIBUTORS.txt for the list of SwiftOpenAPIGenerator project authors +// +// SPDX-License-Identifier: Apache-2.0 +// +//===----------------------------------------------------------------------===// +import PackageDescription + +let package = Package( + name: "AuthenticationClientMiddleware", + platforms: [.macOS(.v11), .iOS(.v14), .tvOS(.v14), .watchOS(.v7), .visionOS(.v1)], + dependencies: [ + .package(url: "https://github.com/apple/swift-openapi-generator", exact: "1.0.0-alpha.1"), + .package(url: "https://github.com/apple/swift-openapi-runtime", exact: "1.0.0-alpha.1"), + .package(url: "https://github.com/apple/swift-openapi-urlsession", exact: "1.0.0-alpha.1"), + .package(url: "https://github.com/apple/swift-http-types", from: "1.0.0"), + ], + targets: [ + .target( + name: "AuthenticationClientMiddleware", + dependencies: [ + .product(name: "OpenAPIRuntime", package: "swift-openapi-runtime"), + .product(name: "HTTPTypes", package: "swift-http-types"), + ] + ), + .executableTarget( + name: "HelloWorldURLSessionClient", + dependencies: [ + "AuthenticationClientMiddleware", .product(name: "OpenAPIRuntime", package: "swift-openapi-runtime"), + .product(name: "OpenAPIURLSession", package: "swift-openapi-urlsession"), + ], + plugins: [.plugin(name: "OpenAPIGenerator", package: "swift-openapi-generator")] + ), + ] +) diff --git a/Examples/AuthenticationClientMiddleware/README.md b/Examples/AuthenticationClientMiddleware/README.md new file mode 100644 index 00000000..495a1bd4 --- /dev/null +++ b/Examples/AuthenticationClientMiddleware/README.md @@ -0,0 +1,27 @@ +# Client Authentication Middleware + +In this example we'll implement a `ClientMiddleware` that injects an authentication header into the request. + +## Overview + +This example extends the [HelloWorldURLSessionClient](../HelloWorldURLSessionClient) +with a new target, `AuthenticationClientMiddleware`, which is then used when creating +the `Client`. + +NOTE: This example shows just one way of injecting authentication information in a middleware +and is purely for illustrative purposes. + +The tool uses the [URLSession](https://developer.apple.com/documentation/foundation/urlsession) API to perform the HTTP call, wrapped in the [Swift OpenAPI URLSession Transport](https://github.com/apple/swift-openapi-urlsession). + +The server can be started by running the `AuthenticationServerMiddleware` example locally. + +## Usage + +Build and run the client CLI using: + +``` +$ swift run HelloWorldURLSessionClient token_for_Fr +Hello, Stranger! (Requested by: Frank) +$ swift run HelloWorldURLSessionClient invalid_token +Unauthorized +``` diff --git a/Examples/AuthenticationClientMiddleware/Sources/AuthenticationClientMiddleware/AuthenticationClientMiddleware.swift b/Examples/AuthenticationClientMiddleware/Sources/AuthenticationClientMiddleware/AuthenticationClientMiddleware.swift new file mode 100644 index 00000000..d3e88624 --- /dev/null +++ b/Examples/AuthenticationClientMiddleware/Sources/AuthenticationClientMiddleware/AuthenticationClientMiddleware.swift @@ -0,0 +1,42 @@ +//===----------------------------------------------------------------------===// +// +// This source file is part of the SwiftOpenAPIGenerator open source project +// +// Copyright (c) 2023 Apple Inc. and the SwiftOpenAPIGenerator project authors +// Licensed under Apache License v2.0 +// +// See LICENSE.txt for license information +// See CONTRIBUTORS.txt for the list of SwiftOpenAPIGenerator project authors +// +// SPDX-License-Identifier: Apache-2.0 +// +//===----------------------------------------------------------------------===// +import OpenAPIRuntime +import Foundation +import HTTPTypes + +/// A client middleware that injects a value into the `Authorization` header field of the request. +package struct AuthenticationMiddleware { + + /// The value for the `Authorization` header field. + private let value: String + + /// Creates a new middleware. + /// - Parameter value: The value for the `Authorization` header field. + package init(authorizationHeaderFieldValue value: String) { self.value = value } +} + +extension AuthenticationMiddleware: ClientMiddleware { + package func intercept( + _ request: HTTPRequest, + body: HTTPBody?, + baseURL: URL, + operationID: String, + next: (HTTPRequest, HTTPBody?, URL) async throws -> (HTTPResponse, HTTPBody?) + ) async throws -> (HTTPResponse, HTTPBody?) { + var request = request + // Adds the `Authorization` header field with the provided value. + request.headerFields[.authorization] = value + return try await next(request, body, baseURL) + } +} diff --git a/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/HelloWorldURLSessionClient.swift b/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/HelloWorldURLSessionClient.swift new file mode 100644 index 00000000..1182bb25 --- /dev/null +++ b/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/HelloWorldURLSessionClient.swift @@ -0,0 +1,37 @@ +//===----------------------------------------------------------------------===// +// +// This source file is part of the SwiftOpenAPIGenerator open source project +// +// Copyright (c) 2023 Apple Inc. and the SwiftOpenAPIGenerator project authors +// Licensed under Apache License v2.0 +// +// See LICENSE.txt for license information +// See CONTRIBUTORS.txt for the list of SwiftOpenAPIGenerator project authors +// +// SPDX-License-Identifier: Apache-2.0 +// +//===----------------------------------------------------------------------===// +import OpenAPIURLSession +import Foundation +import AuthenticationClientMiddleware + +@main struct HelloWorldURLSessionClient { + static func main() async throws { + let args = CommandLine.arguments + guard args.count == 2 else { + print("Requires a token") + exit(1) + } + let client = Client( + serverURL: URL(string: "http://localhost:8080/api")!, + transport: URLSessionTransport(), + middlewares: [AuthenticationMiddleware(authorizationHeaderFieldValue: args[1])] + ) + let response = try await client.getGreeting() + switch response { + case .ok(let okResponse): print(try okResponse.body.json.message) + case .unauthorized: print("Unauthorized") + case .undocumented(statusCode: let statusCode, _): print("Undocumented status code: \(statusCode)") + } + } +} diff --git a/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml b/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml new file mode 100644 index 00000000..1df6f287 --- /dev/null +++ b/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml @@ -0,0 +1,4 @@ +generate: + - types + - client +accessModifier: internal diff --git a/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi.yaml b/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi.yaml new file mode 100644 index 00000000..9552d513 --- /dev/null +++ b/Examples/AuthenticationClientMiddleware/Sources/HelloWorldURLSessionClient/openapi.yaml @@ -0,0 +1,38 @@ +openapi: '3.1.0' +info: + title: GreetingService + version: 1.0.0 +servers: + - url: https://example.com/api + description: Example service deployment. +paths: + /greet: + get: + operationId: getGreeting + parameters: + - name: name + required: false + in: query + description: The name used in the returned greeting. + schema: + type: string + responses: + '200': + description: A success response with a greeting. + content: + application/json: + schema: + $ref: '#/components/schemas/Greeting' + '401': + description: Authentication required. +components: + schemas: + Greeting: + type: object + description: A value with the greeting contents. + properties: + message: + type: string + description: The string representation of the greeting. + required: + - message diff --git a/Examples/AuthenticationServerMiddleware/.gitignore b/Examples/AuthenticationServerMiddleware/.gitignore new file mode 100644 index 00000000..f6f5465e --- /dev/null +++ b/Examples/AuthenticationServerMiddleware/.gitignore @@ -0,0 +1,11 @@ +.DS_Store +.build +/Packages +/*.xcodeproj +xcuserdata/ +DerivedData/ +.swiftpm/xcode/package.xcworkspace/contents.xcworkspacedata +.vscode +/Package.resolved +.ci/ +.docc-build/ diff --git a/Examples/AuthenticationServerMiddleware/Package.swift b/Examples/AuthenticationServerMiddleware/Package.swift new file mode 100644 index 00000000..9f8a9f3f --- /dev/null +++ b/Examples/AuthenticationServerMiddleware/Package.swift @@ -0,0 +1,41 @@ +// swift-tools-version:5.9 +//===----------------------------------------------------------------------===// +// +// This source file is part of the SwiftOpenAPIGenerator open source project +// +// Copyright (c) 2023 Apple Inc. and the SwiftOpenAPIGenerator project authors +// Licensed under Apache License v2.0 +// +// See LICENSE.txt for license information +// See CONTRIBUTORS.txt for the list of SwiftOpenAPIGenerator project authors +// +// SPDX-License-Identifier: Apache-2.0 +// +//===----------------------------------------------------------------------===// +import PackageDescription + +let package = Package( + name: "AuthenticationServerMiddleware", + platforms: [.macOS(.v10_15)], + dependencies: [ + .package(url: "https://github.com/apple/swift-openapi-generator", exact: "1.0.0-alpha.1"), + .package(url: "https://github.com/apple/swift-openapi-runtime", exact: "1.0.0-alpha.1"), + .package(url: "https://github.com/swift-server/swift-openapi-vapor", exact: "1.0.0-alpha.1"), + .package(url: "https://github.com/vapor/vapor", from: "4.87.1"), + ], + targets: [ + .target( + name: "AuthenticationServerMiddleware", + dependencies: [.product(name: "OpenAPIRuntime", package: "swift-openapi-runtime")] + ), + .executableTarget( + name: "HelloWorldVaporServer", + dependencies: [ + "AuthenticationServerMiddleware", .product(name: "OpenAPIRuntime", package: "swift-openapi-runtime"), + .product(name: "OpenAPIVapor", package: "swift-openapi-vapor"), + .product(name: "Vapor", package: "vapor"), + ], + plugins: [.plugin(name: "OpenAPIGenerator", package: "swift-openapi-generator")] + ), + ] +) diff --git a/Examples/AuthenticationServerMiddleware/README.md b/Examples/AuthenticationServerMiddleware/README.md new file mode 100644 index 00000000..4978ef1b --- /dev/null +++ b/Examples/AuthenticationServerMiddleware/README.md @@ -0,0 +1,30 @@ +# Server Authentication Server + +In this example we'll implement a `ServerMiddleware` that verifies an authentication header in the request. + +## Overview + +This example extends the [HelloWorldVaporServer](../HelloWorldVaporServer) with a new target, `AuthenticationServerMiddleware`, which is then used when registering the server handler with the transport. + +NOTE: This example shows just one way of varifying authentication information in a middleware and is purely for illustrative purposes. + +The tool uses the [Vapor](https://github.com/vapor/vapor) server framework to handle HTTP requests, wrapped in the [Swift OpenAPI Vapor Transport](https://github.com/swift-server/swift-openapi-vapor). + +The CLI starts the server on `http://localhost:8080` and can be invoked by running the `AuthenticationClientMiddleware` example client or on the command line using: + +``` +$ curl -H 'Authorization: token_for_Frank' 'http://localhost:8080/api/greet?name=Jane' +{ + "message" : "Hello, Jane! (Requested by: Frank)" +} +``` + +## Usage + +Build and run the server CLI using: + +``` +$ swift run +2023-12-01T14:14:35+0100 notice codes.vapor.application : [Vapor] Server starting on http://127.0.0.1:8080 +... +``` diff --git a/Examples/AuthenticationServerMiddleware/Sources/AuthenticationServerMiddleware/AuthenticationServerMiddleware.swift b/Examples/AuthenticationServerMiddleware/Sources/AuthenticationServerMiddleware/AuthenticationServerMiddleware.swift new file mode 100644 index 00000000..dcbced32 --- /dev/null +++ b/Examples/AuthenticationServerMiddleware/Sources/AuthenticationServerMiddleware/AuthenticationServerMiddleware.swift @@ -0,0 +1,65 @@ +//===----------------------------------------------------------------------===// +// +// This source file is part of the SwiftOpenAPIGenerator open source project +// +// Copyright (c) 2023 Apple Inc. and the SwiftOpenAPIGenerator project authors +// Licensed under Apache License v2.0 +// +// See LICENSE.txt for license information +// See CONTRIBUTORS.txt for the list of SwiftOpenAPIGenerator project authors +// +// SPDX-License-Identifier: Apache-2.0 +// +//===----------------------------------------------------------------------===// +import OpenAPIRuntime +import HTTPTypes + +/// A server middleware that authenticates the incoming user based on the value of +/// the `Authorization` header field and injects the identifier `User` information +/// into a task local value, allowing the request handler to use it. +package struct AuthenticationServerMiddleware: Sendable { + + /// Information about an authenticated user. + package struct User: Hashable { + + /// The name of the authenticated user. + package var name: String + + /// Creates a new user. + /// - Parameter name: The name of the authenticated user. + package init(name: String) { self.name = name } + + /// The task local value of the currently authenticated user. + @TaskLocal package static var current: User? + } + + /// The closure that authenticates the user based on the value of the `Authorization` + /// header field. + private let authenticate: @Sendable (String) -> User? + + /// Creates a new middleware. + /// - Parameter authenticate: The closure that authenticates the user based on the value + /// of the `Authorization` header field. + package init(authenticate: @Sendable @escaping (String) -> User?) { self.authenticate = authenticate } +} + +extension AuthenticationServerMiddleware: ServerMiddleware { + package func intercept( + _ request: HTTPRequest, + body: HTTPBody?, + metadata: ServerRequestMetadata, + operationID: String, + next: @Sendable (HTTPRequest, HTTPBody?, ServerRequestMetadata) async throws -> (HTTPResponse, HTTPBody?) + ) async throws -> (HTTPResponse, HTTPBody?) { + // Extracts the `Authorization` value, if present. + // If no `Authorization` header field value was provided, no User is injected into + // the task local. + guard let authorizationHeaderFieldValue = request.headerFields[.authorization] else { + return try await next(request, body, metadata) + } + // Delegate the authentication logic to the closure. + let user = authenticate(authorizationHeaderFieldValue) + // Inject the authenticated user into the task local and call the next middleware. + return try await User.$current.withValue(user) { try await next(request, body, metadata) } + } +} diff --git a/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/HelloWorldVaporServer.swift b/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/HelloWorldVaporServer.swift new file mode 100644 index 00000000..7d76835a --- /dev/null +++ b/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/HelloWorldVaporServer.swift @@ -0,0 +1,63 @@ +//===----------------------------------------------------------------------===// +// +// This source file is part of the SwiftOpenAPIGenerator open source project +// +// Copyright (c) 2023 Apple Inc. and the SwiftOpenAPIGenerator project authors +// Licensed under Apache License v2.0 +// +// See LICENSE.txt for license information +// See CONTRIBUTORS.txt for the list of SwiftOpenAPIGenerator project authors +// +// SPDX-License-Identifier: Apache-2.0 +// +//===----------------------------------------------------------------------===// +import OpenAPIRuntime +import OpenAPIVapor +import Vapor +import AuthenticationServerMiddleware + +struct Handler: APIProtocol { + func getGreeting(_ input: Operations.getGreeting.Input) async throws -> Operations.getGreeting.Output { + // Extract the authenticated user, if present. + // If unauthenticated, return the 401 HTTP status code. + // Note that the 401 is defined in the OpenAPI document, allowing the client + // to easily detect this condition and provide the correct authentication credentails + // on the next request. + guard let user = AuthenticationServerMiddleware.User.current else { return .unauthorized(.init()) } + let name = input.query.name ?? "Stranger" + // Include the name of the authenticated user in the greeting. + return .ok(.init(body: .json(.init(message: "Hello, \(name)! (Requested by: \(user.name))")))) + } +} + +@main struct HelloWorldVaporServer { + static func main() throws { + let app = Vapor.Application() + let transport = VaporTransport(routesBuilder: app) + let handler = Handler() + try handler.registerHandlers( + on: transport, + serverURL: URL(string: "/api")!, + middlewares: [ + AuthenticationServerMiddleware(authenticate: { stringValue in + // Warning: this is an overly simplified authentication strategy, checking + // for well-known tokens. + // + // In your project, here you would likely call out to a library that performs + // a cryptographic validation, or similar. + // + // The code is for illustrative purposes only and should not be used directly. + switch stringValue { + case "token_for_Frank": + // A known user authenticated. + return .init(name: "Frank") + default: + // Unknown credentials, no authenticated user. + return nil + } + }) + ] + ) + try app.run() + } +} diff --git a/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi-generator-config.yaml b/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi-generator-config.yaml new file mode 100644 index 00000000..f68d9c85 --- /dev/null +++ b/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi-generator-config.yaml @@ -0,0 +1,4 @@ +generate: + - types + - server +accessModifier: internal diff --git a/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi.yaml b/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi.yaml new file mode 100644 index 00000000..9552d513 --- /dev/null +++ b/Examples/AuthenticationServerMiddleware/Sources/HelloWorldVaporServer/openapi.yaml @@ -0,0 +1,38 @@ +openapi: '3.1.0' +info: + title: GreetingService + version: 1.0.0 +servers: + - url: https://example.com/api + description: Example service deployment. +paths: + /greet: + get: + operationId: getGreeting + parameters: + - name: name + required: false + in: query + description: The name used in the returned greeting. + schema: + type: string + responses: + '200': + description: A success response with a greeting. + content: + application/json: + schema: + $ref: '#/components/schemas/Greeting' + '401': + description: Authentication required. +components: + schemas: + Greeting: + type: object + description: A value with the greeting contents. + properties: + message: + type: string + description: The string representation of the greeting. + required: + - message diff --git a/Examples/CommandLineClient/Sources/CommandLineClient/openapi-generator-config.yaml b/Examples/CommandLineClient/Sources/CommandLineClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/CommandLineClient/Sources/CommandLineClient/openapi-generator-config.yaml +++ b/Examples/CommandLineClient/Sources/CommandLineClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/CommandPluginInvocationClient/Sources/CommandPluginInvocationClient/openapi-generator-config.yaml b/Examples/CommandPluginInvocationClient/Sources/CommandPluginInvocationClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/CommandPluginInvocationClient/Sources/CommandPluginInvocationClient/openapi-generator-config.yaml +++ b/Examples/CommandPluginInvocationClient/Sources/CommandPluginInvocationClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/ContentTypesClient/Sources/ContentTypesClient/openapi-generator-config.yaml b/Examples/ContentTypesClient/Sources/ContentTypesClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/ContentTypesClient/Sources/ContentTypesClient/openapi-generator-config.yaml +++ b/Examples/ContentTypesClient/Sources/ContentTypesClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/ContentTypesServer/Sources/ContentTypesServer/openapi-generator-config.yaml b/Examples/ContentTypesServer/Sources/ContentTypesServer/openapi-generator-config.yaml index 2a087488..f68d9c85 100644 --- a/Examples/ContentTypesServer/Sources/ContentTypesServer/openapi-generator-config.yaml +++ b/Examples/ContentTypesServer/Sources/ContentTypesServer/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - server +accessModifier: internal diff --git a/Examples/GreetingService/Sources/GreetingService/openapi-generator-config.yaml b/Examples/GreetingService/Sources/GreetingService/openapi-generator-config.yaml index ad18076a..f68d9c85 100644 --- a/Examples/GreetingService/Sources/GreetingService/openapi-generator-config.yaml +++ b/Examples/GreetingService/Sources/GreetingService/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: -- types -- server + - types + - server +accessModifier: internal diff --git a/Examples/GreetingService/Tests/GreetingServiceMockTests/MockGreetingService.swift b/Examples/GreetingService/Tests/GreetingServiceMockTests/MockGreetingService.swift index 3b55107e..f89e2216 100644 --- a/Examples/GreetingService/Tests/GreetingServiceMockTests/MockGreetingService.swift +++ b/Examples/GreetingService/Tests/GreetingServiceMockTests/MockGreetingService.swift @@ -11,7 +11,7 @@ // SPDX-License-Identifier: Apache-2.0 // //===----------------------------------------------------------------------===// -import GreetingService +@testable import GreetingService // Mock operates on value types, and requires no concrete client or server transport. struct MockGreetingService: APIProtocol { diff --git a/Examples/GreetingServiceClient/Sources/GreetingServiceClient/openapi-generator-config.yaml b/Examples/GreetingServiceClient/Sources/GreetingServiceClient/openapi-generator-config.yaml index 4355afb3..1df6f287 100644 --- a/Examples/GreetingServiceClient/Sources/GreetingServiceClient/openapi-generator-config.yaml +++ b/Examples/GreetingServiceClient/Sources/GreetingServiceClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: -- types -- client + - types + - client +accessModifier: internal diff --git a/Examples/GreetingServiceClient/Tests/GreetingServiceMockTests/MockGreetingService.swift b/Examples/GreetingServiceClient/Tests/GreetingServiceMockTests/MockGreetingService.swift index ffe47d96..f6de757c 100644 --- a/Examples/GreetingServiceClient/Tests/GreetingServiceMockTests/MockGreetingService.swift +++ b/Examples/GreetingServiceClient/Tests/GreetingServiceMockTests/MockGreetingService.swift @@ -11,7 +11,7 @@ // SPDX-License-Identifier: Apache-2.0 // //===----------------------------------------------------------------------===// -import GreetingServiceClient +@testable import GreetingServiceClient // Mock operates on value types, and requires no concrete client or server transport. struct MockGreetingService: APIProtocol { diff --git a/Examples/HelloWorldAsyncHTTPClient/Sources/HelloWorldAsyncHTTPClient/openapi-generator-config.yaml b/Examples/HelloWorldAsyncHTTPClient/Sources/HelloWorldAsyncHTTPClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/HelloWorldAsyncHTTPClient/Sources/HelloWorldAsyncHTTPClient/openapi-generator-config.yaml +++ b/Examples/HelloWorldAsyncHTTPClient/Sources/HelloWorldAsyncHTTPClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/HelloWorldHummingbirdServer/Sources/HelloWorldHummingbirdServer/openapi-generator-config.yaml b/Examples/HelloWorldHummingbirdServer/Sources/HelloWorldHummingbirdServer/openapi-generator-config.yaml index 2a087488..f68d9c85 100644 --- a/Examples/HelloWorldHummingbirdServer/Sources/HelloWorldHummingbirdServer/openapi-generator-config.yaml +++ b/Examples/HelloWorldHummingbirdServer/Sources/HelloWorldHummingbirdServer/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - server +accessModifier: internal diff --git a/Examples/HelloWorldURLSessionClient/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml b/Examples/HelloWorldURLSessionClient/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/HelloWorldURLSessionClient/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml +++ b/Examples/HelloWorldURLSessionClient/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/HelloWorldVaporServer/Sources/HelloWorldVaporServer/openapi-generator-config.yaml b/Examples/HelloWorldVaporServer/Sources/HelloWorldVaporServer/openapi-generator-config.yaml index 2a087488..f68d9c85 100644 --- a/Examples/HelloWorldVaporServer/Sources/HelloWorldVaporServer/openapi-generator-config.yaml +++ b/Examples/HelloWorldVaporServer/Sources/HelloWorldVaporServer/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - server +accessModifier: internal diff --git a/Examples/LoggingMiddlewareOSLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml b/Examples/LoggingMiddlewareOSLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/LoggingMiddlewareOSLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml +++ b/Examples/LoggingMiddlewareOSLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/LoggingMiddlewareSwiftLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml b/Examples/LoggingMiddlewareSwiftLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/LoggingMiddlewareSwiftLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml +++ b/Examples/LoggingMiddlewareSwiftLog/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/ManualGeneratorInvocationClient/openapi-generator-config.yaml b/Examples/ManualGeneratorInvocationClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/ManualGeneratorInvocationClient/openapi-generator-config.yaml +++ b/Examples/ManualGeneratorInvocationClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/PostgresDatabaseServer/Sources/PostgresDatabaseServer/openapi-generator-config.yaml b/Examples/PostgresDatabaseServer/Sources/PostgresDatabaseServer/openapi-generator-config.yaml index 2a087488..f68d9c85 100644 --- a/Examples/PostgresDatabaseServer/Sources/PostgresDatabaseServer/openapi-generator-config.yaml +++ b/Examples/PostgresDatabaseServer/Sources/PostgresDatabaseServer/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - server +accessModifier: internal diff --git a/Examples/RetryingClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml b/Examples/RetryingClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml index ecefb471..1df6f287 100644 --- a/Examples/RetryingClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml +++ b/Examples/RetryingClientMiddleware/Sources/HelloWorldURLSessionClient/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - client +accessModifier: internal diff --git a/Examples/SwaggerUIEndpointsServer/Sources/SwaggerUIEndpointsServer/openapi-generator-config.yaml b/Examples/SwaggerUIEndpointsServer/Sources/SwaggerUIEndpointsServer/openapi-generator-config.yaml index 2a087488..f68d9c85 100644 --- a/Examples/SwaggerUIEndpointsServer/Sources/SwaggerUIEndpointsServer/openapi-generator-config.yaml +++ b/Examples/SwaggerUIEndpointsServer/Sources/SwaggerUIEndpointsServer/openapi-generator-config.yaml @@ -1,3 +1,4 @@ generate: - types - server +accessModifier: internal