VKAccessToken.h 3.75 KB
//
//  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.
//
//  --------------------------------------------------------------------------------
//
//  Modified by Ruslan Kavetsky

#import <Foundation/Foundation.h>
#import "VKObject.h"
#import "VKUser.h"

/**
Presents VK API access token that used for loading API methods and other stuff.
*/
@interface VKAccessToken : VKObject <NSCoding>

/// 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;

/// Indicates time of token creation
@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
 */
+ (void)delete:(NSString *)service;

@end

@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