forked from karelia/KSFileUtilities
-
Notifications
You must be signed in to change notification settings - Fork 0
/
KSURLComponents.h
129 lines (106 loc) · 5.99 KB
/
KSURLComponents.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
//
// KSURLComponents.h
// KSFileUtilities
//
// Created by Mike Abdullah on 06/07/2013.
// Copyright © 2013 Karelia Software
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
//
#import <Foundation/Foundation.h>
@interface KSURLComponents : NSObject <NSCopying>
{
@private
NSString *_schemeComponent;
NSString *_userComponent;
NSString *_passwordComponent;
NSString *_hostComponent;
NSNumber *_portComponent;
NSString *_pathComponent;
NSString *_queryComponent;
NSString *_fragmentComponent;
}
/**
Initialize a `KSURLComponents` with the components of a URL.
If the url string from the NSURL is malformed, nil is returned.
If `resolve` is `YES` and `url` is a relative URL, the components of `[url absoluteURL]`
are used. As a general rule, clients should pass in `YES` unless they're
specifically interested in the components of only the relative portion of a
relative URL.
@param url The URL whose components you want.
@param resolve Whether to resolve relative URLs before retrieving components
*/
- (instancetype)initWithURL:(NSURL *)url resolvingAgainstBaseURL:(BOOL)resolve __attribute((nonnull));
/**
Initializes and returns a newly created `KSURLComponents` with the components of a URL.
If the url string from the NSURL is malformed, nil is returned.
If `resolve` is `YES` and `url` is a relative URL, the components of `[url absoluteURL]`
are used. As a general rule, clients should pass in `YES` unless they're
specifically interested in the components of only the relative portion of a
relative URL.
@param url The URL whose components you want.
@param resolve Whether to resolve relative URLs before retrieving components
*/
+ (instancetype)componentsWithURL:(NSURL *)url resolvingAgainstBaseURL:(BOOL)resolve __attribute((nonnull));
/**
Initialize a `KSURLComponents` with a URL string.
If the URLString is malformed, `nil` is returned.
*/
- (instancetype)initWithString:(NSString *)URLString;
/**
Initializes and returns a newly created `KSURLComponents` with a URL string.
If the URLString is malformed, `nil` is returned.
*/
+ (instancetype)componentsWithString:(NSString *)URLString;
/**
Returns a URL created from the `KSURLComponents`.
If the `KSURLComponents` has an authority component (user, password, host or port)
and a path component, then the path must either begin with `/` or be an empty
string. If the `KSURLComponents` does not have an authority component (user, password, host or port)
and has a path component, the path component must not start with `//`. If those
requirements are not met, `nil` is returned.
*/
@property (nonatomic, readonly, copy) NSURL *URL;
/**
Returns a URL created from the `KSURLComponents` relative to a base URL.
If the `KSURLComponents` has an authority component (user, password, host or port)
and a path component, then the path must either begin with `/` or be an empty
string. If the `KSURLComponents` does not have an authority component (user, password, host or port)
and has a path component, the path component must not start with `//`. If those
requirements are not met, `nil` is returned.
*/
- (NSURL *)URLRelativeToURL:(NSURL *)baseURL;
// Warning: IETF STD 66 (rfc3986) says the use of the format "user:password" in the userinfo subcomponent of a URI is deprecated because passing authentication information in clear text has proven to be a security risk. However, there are cases where this practice is still needed, and so the user and password components and methods are provided.
// Getting these properties removes any percent encoding these components may have (if the component allows percent encoding). Setting these properties assumes the subcomponent or component string is not percent encoded and will add percent encoding (if the component allows percent encoding).
@property (nonatomic, copy) NSString *scheme; // Attempting to set the scheme with an invalid scheme string will cause an exception.
@property (nonatomic, copy) NSString *user;
@property (nonatomic, copy) NSString *password;
@property (nonatomic, copy) NSString *host;
@property (nonatomic, copy) NSNumber *port; // Attempting to set a negative port number will cause an exception.
@property (nonatomic, copy) NSString *path;
@property (nonatomic, copy) NSString *query;
@property (nonatomic, copy) NSString *fragment;
// Getting these properties retains any percent encoding these components may have. Setting these properties is currently not supported as I am lazy and doing so is rarely useful. If you do have a use case, please send me a pull request or file an issue on GitHub.
@property (nonatomic, copy, readonly) NSString *percentEncodedUser;
@property (nonatomic, copy, readonly) NSString *percentEncodedPassword;
@property (nonatomic, copy, readonly) NSString *percentEncodedHost;
@property (nonatomic, copy, readonly) NSString *percentEncodedPath;
@property (nonatomic, copy, readonly) NSString *percentEncodedQuery;
@property (nonatomic, copy, readonly) NSString *percentEncodedFragment;
@end