From d0ef3631b63d0fca8229fe62ffbf31f77cb25d32 Mon Sep 17 00:00:00 2001 From: Arkadiusz Fal Date: Sun, 26 Jun 2022 14:32:15 +0200 Subject: [PATCH] Fix channels URL parsing --- Shared Tests/URLParserTests.swift | 2 ++ Shared/URLParser.swift | 7 +++---- 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/Shared Tests/URLParserTests.swift b/Shared Tests/URLParserTests.swift index 9d7055ed..c7bbaa22 100644 --- a/Shared Tests/URLParserTests.swift +++ b/Shared Tests/URLParserTests.swift @@ -55,6 +55,7 @@ final class URLParserTests: XCTestCase { let parser = URLParser(url: URL(string: url)!) XCTAssertEqual(parser.destination, .channel) XCTAssertEqual(parser.channelName, name) + XCTAssertNil(parser.channelID) } } @@ -63,6 +64,7 @@ final class URLParserTests: XCTestCase { let parser = URLParser(url: URL(string: url)!) XCTAssertEqual(parser.destination, .channel) XCTAssertEqual(parser.channelID, id) + XCTAssertNil(parser.channelName) } } diff --git a/Shared/URLParser.swift b/Shared/URLParser.swift index 46a172b2..85dc31fe 100644 --- a/Shared/URLParser.swift +++ b/Shared/URLParser.swift @@ -75,13 +75,12 @@ struct URLParser { } var channelName: String? { - guard destination == .channel else { return nil } - + guard hasAnyOfPrefixes(path, ["c/", "/c/"]) else { return nil } return removePrefixes(path, Self.prefixes[.channel]!.map { [$0, "/"].joined() }) } var channelID: String? { - guard destination == .channel else { return nil } + guard hasAnyOfPrefixes(path, ["channel/", "/channel/"]) else { return nil } return removePrefixes(path, Self.prefixes[.channel]!.map { [$0, "/"].joined() }) } @@ -95,7 +94,7 @@ struct URLParser { } private func hasAnyOfPrefixes(_ value: String, _ prefixes: [String]) -> Bool { - return prefixes.contains { value.hasPrefix($0) } + prefixes.contains { value.hasPrefix($0) } } private func removePrefixes(_ value: String, _ prefixes: [String]) -> String {