// // VKAccessToken.h // // Copyright (c) 2014 VK.com // // 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 #import "VKObject.h" #import "VKUser.h" /** * Represents VK API access token that used for loading API methods and other stuff. */ @interface VKAccessToken : VKObject /// String token for use in request parameters @property(nonatomic, readonly, copy) NSString *accessToken; /// Current user id for this token @property(nonatomic, readonly, copy) NSString *userId; /// User secret to sign requests (if nohttps used) @property(nonatomic, readonly, copy) NSString *secret; // Permisiions assosiated with token @property(nonatomic, readonly, copy) NSArray *permissions; // User email (if passed) @property(nonatomic, readonly, copy) NSString *email; /// Time when token expires @property(nonatomic, readonly, assign) NSInteger expiresIn; /// If user sets "Always use HTTPS" setting in his profile, it will be true @property(nonatomic, readonly, assign) BOOL httpsRequired; /// Indicates time of token creation @property(nonatomic, readonly, assign) NSTimeInterval created; /// Contains basic current user information. Available after delegate method -[VKSdkDelegate vkSdkAuthorizationStateUpdatedWithResult:] called @property(nonatomic, readonly, strong) VKUser *localUser; /** Retrieve token from key-value query string @param urlString string that contains URL-query part with token. E.g. access_token=ffffff&expires_in=0... @return parsed token */ + (instancetype)tokenFromUrlString:(NSString *)urlString; /** Create token with existing properties @param accessToken token string @param secret secret @param userId user id @return new token */ + (instancetype)tokenWithToken:(NSString *)accessToken secret:(NSString *)secret userId:(NSString *)userId; /** Retrieve token from user defaults. Token must be saved to defaults with saveTokenToDefaults method @param defaultsKey path to file with saved token @return parsed token */ + (instancetype)savedToken:(NSString *)defaultsKey; /** Save token into user defaults by specified key @param defaultsKey key for defaults */ - (void)saveTokenToDefaults:(NSString *)defaultsKey; /// Return YES if token has expired - (BOOL)isExpired; /** Remove token from storage @param service Access token storage key name */ + (void)delete:(NSString *)service; @end /** * This is mutable version of VKAccessToken. You should never use this class directly */ @interface VKAccessTokenMutable : VKAccessToken @property(nonatomic, readwrite, copy) NSString *accessToken; @property(nonatomic, readwrite, copy) NSString *userId; @property(nonatomic, readwrite, copy) NSString *secret; @property(nonatomic, readwrite, copy) NSArray *permissions; @property(nonatomic, readwrite, assign) BOOL httpsRequired; @property(nonatomic, readwrite, assign) NSInteger expiresIn; @property(nonatomic, readwrite, strong) VKUser *localUser; @end