├── .gitattributes ├── .gitignore ├── .vscode └── settings.json ├── Assets ├── Editor.meta ├── Editor │ ├── UnityPackageGenerator.cs │ └── UnityPackageGenerator.cs.meta ├── Plugins.meta ├── Plugins │ ├── Android.meta │ ├── Android │ │ ├── TorikiAndroidPlugin.aar │ │ ├── TorikiAndroidPlugin.aar.meta │ │ ├── TorikiAndroidPluginGenerator.zip │ │ └── TorikiAndroidPluginGenerator.zip.meta │ ├── iOS.meta │ └── iOS │ │ ├── Toriki.meta │ │ └── Toriki │ │ ├── Internal.meta │ │ ├── Internal │ │ ├── TKConstants.h │ │ ├── TKConstants.h.meta │ │ ├── TKConstants.m │ │ ├── TKConstants.m.meta │ │ ├── TKLoginURLParser.h │ │ ├── TKLoginURLParser.h.meta │ │ ├── TKLoginURLParser.m │ │ ├── TKLoginURLParser.m.meta │ │ ├── TKTwitter.h │ │ ├── TKTwitter.h.meta │ │ ├── TKTwitter.m │ │ └── TKTwitter.m.meta │ │ ├── Toriki.h │ │ ├── Toriki.h.meta │ │ ├── Toriki.mm │ │ └── Toriki.mm.meta ├── Toriki.meta ├── Toriki │ ├── Editor.meta │ ├── Editor │ │ ├── TwitterPostProcess.cs │ │ └── TwitterPostProcess.cs.meta │ ├── Scripts.meta │ └── Scripts │ │ ├── AndroidTwitterImpl.cs │ │ ├── AndroidTwitterImpl.cs.meta │ │ ├── EditorTwitterImpl.cs │ │ ├── EditorTwitterImpl.cs.meta │ │ ├── IOSTwitterImpl.cs │ │ ├── IOSTwitterImpl.cs.meta │ │ ├── ITwitter.cs │ │ ├── ITwitter.cs.meta │ │ ├── TwitterAPI.cs │ │ ├── TwitterAPI.cs.meta │ │ ├── TwitterConnector.cs │ │ ├── TwitterConnector.cs.meta │ │ ├── TwitterSettings.cs │ │ └── TwitterSettings.cs.meta ├── _Sample.meta └── _Sample │ ├── APIAccess.meta │ ├── APIAccess │ ├── APIAccess.cs │ ├── APIAccess.cs.meta │ ├── APIAccess.unity │ └── APIAccess.unity.meta │ ├── Login.meta │ └── Login │ ├── Login.cs │ ├── Login.cs.meta │ ├── Login.unity │ └── Login.unity.meta ├── LICENSE ├── Packages └── manifest.json ├── ProjectSettings ├── AudioManager.asset ├── ClusterInputManager.asset ├── DynamicsManager.asset ├── EditorBuildSettings.asset ├── EditorSettings.asset ├── GraphicsSettings.asset ├── InputManager.asset ├── NavMeshAreas.asset ├── Physics2DSettings.asset ├── PresetManager.asset ├── ProjectSettings.asset ├── ProjectVersion.txt ├── QualitySettings.asset ├── TagManager.asset ├── TimeManager.asset ├── UnityConnectSettings.asset ├── VFXManager.asset └── XRSettings.asset ├── README.md ├── Toriki.unitypackage ├── UserSettings └── EditorUserSettings.asset └── toriki.sln /.gitattributes: -------------------------------------------------------------------------------- 1 | # Auto detect text files and perform LF normalization 2 | * text=auto 3 | -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | 2 | Temp/* 3 | Library/* 4 | iOS/* 5 | Assembly-CSharp-Editor.csproj 6 | Assembly-CSharp.csproj 7 | obj/* 8 | .DS_Store 9 | Logs/* 10 | toriki.sln 11 | 12 | Assets/Resources.meta 13 | -------------------------------------------------------------------------------- /.vscode/settings.json: -------------------------------------------------------------------------------- 1 | { 2 | "files.exclude": 3 | { 4 | "**/.DS_Store":true, 5 | "**/.git":true, 6 | "**/.gitignore":true, 7 | "**/.gitmodules":true, 8 | "**/*.booproj":true, 9 | "**/*.pidb":true, 10 | "**/*.suo":true, 11 | "**/*.user":true, 12 | "**/*.userprefs":true, 13 | "**/*.unityproj":true, 14 | "**/*.dll":true, 15 | "**/*.exe":true, 16 | "**/*.pdf":true, 17 | "**/*.mid":true, 18 | "**/*.midi":true, 19 | "**/*.wav":true, 20 | "**/*.gif":true, 21 | "**/*.ico":true, 22 | "**/*.jpg":true, 23 | "**/*.jpeg":true, 24 | "**/*.png":true, 25 | "**/*.psd":true, 26 | "**/*.tga":true, 27 | "**/*.tif":true, 28 | "**/*.tiff":true, 29 | "**/*.3ds":true, 30 | "**/*.3DS":true, 31 | "**/*.fbx":true, 32 | "**/*.FBX":true, 33 | "**/*.lxo":true, 34 | "**/*.LXO":true, 35 | "**/*.ma":true, 36 | "**/*.MA":true, 37 | "**/*.obj":true, 38 | "**/*.OBJ":true, 39 | "**/*.asset":true, 40 | "**/*.cubemap":true, 41 | "**/*.flare":true, 42 | "**/*.mat":true, 43 | "**/*.meta":true, 44 | "**/*.prefab":true, 45 | "**/*.unity":true, 46 | "build/":true, 47 | "Build/":true, 48 | "Library/":true, 49 | "library/":true, 50 | "obj/":true, 51 | "Obj/":true, 52 | "ProjectSettings/":true, 53 | "temp/":true, 54 | "Temp/":true 55 | } 56 | } -------------------------------------------------------------------------------- /Assets/Editor.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 66f521821424042c1942140de73a937d 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Editor/UnityPackageGenerator.cs: -------------------------------------------------------------------------------- 1 | using System.Collections.Generic; 2 | using System.IO; 3 | using UnityEditor; 4 | 5 | public class UnityPackageGenerator 6 | { 7 | [MenuItem("Window/Toriki/Generate UnityPackage")] 8 | public static void UnityPackage() 9 | { 10 | var assetPaths = new List(); 11 | 12 | var torikiPath = "Assets/Toriki"; 13 | CollectPathRecursive(torikiPath, assetPaths); 14 | 15 | var pluginsPath = "Assets/Plugins"; 16 | CollectPathRecursive(pluginsPath, assetPaths); 17 | 18 | AssetDatabase.ExportPackage(assetPaths.ToArray(), "Toriki.unitypackage", ExportPackageOptions.IncludeDependencies); 19 | } 20 | 21 | private static void CollectPathRecursive(string path, List collectedPaths) 22 | { 23 | var filePaths = Directory.GetFiles(path); 24 | foreach (var filePath in filePaths) 25 | { 26 | collectedPaths.Add(filePath); 27 | } 28 | 29 | var modulePaths = Directory.GetDirectories(path); 30 | foreach (var folderPath in modulePaths) 31 | { 32 | CollectPathRecursive(folderPath, collectedPaths); 33 | } 34 | } 35 | } -------------------------------------------------------------------------------- /Assets/Editor/UnityPackageGenerator.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 65bbb0af687fd4fcea571e4b90b2ef4b 3 | MonoImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | defaultReferences: [] 7 | executionOrder: 0 8 | icon: {instanceID: 0} 9 | userData: 10 | assetBundleName: 11 | assetBundleVariant: 12 | -------------------------------------------------------------------------------- /Assets/Plugins.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 3d56f4a676222474aa0573a63e887e0f 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Plugins/Android.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: a0104e543bab941cbaa6fac67276fcbc 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Plugins/Android/TorikiAndroidPlugin.aar: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sassembla/toriki/6cdbe4c014b6ad85bf35a915e859ad70d56631ae/Assets/Plugins/Android/TorikiAndroidPlugin.aar -------------------------------------------------------------------------------- /Assets/Plugins/Android/TorikiAndroidPlugin.aar.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: e40263eb60a944a32aa40307218f8046 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Android: Android 13 | second: 14 | enabled: 1 15 | settings: {} 16 | - first: 17 | Any: 18 | second: 19 | enabled: 0 20 | settings: {} 21 | - first: 22 | Editor: Editor 23 | second: 24 | enabled: 0 25 | settings: 26 | DefaultValueInitialized: true 27 | userData: 28 | assetBundleName: 29 | assetBundleVariant: 30 | -------------------------------------------------------------------------------- /Assets/Plugins/Android/TorikiAndroidPluginGenerator.zip: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sassembla/toriki/6cdbe4c014b6ad85bf35a915e859ad70d56631ae/Assets/Plugins/Android/TorikiAndroidPluginGenerator.zip -------------------------------------------------------------------------------- /Assets/Plugins/Android/TorikiAndroidPluginGenerator.zip.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: fc98cdff51e4d4f368635ece3eec96d3 3 | DefaultImporter: 4 | externalObjects: {} 5 | userData: 6 | assetBundleName: 7 | assetBundleVariant: 8 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 8c81947ad801a414f9983dc0676e2eef 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 29663630af20e4bad9d2afdfcc6f3f02 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: d266e6e186ff14f03bb7f872f1768ad5 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKConstants.h: -------------------------------------------------------------------------------- 1 | #import 2 | 3 | NS_ASSUME_NONNULL_BEGIN 4 | 5 | FOUNDATION_EXTERN NSString *const TKErrorDomain; 6 | 7 | typedef NS_ENUM(NSInteger, TKErrorCode) { 8 | 9 | /** 10 | * Unknown error. 11 | */ 12 | TKErrorCodeUnknown = -1, 13 | 14 | /** 15 | * Authentication has not been set up yet. You must call -[TKTwitter logInWithCompletion:] or -[TKTwitter logInGuestWithCompletion:] 16 | */ 17 | TKErrorCodeNoAuthentication = 0, 18 | 19 | /** 20 | * Twitter has not been initialized yet. Call +[Fabric with:@[TwitterKit]] or -[TKTwitter startWithConsumerKey:consumerSecret:]. 21 | */ 22 | TKErrorCodeNotInitialized = 1, 23 | 24 | /** 25 | * User has declined to grant permission to information such as their email address. 26 | */ 27 | TKErrorCodeUserDeclinedPermission = 2, 28 | 29 | /** 30 | * User has granted permission to their email address but no address is associated with their account. 31 | */ 32 | TKErrorCodeUserHasNoEmailAddress = 3, 33 | 34 | /** 35 | * A resource has been requested by ID, but that ID was not found. 36 | */ 37 | TKErrorCodeInvalidResourceID = 4, 38 | 39 | /** 40 | * A request has been issued for an invalid URL. 41 | */ 42 | TKErrorCodeInvalidURL = 5, 43 | 44 | /** 45 | * Type mismatch in parsing JSON from the Twitter API. 46 | */ 47 | TKErrorCodeMismatchedJSONType = 6, 48 | 49 | /** 50 | * Fail to save to keychain. 51 | */ 52 | TKErrorCodeKeychainSerializationFailure = 7, 53 | 54 | /** 55 | * Fail to save to disk. 56 | */ 57 | TKErrorCodeDiskSerializationError = 8, 58 | 59 | /** 60 | * Error authenticating with the webview. 61 | */ 62 | TKErrorCodeWebViewError = 9, 63 | 64 | /** 65 | * A required parameter is missing. 66 | */ 67 | TKErrorCodeMissingParameter = 10 68 | }; 69 | 70 | FOUNDATION_EXTERN NSString *const TKLogInErrorDomain; 71 | 72 | typedef NS_ENUM(NSInteger, TKLogInErrorCode) { 73 | 74 | /** 75 | * Unknown error. 76 | */ 77 | TKLogInErrorCodeUnknown = -1, 78 | 79 | /** 80 | * User denied login. 81 | */ 82 | TKLogInErrorCodeDenied = 0, 83 | 84 | /** 85 | * User canceled login. 86 | */ 87 | TKLogInErrorCodeCancelled = 1, 88 | 89 | /** 90 | * No Twitter account found. 91 | */ 92 | TKLogInErrorCodeNoAccounts = 2, 93 | 94 | /** 95 | * Reverse auth with linked account failed. 96 | */ 97 | TKLogInErrorCodeReverseAuthFailed = 3, 98 | 99 | /** 100 | * Refreshing session tokens failed. 101 | */ 102 | TKLogInErrorCodeCannotRefreshSession = 4, 103 | 104 | /** 105 | * No such session or session is not tracked 106 | * in the associated session store. 107 | */ 108 | TKLogInErrorCodeSessionNotFound = 5, 109 | 110 | /** 111 | * The login request failed. 112 | */ 113 | TKLogInErrorCodeFailed = 6, 114 | 115 | /** 116 | * The system account credentials are no longer valid and the 117 | * user will need to update their credentials in the Settings app. 118 | */ 119 | TKLogInErrorCodeSystemAccountCredentialsInvalid = 7, 120 | 121 | /** 122 | * There was no Twitter iOS app installed to attemp 123 | * the Mobile SSO flow. 124 | */ 125 | TKLoginErrorNoTwitterApp = 8, 126 | }; 127 | 128 | NS_ASSUME_NONNULL_END 129 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKConstants.h.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 1f1c5bb14c726477cbe62af9006eff5e 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKConstants.m: -------------------------------------------------------------------------------- 1 | #import "TKConstants.h" 2 | 3 | NSString *const TKErrorDomain = @"TKErrorDomain"; 4 | 5 | NSString *const TKLogInErrorDomain = @"TKLogInErrorDomain"; 6 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKConstants.m.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 240a6e89a51c2461688ac770b9f27abf 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKLoginURLParser.h: -------------------------------------------------------------------------------- 1 | NS_ASSUME_NONNULL_BEGIN 2 | 3 | @class TKAuthConfig; 4 | 5 | @interface TKLoginURLParser : NSObject 6 | 7 | - (instancetype)initWithKey:(NSString *)key secret:(NSString *)secret; 8 | 9 | - (BOOL)isTwitterKitRedirectURL:(NSURL *)url; 10 | - (BOOL)hasValidURLScheme; 11 | - (NSURL *)twitterAuthorizeURL; 12 | - (BOOL)isMobileSSOSuccessURL:(NSURL *)url; 13 | - (BOOL)isMobileSSOCancelURL:(NSURL *)url; 14 | - (NSDictionary *)parametersForSSOURL:(NSURL *)url; 15 | 16 | @end 17 | 18 | NS_ASSUME_NONNULL_END 19 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKLoginURLParser.h.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: f133bb076c76644c19726521c092d769 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKLoginURLParser.m: -------------------------------------------------------------------------------- 1 | #import "TKLoginURLParser.h" 2 | 3 | @interface TKLoginURLParser () 4 | 5 | @property (nonatomic, copy) NSString *twitterKitURLScheme; 6 | @property (nonatomic, copy) NSString *twitterAuthURL; 7 | 8 | @end 9 | 10 | @implementation TKLoginURLParser 11 | 12 | - (instancetype)initWithKey:(NSString *)key secret:(NSString *)secret 13 | { 14 | if (self = [super init]) { 15 | self.twitterKitURLScheme = [NSString stringWithFormat:@"twitterkit-%@", key]; 16 | self.twitterAuthURL = [NSString stringWithFormat:@"twitterauth://authorize?consumer_key=%@&consumer_secret=%@&oauth_callback=%@", key, secret, self.twitterKitURLScheme]; 17 | } 18 | return self; 19 | } 20 | 21 | - (NSString *)percentUnescapedQueryStringWithString:(NSString *)string encoding:(NSStringEncoding)encoding 22 | { 23 | return [string stringByRemovingPercentEncoding]; 24 | } 25 | 26 | - (NSDictionary *)parametersFromQueryString:(NSString *)queryString 27 | { 28 | NSArray *pairs = [queryString componentsSeparatedByString:@"&"]; 29 | NSMutableDictionary *parameters = [NSMutableDictionary dictionary]; 30 | [pairs enumerateObjectsUsingBlock:^(NSString *keyValueStr, NSUInteger idx, BOOL *stop) { 31 | NSArray *keyValue = [keyValueStr componentsSeparatedByString:@"="]; 32 | if ([keyValue count] >= 2) { 33 | NSString *key = [self percentUnescapedQueryStringWithString:keyValue[0] encoding:NSUTF8StringEncoding]; 34 | NSString *value = [self percentUnescapedQueryStringWithString:keyValue[1] encoding:NSUTF8StringEncoding]; 35 | parameters[key] = value; 36 | } 37 | }]; 38 | return parameters; 39 | } 40 | 41 | 42 | - (BOOL)isMobileSSOSuccessURL:(NSURL *)url 43 | { 44 | BOOL properScheme = [self isTwitterKitRedirectURL:url]; 45 | 46 | NSDictionary *parameters = [self parametersFromQueryString:url.host]; 47 | NSArray *keys = [parameters allKeys]; 48 | BOOL successState = [keys containsObject:@"secret"] && [keys containsObject:@"token"] && [keys containsObject:@"username"] && properScheme; 49 | 50 | BOOL isSuccessURL = successState && properScheme; 51 | 52 | return isSuccessURL; 53 | } 54 | 55 | - (BOOL)isMobileSSOCancelURL:(NSURL *)url 56 | { 57 | BOOL properScheme = [self isTwitterKitRedirectURL:url]; 58 | BOOL cancelState = (url.host == nil) && properScheme; 59 | 60 | BOOL isCancelURL = properScheme && cancelState; 61 | 62 | return isCancelURL; 63 | } 64 | 65 | - (NSDictionary *)parametersForSSOURL:(NSURL *)url 66 | { 67 | return [self parametersFromQueryString:url.host]; 68 | } 69 | 70 | - (BOOL)isTwitterKitRedirectURL:(NSURL *)url 71 | { 72 | return [self isTwitterKitURLScheme:url.scheme]; 73 | } 74 | 75 | - (BOOL)hasValidURLScheme 76 | { 77 | return ([self appSpecificURLScheme] != nil); 78 | } 79 | 80 | - (NSURL *)twitterAuthorizeURL 81 | { 82 | return [NSURL URLWithString:self.twitterAuthURL]; 83 | } 84 | 85 | - (BOOL)isTwitterKitURLScheme:(NSString *)scheme 86 | { 87 | // The Twitter API will redirect to a lowercase version of the 88 | // URL that we pass to them 89 | return [scheme caseInsensitiveCompare:self.twitterKitURLScheme] == NSOrderedSame; 90 | } 91 | 92 | - (NSString *)appSpecificURLScheme 93 | { 94 | NSString *matchingScheme; 95 | NSBundle* mainBundle = [NSBundle mainBundle]; 96 | NSDictionary *infoPlist = mainBundle.infoDictionary; 97 | 98 | NSArray *urlTypes = [infoPlist objectForKey:@"CFBundleURLTypes"]; 99 | 100 | for (NSDictionary *schemeDetails in urlTypes) { 101 | NSPredicate *predicate = [NSPredicate predicateWithBlock:^BOOL(id _Nullable evaluatedObject, NSDictionary *_Nullable bindings) { 102 | NSString *scheme = (NSString *)evaluatedObject; 103 | return (scheme) ? [self isTwitterKitURLScheme:scheme] : NO; 104 | }]; 105 | 106 | NSArray *filteredArray = [[schemeDetails objectForKey:@"CFBundleURLSchemes"] filteredArrayUsingPredicate:predicate]; 107 | if ([filteredArray count] > 0) { 108 | matchingScheme = [filteredArray firstObject]; 109 | } 110 | } 111 | 112 | return matchingScheme; 113 | } 114 | 115 | @end 116 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKLoginURLParser.m.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 080eadea2e6c9464e98598546a9c1365 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKTwitter.h: -------------------------------------------------------------------------------- 1 | NS_ASSUME_NONNULL_BEGIN 2 | 3 | //ログイン処理完了時に発行するイベント型 4 | typedef void (^TKLogInCompletion)( 5 | NSString *_Nullable username, 6 | NSString *_Nullable accessToken, 7 | NSString *_Nullable accessSecret, 8 | NSError *_Nullable error); 9 | 10 | @interface TKTwitter : NSObject 11 | @property (nonatomic, copy, readonly) NSString *consumerKey; 12 | @property (nonatomic, copy, readonly) NSString *consumerSecret; 13 | 14 | + (TKTwitter *)sharedInstance; 15 | 16 | - (void)startWithConsumerKey:(NSString *)consumerKey consumerSecret:(NSString *)consumerSecret; 17 | - (void)attemptLogin:(TKLogInCompletion)completion; 18 | 19 | - (void)onAppLaunch:(NSURL *)url sourceApplication:(NSString *)sourceApplication; 20 | 21 | @end 22 | 23 | NS_ASSUME_NONNULL_END 24 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKTwitter.h.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: faca34438edfd4e6c92ab1ad366311e2 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKTwitter.m: -------------------------------------------------------------------------------- 1 | #import "TKTwitter.h" 2 | #import "TKConstants.h" 3 | #import "TKLoginURLParser.h" 4 | 5 | @interface TKTwitter () 6 | @property(nonatomic, copy, readwrite) NSString *consumerKey; 7 | @property(nonatomic, copy, readwrite) NSString *consumerSecret; 8 | @property(nonatomic, readonly, getter=isInitialized) BOOL initialized; 9 | @property(nonatomic) TKLoginURLParser *loginURLParser; 10 | @property(nonatomic, copy) TKLogInCompletion completion; 11 | @end 12 | 13 | @implementation TKTwitter 14 | 15 | static TKTwitter *sharedTwitter; 16 | + (TKTwitter *)sharedInstance { 17 | if (!sharedTwitter) { 18 | sharedTwitter = [[super allocWithZone:nil] init]; 19 | } 20 | 21 | return sharedTwitter; 22 | } 23 | 24 | + (id)allocWithZone:(NSZone *)zone { 25 | return [self sharedInstance]; 26 | } 27 | 28 | - (void)startWithConsumerKey:(NSString *)consumerKey 29 | consumerSecret:(NSString *)consumerSecret { 30 | if (self.isInitialized) { 31 | return; 32 | } 33 | 34 | self.consumerKey = consumerKey; 35 | self.consumerSecret = consumerSecret; 36 | self.loginURLParser = 37 | [[TKLoginURLParser alloc] initWithKey:self.consumerKey 38 | secret:self.consumerSecret]; 39 | 40 | _initialized = YES; 41 | } 42 | 43 | - (void)assertTwitterKitInitialized { 44 | if (!self.isInitialized) { 45 | [NSException raise:@"TKInvalidInitializationException" 46 | format:@"Attempted to call TwitterKit methods before calling " 47 | @"the requisite start method. You must call " 48 | @"TKTwitter.sharedInstance().start(withConsumerKey:" 49 | @"consumerSecret:) before calling any other methods."]; 50 | } 51 | } 52 | 53 | /** 54 | ログイン処理 = Twitterアプリの起動と認証を行う。 55 | Twiiterアプリからのレスポンスパラメータの検証を行い、エラーがなければ成功とみなす。 56 | */ 57 | - (void)attemptLogin:(TKLogInCompletion)unityCompletion { 58 | [self assertTwitterKitInitialized]; 59 | 60 | if (![self.loginURLParser hasValidURLScheme]) { 61 | // アプリのURLSchemeに、TwitterAPpから起動するためのセッティングが足りない。このままだとTwitterAppから復帰できない。 62 | [NSException raise:@"TKInvalidInitializationException" 63 | format:@"Attempt made to Log in without a valid Twitter Kit " 64 | @"URL Scheme set up in the app settings. Please see " 65 | @"https://dev.twitter.com/twitterkit/ios/installation " 66 | @"for more info."]; 67 | return; 68 | } 69 | 70 | [self 71 | attemptAppLoginWithCompletion:^(NSString *username, NSString *accessToken, 72 | NSString *accessSecret, NSError *error) { 73 | // エラーがなければ成功 74 | if (!error) { 75 | unityCompletion(username, accessToken, accessSecret, error); 76 | return; 77 | } 78 | 79 | // 失敗 80 | unityCompletion(nil, nil, nil, error); 81 | }]; 82 | } 83 | 84 | - (void)attemptAppLoginWithCompletion:(TKLogInCompletion)completion { 85 | // ここで終了時処理をキャプチャしておき、TwitterAppから本Appが呼ばれた際に実行できるようにしておく。 86 | self.completion = [completion copy]; 87 | 88 | // Twitterアプリを開く 89 | NSURL *twitterAuthURL = [self.loginURLParser twitterAuthorizeURL]; 90 | [[UIApplication sharedApplication] 91 | openURL:twitterAuthURL 92 | options:@{} 93 | completionHandler:^(BOOL success) { 94 | // 失敗した場合、アプリケーションが存在していない。 95 | if (!success) { 96 | completion(nil, nil, nil, 97 | [[NSError alloc] initWithDomain:TKLogInErrorDomain 98 | code:TKLoginErrorNoTwitterApp 99 | userInfo:@{ 100 | NSLocalizedDescriptionKey : 101 | @"No Twitter App installed. " 102 | @"please install Twitter.app." 103 | }]); 104 | } 105 | }]; 106 | } 107 | 108 | - (void)onAppLaunch:(NSURL *)url 109 | sourceApplication:(NSString *)sourceApplication { 110 | if ([self.loginURLParser isTwitterKitRedirectURL:url]) { 111 | // 成功URLかどうかチェック 112 | if ([self.loginURLParser isMobileSSOSuccessURL:url]) { 113 | NSDictionary *parameters = [self.loginURLParser parametersForSSOURL:url]; 114 | 115 | // 最終的なアプリ側へのパラメータ渡しを行う 116 | self.completion(parameters[@"username"], parameters[@"token"], 117 | parameters[@"secret"], nil); 118 | return; 119 | } 120 | 121 | // キャンセルURLかどうかチェック 122 | if ([self.loginURLParser isMobileSSOCancelURL:url]) { 123 | // The user cancelled the Twitter SSO flow 124 | dispatch_async(dispatch_get_main_queue(), ^{ 125 | self.completion(nil, nil, nil, 126 | [[NSError alloc] 127 | initWithDomain:TKLogInErrorDomain 128 | code:TKLogInErrorCodeCancelled 129 | userInfo:@{ 130 | NSLocalizedDescriptionKey : 131 | @"User cancelled login from Twitter App" 132 | }]); 133 | }); 134 | return; 135 | } 136 | 137 | NSLog(@"unhandled twitter error. url:%@", url); 138 | return; 139 | } 140 | 141 | // Twitter以外のアプリからのデータが来た。 142 | // 無視する。 143 | } 144 | 145 | @end 146 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Internal/TKTwitter.m.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 9da66586cb938475ca8c926b9b65f5e2 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Toriki.h: -------------------------------------------------------------------------------- 1 | #import 2 | #import "AppDelegateListener.h" 3 | 4 | @interface Toriki : NSObject 5 | + (Toriki *)sharedInstance; 6 | @end 7 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Toriki.h.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 8e1c25665fe0f4f279c27fb1717687d7 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Toriki.mm: -------------------------------------------------------------------------------- 1 | #import "TKTwitter.h" 2 | #import "Toriki.h" 3 | 4 | static const char * TKInternalGameObject = "TorikiGameObject"; 5 | static const char * TKUnityAPIMethodLogInComplete = "LoginComplete"; 6 | static const char * TKUnityAPIMethodLogInFailed = "LoginFailed"; 7 | 8 | 9 | static char * cStringCopy(const char *string) 10 | { 11 | if (string == NULL) 12 | return NULL; 13 | 14 | char *res = (char *)malloc(strlen(string) + 1); 15 | strcpy(res, string); 16 | 17 | return res; 18 | } 19 | 20 | static NSString * const NSStringFromCString(const char *string) 21 | { 22 | if (string != NULL) { 23 | return [NSString stringWithUTF8String:string]; 24 | } else { 25 | return nil; 26 | } 27 | } 28 | 29 | static char * serializedJSONFromNSDictionary(NSDictionary *dictionary) 30 | { 31 | if (!dictionary) { 32 | return NULL; 33 | } 34 | 35 | NSData *serializedData = [NSJSONSerialization dataWithJSONObject:dictionary options:0 error:nil]; 36 | NSString *serializedJSONString = [[NSString alloc] initWithData:serializedData encoding:NSUTF8StringEncoding]; 37 | return cStringCopy([serializedJSONString UTF8String]); 38 | } 39 | 40 | 41 | 42 | 43 | static NSDictionary * NSDictionaryFromError(NSError *error) 44 | { 45 | return @{ @"code": @(error.code), @"message": error.localizedDescription }; 46 | } 47 | 48 | static Toriki *_instance = [Toriki sharedInstance]; 49 | 50 | @implementation Toriki 51 | 52 | + (Toriki *)sharedInstance 53 | { 54 | if(_instance == nil) { 55 | _instance = [[Toriki alloc] init]; 56 | } 57 | 58 | return _instance; 59 | } 60 | 61 | - (id)init 62 | { 63 | if(_instance != nil) { 64 | return _instance; 65 | } 66 | 67 | if ((self = [super init])) { 68 | _instance = self; 69 | UnityRegisterAppDelegateListener(self); 70 | } 71 | 72 | return self; 73 | } 74 | 75 | 76 | /** 77 | Twitterアプリからの起動 78 | */ 79 | - (void)onOpenURL:(NSNotification *)notification 80 | { 81 | [[TKTwitter sharedInstance] 82 | onAppLaunch:notification.userInfo[@"url"] 83 | sourceApplication:notification.userInfo[@"sourceApplication"]]; 84 | } 85 | 86 | @end 87 | 88 | 89 | extern "C" { 90 | /** 91 | Unity -> Twitterアプリの起動 92 | */ 93 | void TwitterInit(const char *consumerKey, const char *consumerSecret) 94 | { 95 | [[TKTwitter sharedInstance] startWithConsumerKey:NSStringFromCString(consumerKey) consumerSecret:NSStringFromCString(consumerSecret)]; 96 | } 97 | 98 | /** 99 | Unity -> Twitterのトークン取得処理 100 | */ 101 | void TwitterLogIn() 102 | { 103 | [[TKTwitter sharedInstance] attemptLogin:^( 104 | NSString *username, 105 | NSString *accessToken, 106 | NSString* accessSecret, 107 | NSError *error 108 | ) { 109 | if (!error) { 110 | // トークンを受け取ったのでUnity側の呼び出し処理を行う 111 | NSDictionary *sessionDictionary = 112 | @{ 113 | @"nickname": username, 114 | @"accessToken": accessToken, 115 | @"accessSecret": accessSecret 116 | }; 117 | char *serializedSession = serializedJSONFromNSDictionary(sessionDictionary); 118 | 119 | // NSLog(@"sessionDictionary:%@", sessionDictionary); 120 | UnitySendMessage(TKInternalGameObject, TKUnityAPIMethodLogInComplete, serializedSession); 121 | free(serializedSession); 122 | } else { 123 | NSDictionary *errorDictionary = NSDictionaryFromError(error); 124 | char *serializedError = serializedJSONFromNSDictionary(errorDictionary); 125 | UnitySendMessage(TKInternalGameObject, TKUnityAPIMethodLogInFailed, serializedError); 126 | free(serializedError); 127 | } 128 | }]; 129 | } 130 | } 131 | -------------------------------------------------------------------------------- /Assets/Plugins/iOS/Toriki/Toriki.mm.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 230891ed40411495cb20574de10460d5 3 | PluginImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | iconMap: {} 7 | executionOrder: {} 8 | isPreloaded: 0 9 | isOverridable: 0 10 | platformData: 11 | - first: 12 | Any: 13 | second: 14 | enabled: 0 15 | settings: {} 16 | - first: 17 | Editor: Editor 18 | second: 19 | enabled: 0 20 | settings: 21 | DefaultValueInitialized: true 22 | - first: 23 | iPhone: iOS 24 | second: 25 | enabled: 1 26 | settings: 27 | AddToEmbeddedBinaries: false 28 | userData: 29 | assetBundleName: 30 | assetBundleVariant: 31 | -------------------------------------------------------------------------------- /Assets/Toriki.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 5caafeac3faf346ba8001e52d6d76d25 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Toriki/Editor.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: bc3d7198ef17b43f7bf7206101ee6b7a 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Toriki/Editor/TwitterPostProcess.cs: -------------------------------------------------------------------------------- 1 | #if UNITY_IOS 2 | using UnityEngine; 3 | using UnityEditor; 4 | using UnityEditor.Callbacks; 5 | using System.Collections; 6 | using System.IO; 7 | using Toriki.Settings; 8 | using UnityEditor.iOS.Xcode; 9 | 10 | namespace Toriki.Internal 11 | { 12 | public class TwitterPostProcessBuild 13 | { 14 | private const string URL_TYPES = "CFBundleURLTypes"; 15 | private const string URL_SCHEMES = "CFBundleURLSchemes"; 16 | private const string APPLICATION_QUERIES_SCHEMES = "LSApplicationQueriesSchemes"; 17 | 18 | [PostProcessBuild] 19 | public static void SetupXcodeSettingsForToriki(BuildTarget buildTarget, string pathToBuiltProject) 20 | { 21 | if (buildTarget == BuildTarget.iOS) 22 | { 23 | // Get plist 24 | string plistPath = pathToBuiltProject + "/Info.plist"; 25 | PlistDocument plist = new PlistDocument(); 26 | plist.ReadFromString(File.ReadAllText(plistPath)); 27 | 28 | // Get root 29 | PlistElementDict rootDict = plist.root; 30 | 31 | // Modify Info.Plist for Twitter Kit (https://dev.twitter.com/twitterkit/ios/installation) 32 | PlistElementArray bundleURLTypesArray = rootDict[URL_TYPES] as PlistElementArray; 33 | if (bundleURLTypesArray == null) 34 | { 35 | bundleURLTypesArray = rootDict.CreateArray(URL_TYPES); 36 | } 37 | PlistElementDict dict = bundleURLTypesArray.AddDict(); 38 | PlistElementArray bundleURLSchemesArray = dict.CreateArray(URL_SCHEMES); 39 | bundleURLSchemesArray.AddString("twitterkit-" + TwitterSettings.ConsumerKey); 40 | PlistElementArray queriesSchemesArray = rootDict[APPLICATION_QUERIES_SCHEMES] as PlistElementArray; 41 | if (queriesSchemesArray == null) 42 | { 43 | queriesSchemesArray = rootDict.CreateArray(APPLICATION_QUERIES_SCHEMES); 44 | } 45 | queriesSchemesArray.AddString("twitter"); 46 | queriesSchemesArray.AddString("twitterauth"); 47 | 48 | // Write to file 49 | File.WriteAllText(plistPath, plist.WriteToString()); 50 | } 51 | } 52 | } 53 | } 54 | #endif -------------------------------------------------------------------------------- /Assets/Toriki/Editor/TwitterPostProcess.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: b6d707c2dcf5947bf97e2d5963610fe6 3 | timeCreated: 1499717552 4 | licenseType: Store 5 | MonoImporter: 6 | serializedVersion: 2 7 | defaultReferences: [] 8 | executionOrder: 0 9 | icon: {instanceID: 0} 10 | userData: 11 | assetBundleName: 12 | assetBundleVariant: 13 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: f134a872be009410985c90bcadaddd57 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/AndroidTwitterImpl.cs: -------------------------------------------------------------------------------- 1 | #if UNITY_EDITOR 2 | #elif UNITY_ANDROID 3 | using System; 4 | using System.Runtime.InteropServices; 5 | using UnityEngine; 6 | using Toriki.Settings; 7 | 8 | namespace Toriki.Internal 9 | { 10 | internal class AndroidTwitterImpl : ITwitterImpl 11 | { 12 | private AndroidJavaClass twitter = new AndroidJavaClass("com.twitter.sdk.android.unity.TwitterKit"); 13 | 14 | public void Init(string consumerKey, string consumerSecret) 15 | { 16 | twitter.CallStatic("init", consumerKey, consumerSecret); 17 | } 18 | 19 | public void LogIn() 20 | { 21 | twitter.CallStatic("login"); 22 | } 23 | } 24 | } 25 | #endif -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/AndroidTwitterImpl.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: abbb89b6e37ac46dfbfed60153799e7f 3 | timeCreated: 1499717552 4 | licenseType: Store 5 | MonoImporter: 6 | serializedVersion: 2 7 | defaultReferences: [] 8 | executionOrder: 0 9 | icon: {instanceID: 0} 10 | userData: 11 | assetBundleName: 12 | assetBundleVariant: 13 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/EditorTwitterImpl.cs: -------------------------------------------------------------------------------- 1 | #if UNITY_EDITOR 2 | using Toriki.Settings; 3 | using UnityEngine; 4 | 5 | namespace Toriki.Internal 6 | { 7 | internal class EditorTwitterImpl : ITwitterImpl 8 | { 9 | public EditorTwitterImpl() 10 | { 11 | } 12 | 13 | public void Init(string consumerKey, string consumerSecret) 14 | { 15 | Debug.Log("Would call Twitter init on a physical device with key=" + consumerKey + " and secret=" + consumerSecret); 16 | // このへんどうするのがいいのかな〜〜、、key, secretがあれば、tokenが得られるか、、というと得られないし。 accessTokenとかがあれば。 17 | } 18 | 19 | public void LogIn() 20 | { 21 | Debug.Log("Would call Twitter login on a physical device."); 22 | } 23 | } 24 | } 25 | #endif 26 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/EditorTwitterImpl.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: a6a148a5f3c544ca09ad63834e848fb0 3 | timeCreated: 1499717552 4 | licenseType: Store 5 | MonoImporter: 6 | serializedVersion: 2 7 | defaultReferences: [] 8 | executionOrder: 0 9 | icon: {instanceID: 0} 10 | userData: 11 | assetBundleName: 12 | assetBundleVariant: 13 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/IOSTwitterImpl.cs: -------------------------------------------------------------------------------- 1 | #if UNITY_EDITOR 2 | #elif UNITY_IOS 3 | using System; 4 | using System.Runtime.InteropServices; 5 | using UnityEngine; 6 | using Toriki.Settings; 7 | 8 | namespace Toriki.Internal 9 | { 10 | internal class IOSTwitterImpl : ITwitterImpl 11 | { 12 | [DllImport("__Internal")] 13 | private static extern void TwitterInit(string consumerKey, string consumerSecret); 14 | 15 | [DllImport("__Internal")] 16 | private static extern void TwitterLogIn(); 17 | 18 | public void Init(string consumerKey, string consumerSecret) 19 | { 20 | IOSTwitterImpl.TwitterInit(consumerKey, consumerSecret); 21 | } 22 | 23 | public void LogIn() 24 | { 25 | IOSTwitterImpl.TwitterLogIn(); 26 | } 27 | } 28 | } 29 | #endif 30 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/IOSTwitterImpl.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: a8ac0cb606980426b898d56bd5d9a448 3 | timeCreated: 1499717552 4 | licenseType: Store 5 | MonoImporter: 6 | serializedVersion: 2 7 | defaultReferences: [] 8 | executionOrder: 0 9 | icon: {instanceID: 0} 10 | userData: 11 | assetBundleName: 12 | assetBundleVariant: 13 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/ITwitter.cs: -------------------------------------------------------------------------------- 1 | namespace Toriki.Internal 2 | { 3 | internal interface ITwitterImpl 4 | { 5 | void Init(string consumerKey, string consumerSecret); 6 | 7 | void LogIn(); 8 | } 9 | } 10 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/ITwitter.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 82a36d5bca3b744c1b6d3b2855e7ffa7 3 | timeCreated: 1499717552 4 | licenseType: Store 5 | MonoImporter: 6 | serializedVersion: 2 7 | defaultReferences: [] 8 | executionOrder: 0 9 | icon: {instanceID: 0} 10 | userData: 11 | assetBundleName: 12 | assetBundleVariant: 13 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/TwitterAPI.cs: -------------------------------------------------------------------------------- 1 | using UnityEngine; 2 | using System; 3 | using System.Collections.Generic; 4 | using Toriki.Settings; 5 | using Toriki.Internal; 6 | 7 | namespace Toriki 8 | { 9 | public class TwitterAPI : MonoBehaviour 10 | { 11 | [Serializable] 12 | private class SessionData 13 | { 14 | [SerializeField] public string nickname; 15 | [SerializeField] public string accessToken; 16 | [SerializeField] public string accessSecret; 17 | } 18 | 19 | [Serializable] 20 | private class ErrorData 21 | { 22 | [SerializeField] public int code; 23 | [SerializeField] public string message; 24 | } 25 | 26 | [Serializable] 27 | public class APIError 28 | { 29 | [Serializable] 30 | public class Error 31 | { 32 | [SerializeField] 33 | public int code; 34 | 35 | [SerializeField] 36 | public string message; 37 | } 38 | 39 | [SerializeField] 40 | public Error[] errors; 41 | } 42 | 43 | private TwitterConnector _connector; 44 | 45 | private Action loginSuccessAction { set; get; } 46 | private Action loginFailureAction { set; get; } 47 | 48 | /* 49 | called from Native Plugin via UnitySendMessage. 50 | */ 51 | public void LoginComplete(string sessionData) 52 | { 53 | if (loginSuccessAction != null) 54 | { 55 | var session = JsonUtility.FromJson(sessionData); 56 | loginSuccessAction(session.nickname, session.accessToken, session.accessSecret); 57 | } 58 | } 59 | 60 | /* 61 | called from Native Plugin via UnitySendMessage. 62 | */ 63 | public void LoginFailed(string errorData) 64 | { 65 | if (loginFailureAction != null) 66 | { 67 | var error = JsonUtility.FromJson(errorData); 68 | loginFailureAction(error.code, error.message); 69 | } 70 | } 71 | 72 | /* 73 | static functions. 74 | */ 75 | 76 | private enum TKState 77 | { 78 | NotLoggedIn, 79 | APIReady 80 | } 81 | private static TKState _state = TKState.NotLoggedIn; 82 | 83 | private static ITwitterImpl _twitter; 84 | private static TwitterAPI _component; 85 | 86 | 87 | private static void GenerateInstanceIfNeed() 88 | { 89 | if (_component == null) 90 | { 91 | var twitterGameObject = new GameObject("TorikiGameObject"); 92 | _component = twitterGameObject.AddComponent(); 93 | } 94 | } 95 | 96 | private static void InitializeTwitterPlugin() 97 | { 98 | // initialize plugin implementation if need. 99 | if (_twitter == null) 100 | { 101 | #if UNITY_EDITOR 102 | _twitter = new EditorTwitterImpl(); 103 | #elif UNITY_IOS 104 | _twitter = new IOSTwitterImpl(); 105 | #elif UNITY_ANDROID 106 | _twitter = new AndroidTwitterImpl(); 107 | #endif 108 | 109 | _twitter.Init(TwitterSettings.ConsumerKey, TwitterSettings.ConsumerSecret); 110 | } 111 | } 112 | 113 | /* 114 | initialize with token. 115 | */ 116 | public static void InitWithToken(string accessToken, string accessSecret) 117 | { 118 | InitializeTwitterPlugin(); 119 | 120 | // load component. 121 | GenerateInstanceIfNeed(); 122 | 123 | // initialize twitter connector. 124 | _component._connector = new TwitterConnector(TwitterSettings.ConsumerKey, TwitterSettings.ConsumerSecret, accessToken, accessSecret); 125 | _state = TKState.APIReady; 126 | } 127 | 128 | /* 129 | initialize with login. 130 | */ 131 | public static void InitWithLogin(Action successCallback, Action failureCallback) 132 | { 133 | InitializeTwitterPlugin(); 134 | 135 | // load component. 136 | GenerateInstanceIfNeed(); 137 | 138 | _component.loginSuccessAction = (nickname, token, secret) => 139 | { 140 | // API Connectorの初期化 141 | _component._connector = new TwitterConnector(TwitterSettings.ConsumerKey, TwitterSettings.ConsumerSecret, token, secret); 142 | _state = TKState.APIReady; 143 | 144 | successCallback(nickname, token, secret); 145 | }; 146 | _component.loginFailureAction = failureCallback; 147 | _twitter.LogIn(); 148 | } 149 | 150 | public static void Get(string url, SortedDictionary parameters, Action onSucceeded, Action onFailed) 151 | { 152 | if (_state != TKState.APIReady) 153 | { 154 | onFailed(0, new APIError.Error[]{new APIError.Error(){ 155 | code = 0, 156 | message = "not logged in. please Login first." 157 | }}); 158 | return; 159 | } 160 | 161 | GenerateInstanceIfNeed(); 162 | 163 | var cor = _component._connector.GenerateAccessCoroutine( 164 | url, 165 | TKMethod.GET, 166 | parameters, 167 | null, 168 | (conId, code, resp, data) => 169 | { 170 | onSucceeded(data); 171 | }, 172 | (conId, code, error, resp) => 173 | { 174 | onFailed(code, error.errors); 175 | } 176 | ); 177 | 178 | _component.StartCoroutine(cor); 179 | } 180 | 181 | public static void Post(string url, SortedDictionary parameters, Action onSucceeded, Action onFailed) 182 | { 183 | if (_state != TKState.APIReady) 184 | { 185 | onFailed(0, new APIError.Error[]{new APIError.Error(){ 186 | code = 0, 187 | message = "not logged in. please Login first." 188 | }}); 189 | return; 190 | } 191 | 192 | GenerateInstanceIfNeed(); 193 | 194 | var cor = _component._connector.GenerateAccessCoroutine( 195 | url, 196 | TKMethod.POST, 197 | null, 198 | parameters, 199 | (conId, code, resp, data) => 200 | { 201 | onSucceeded(data); 202 | }, 203 | (conId, code, error, resp) => 204 | { 205 | onFailed(code, error.errors); 206 | } 207 | ); 208 | 209 | _component.StartCoroutine(cor); 210 | } 211 | } 212 | } 213 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/TwitterAPI.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: ab92d187fb6c746ab89f183d4147edeb 3 | MonoImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | defaultReferences: [] 7 | executionOrder: 0 8 | icon: {instanceID: 0} 9 | userData: 10 | assetBundleName: 11 | assetBundleVariant: 12 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/TwitterConnector.cs: -------------------------------------------------------------------------------- 1 | using System; 2 | using System.Collections; 3 | using System.Collections.Generic; 4 | using System.Security.Cryptography; 5 | using System.Text; 6 | using UnityEngine; 7 | using UnityEngine.Networking; 8 | 9 | namespace Toriki.Internal 10 | { 11 | public class TwitterConnector 12 | { 13 | 14 | private readonly string consumerKey; 15 | private readonly string consumerKeySecret; 16 | private readonly string accessToken; 17 | private readonly string accessTokenSecret; 18 | 19 | private const string OauthVersion = "1.0"; 20 | private const string OauthSignatureMethod = "HMAC-SHA1"; 21 | 22 | public TwitterConnector(string consumerKey, string consumerKeySecret, string accessToken, string accessTokenSecret) 23 | { 24 | this.consumerKey = consumerKey; 25 | this.consumerKeySecret = consumerKeySecret; 26 | this.accessToken = accessToken; 27 | this.accessTokenSecret = accessTokenSecret; 28 | } 29 | 30 | 31 | /* 32 | 与えられたTwitter API urlに対し、指定したHTTPメソッドでアクセスを行う。 33 | */ 34 | public IEnumerator GenerateAccessCoroutine( 35 | string resourceUrl, 36 | TKMethod method, 37 | SortedDictionary urlQueryParameters, 38 | SortedDictionary bodyParameters, 39 | Action, string> succeeded, 40 | Action> failed 41 | ) 42 | { 43 | if (urlQueryParameters == null) urlQueryParameters = new SortedDictionary(); 44 | if (bodyParameters == null) bodyParameters = new SortedDictionary(); 45 | 46 | /* 47 | collect all parameters. 48 | */ 49 | var allParameters = new SortedDictionary(); 50 | foreach (var item in urlQueryParameters) 51 | { 52 | allParameters[item.Key] = item.Value; 53 | } 54 | 55 | foreach (var item in bodyParameters) 56 | { 57 | allParameters[item.Key] = item.Value; 58 | } 59 | 60 | 61 | var oauthNonce = GenerateNonce(); 62 | var oauthTimestamp = GenerateTimestamp(); 63 | var oauthSignature = GenerateSignature(resourceUrl, method, oauthNonce, oauthTimestamp, allParameters); 64 | 65 | /* 66 | generate authorization header. 67 | */ 68 | const string headerFormat = "OAuth oauth_consumer_key=\"{0}\", oauth_nonce=\"{1}\", " + "oauth_signature=\"{2}\", oauth_signature_method=\"{3}\", " + "oauth_timestamp=\"{4}\", oauth_token=\"{5}\", " + "oauth_version=\"{6}\""; 69 | 70 | var authHeader = string.Format(headerFormat, 71 | Uri.EscapeDataString(consumerKey), 72 | Uri.EscapeDataString(oauthNonce), 73 | Uri.EscapeDataString(oauthSignature), 74 | Uri.EscapeDataString(OauthSignatureMethod), 75 | Uri.EscapeDataString(oauthTimestamp), 76 | Uri.EscapeDataString(accessToken), 77 | Uri.EscapeDataString(OauthVersion) 78 | ); 79 | 80 | // Debug.Log("authHeader:" + authHeader); 81 | 82 | var reqCon = new TKHTTPConnection(); 83 | IEnumerator requestCor = null; 84 | 85 | switch (method) 86 | { 87 | case TKMethod.GET: 88 | { 89 | requestCor = reqCon.Get( 90 | "twitterCon_Get_" + Guid.NewGuid().ToString(), 91 | new Dictionary 92 | { 93 | {"Authorization", authHeader} 94 | }, 95 | resourceUrl + GenerateQueryParameters(urlQueryParameters), 96 | succeeded, 97 | (conId, code, reason, response) => 98 | { 99 | TwitterAPI.APIError error = null; 100 | try 101 | { 102 | error = JsonUtility.FromJson(reason); 103 | } 104 | catch 105 | { 106 | error = new TwitterAPI.APIError() 107 | { 108 | errors = new TwitterAPI.APIError.Error[1] 109 | { 110 | new TwitterAPI.APIError.Error() 111 | { 112 | code = code, 113 | message = reason 114 | } 115 | } 116 | }; 117 | } 118 | 119 | failed(conId, code, error, response); 120 | } 121 | ); 122 | break; 123 | } 124 | case TKMethod.POST: 125 | { 126 | var pairArray = new List(); 127 | foreach (var pair in bodyParameters) 128 | { 129 | var kv = "\"" + pair.Key + "\":\"" + pair.Value + "\""; 130 | pairArray.Add(kv); 131 | } 132 | 133 | var data = "{" + string.Join(",", pairArray.ToArray()) + "}"; 134 | 135 | requestCor = reqCon.Post( 136 | "twitterCon_Post_" + Guid.NewGuid().ToString(), 137 | new Dictionary 138 | { 139 | {"Authorization", authHeader}, 140 | }, 141 | resourceUrl + GenerateQueryParameters(bodyParameters), 142 | data, 143 | succeeded, 144 | (conId, code, reason, response) => 145 | { 146 | TwitterAPI.APIError error = null; 147 | try 148 | { 149 | error = JsonUtility.FromJson(reason); 150 | } 151 | catch 152 | { 153 | error = new TwitterAPI.APIError() 154 | { 155 | errors = new TwitterAPI.APIError.Error[1] 156 | { 157 | new TwitterAPI.APIError.Error() 158 | { 159 | code = code, 160 | message = reason 161 | } 162 | } 163 | }; 164 | } 165 | 166 | failed(conId, code, error, response); 167 | } 168 | ); 169 | break; 170 | } 171 | } 172 | 173 | while (requestCor.MoveNext()) 174 | { 175 | yield return null; 176 | } 177 | } 178 | 179 | private class TKHTTPConnection 180 | { 181 | public IEnumerator Get(string connectionId, Dictionary requestHeader, string url, Action, string> succeeded, Action> failed) 182 | { 183 | var currentDate = DateTime.UtcNow; 184 | 185 | using (var request = UnityWebRequest.Get(url)) 186 | { 187 | if (requestHeader != null) 188 | { 189 | foreach (var kv in requestHeader) 190 | { 191 | request.SetRequestHeader(kv.Key, kv.Value); 192 | } 193 | } 194 | request.chunkedTransfer = false; 195 | 196 | var p = request.SendWebRequest(); 197 | 198 | while (!p.isDone) 199 | { 200 | yield return null; 201 | } 202 | 203 | var responseCode = (int)request.responseCode; 204 | var responseHeaders = request.GetResponseHeaders(); 205 | 206 | if (request.isNetworkError) 207 | { 208 | failed(connectionId, responseCode, request.error, responseHeaders); 209 | yield break; 210 | } 211 | 212 | var result = Encoding.UTF8.GetString(request.downloadHandler.data); 213 | if (200 <= responseCode && responseCode <= 299) 214 | { 215 | succeeded(connectionId, responseCode, responseHeaders, result); 216 | } 217 | else 218 | { 219 | failed(connectionId, responseCode, result, responseHeaders); 220 | } 221 | } 222 | } 223 | 224 | public IEnumerator Post(string connectionId, Dictionary requestHeader, string url, string data, Action, string> succeeded, Action> failed) 225 | { 226 | var currentDate = DateTime.UtcNow; 227 | 228 | using (var request = UnityWebRequest.Post(url, data)) 229 | { 230 | request.uploadHandler = (UploadHandler)new UploadHandlerRaw(Encoding.UTF8.GetBytes(data)); 231 | if (requestHeader != null) 232 | { 233 | foreach (var kv in requestHeader) 234 | { 235 | request.SetRequestHeader(kv.Key, kv.Value); 236 | } 237 | } 238 | request.chunkedTransfer = false; 239 | 240 | var p = request.SendWebRequest(); 241 | 242 | while (!p.isDone) 243 | { 244 | yield return null; 245 | } 246 | 247 | var responseCode = (int)request.responseCode; 248 | var responseHeaders = request.GetResponseHeaders(); 249 | 250 | if (request.isNetworkError) 251 | { 252 | failed(connectionId, responseCode, request.error, responseHeaders); 253 | yield break; 254 | } 255 | 256 | var result = Encoding.UTF8.GetString(request.downloadHandler.data); 257 | if (200 <= responseCode && responseCode <= 299) 258 | { 259 | succeeded(connectionId, responseCode, responseHeaders, result); 260 | } 261 | else 262 | { 263 | failed(connectionId, responseCode, result, responseHeaders); 264 | } 265 | } 266 | } 267 | } 268 | 269 | private string GenerateNonce() 270 | { 271 | return Convert.ToBase64String(new ASCIIEncoding().GetBytes(DateTime.Now.Ticks.ToString())); 272 | } 273 | 274 | private string GenerateQueryParameters(SortedDictionary urlQueryParameters) 275 | { 276 | if (urlQueryParameters.Count == 0) 277 | { 278 | return string.Empty; 279 | } 280 | 281 | var builder = new List(); 282 | 283 | foreach (var item in urlQueryParameters) 284 | { 285 | builder.Add(item.Key + "=" + Uri.EscapeDataString(item.Value)); 286 | } 287 | 288 | return "?" + string.Join("&", builder.ToArray()); 289 | } 290 | 291 | private string ToWebString(SortedDictionary source) 292 | { 293 | var body = new StringBuilder(); 294 | 295 | foreach (var requestParameter in source) 296 | { 297 | body.Append(requestParameter.Key); 298 | body.Append("="); 299 | body.Append(Uri.EscapeDataString(requestParameter.Value)); 300 | body.Append("&"); 301 | } 302 | 303 | //不要な末尾の&を消す。 304 | body.Remove(body.Length - 1, 1); 305 | 306 | return body.ToString(); 307 | } 308 | 309 | private string GenerateSignature(string resourceUrl, TKMethod method, string oauthNonce, string oauthTimestamp, SortedDictionary requestParameters) 310 | { 311 | // パラメータ集合にoauth用の値を加える。 312 | requestParameters.Add("oauth_consumer_key", consumerKey); 313 | requestParameters.Add("oauth_nonce", oauthNonce); 314 | requestParameters.Add("oauth_signature_method", OauthSignatureMethod); 315 | requestParameters.Add("oauth_timestamp", oauthTimestamp); 316 | requestParameters.Add("oauth_token", accessToken); 317 | requestParameters.Add("oauth_version", OauthVersion); 318 | 319 | var sigBaseString = ToWebString(requestParameters); 320 | 321 | /* 322 | method と url と パラメータ列を&で結合 323 | */ 324 | var signatureBaseString = string.Concat( 325 | method.ToString(), 326 | "&", 327 | Uri.EscapeDataString(resourceUrl), 328 | "&", 329 | Uri.EscapeDataString(sigBaseString) 330 | ); 331 | 332 | // consumer secret と access secret を結合、 333 | var compositeKey = string.Concat(Uri.EscapeDataString(consumerKeySecret), "&", Uri.EscapeDataString(accessTokenSecret)); 334 | 335 | var oauthSignature = string.Empty; 336 | using (var hasher = new HMACSHA1(Encoding.ASCII.GetBytes(compositeKey))) 337 | { 338 | oauthSignature = Convert.ToBase64String( 339 | hasher.ComputeHash(Encoding.ASCII.GetBytes(signatureBaseString))); 340 | } 341 | 342 | return oauthSignature; 343 | } 344 | 345 | private static string GenerateTimestamp() 346 | { 347 | var nowUtc = DateTime.UtcNow; 348 | var timeSpan = nowUtc - new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc); 349 | var timestamp = Convert.ToInt64(timeSpan.TotalSeconds).ToString(); 350 | 351 | return timestamp; 352 | } 353 | } 354 | 355 | public enum TKMethod 356 | { 357 | POST, 358 | GET 359 | } 360 | } -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/TwitterConnector.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 588372032e5a5441f8d8c28ff183e2dc 3 | MonoImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | defaultReferences: [] 7 | executionOrder: 0 8 | icon: {instanceID: 0} 9 | userData: 10 | assetBundleName: 11 | assetBundleVariant: 12 | -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/TwitterSettings.cs: -------------------------------------------------------------------------------- 1 | using UnityEngine; 2 | 3 | namespace Toriki.Settings 4 | { 5 | public class TwitterSettings 6 | { 7 | public static readonly string ConsumerKey; 8 | public static readonly string ConsumerSecret; 9 | 10 | static TwitterSettings() 11 | { 12 | ConsumerKey = string.Empty; 13 | ConsumerSecret = string.Empty; 14 | 15 | if (string.IsNullOrEmpty(ConsumerKey)) 16 | { 17 | Debug.Log("ConsumerKey is null. please write some code for setting ConsumerKey."); 18 | } 19 | 20 | if (string.IsNullOrEmpty(ConsumerSecret)) 21 | { 22 | Debug.Log("ConsumerSecret is null. please write some code for setting ConsumerSecret."); 23 | } 24 | } 25 | } 26 | 27 | } -------------------------------------------------------------------------------- /Assets/Toriki/Scripts/TwitterSettings.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: ceaab206b4369435481b3f443a96b774 3 | timeCreated: 1499717552 4 | licenseType: Store 5 | MonoImporter: 6 | serializedVersion: 2 7 | defaultReferences: [] 8 | executionOrder: 0 9 | icon: {instanceID: 0} 10 | userData: 11 | assetBundleName: 12 | assetBundleVariant: 13 | -------------------------------------------------------------------------------- /Assets/_Sample.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 3e374103a8be042caac7368bc297f089 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/_Sample/APIAccess.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: e79cf15f552084f06ad6805259378ca3 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/_Sample/APIAccess/APIAccess.cs: -------------------------------------------------------------------------------- 1 | using System.Collections.Generic; 2 | using Toriki; 3 | using UnityEngine; 4 | 5 | public class APIAccess : MonoBehaviour 6 | { 7 | public static string ACCESS_TOKEN; 8 | public static string ACCESS_SECRET; 9 | 10 | void Start() 11 | { 12 | TwitterAPI.InitWithToken(ACCESS_TOKEN, ACCESS_SECRET); 13 | TwitterAPI.Get( 14 | "https://api.twitter.com/1.1/users/show.json", 15 | new SortedDictionary 16 | { 17 | {"screen_name", "toru_inoue"} 18 | }, 19 | result => 20 | { 21 | Debug.Log("show result:" + result); 22 | }, 23 | (code, errors) => 24 | { 25 | Debug.Log("show code:" + code); 26 | } 27 | ); 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /Assets/_Sample/APIAccess/APIAccess.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: cc5f975c8b2f54b9e90b113f96648d3d 3 | MonoImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | defaultReferences: [] 7 | executionOrder: 0 8 | icon: {instanceID: 0} 9 | userData: 10 | assetBundleName: 11 | assetBundleVariant: 12 | -------------------------------------------------------------------------------- /Assets/_Sample/APIAccess/APIAccess.unity: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!29 &1 4 | OcclusionCullingSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 2 7 | m_OcclusionBakeSettings: 8 | smallestOccluder: 5 9 | smallestHole: 0.25 10 | backfaceThreshold: 100 11 | m_SceneGUID: 00000000000000000000000000000000 12 | m_OcclusionCullingData: {fileID: 0} 13 | --- !u!104 &2 14 | RenderSettings: 15 | m_ObjectHideFlags: 0 16 | serializedVersion: 9 17 | m_Fog: 0 18 | m_FogColor: {r: 0.5, g: 0.5, b: 0.5, a: 1} 19 | m_FogMode: 3 20 | m_FogDensity: 0.01 21 | m_LinearFogStart: 0 22 | m_LinearFogEnd: 300 23 | m_AmbientSkyColor: {r: 0.212, g: 0.227, b: 0.259, a: 1} 24 | m_AmbientEquatorColor: {r: 0.114, g: 0.125, b: 0.133, a: 1} 25 | m_AmbientGroundColor: {r: 0.047, g: 0.043, b: 0.035, a: 1} 26 | m_AmbientIntensity: 1 27 | m_AmbientMode: 0 28 | m_SubtractiveShadowColor: {r: 0.42, g: 0.478, b: 0.627, a: 1} 29 | m_SkyboxMaterial: {fileID: 10304, guid: 0000000000000000f000000000000000, type: 0} 30 | m_HaloStrength: 0.5 31 | m_FlareStrength: 1 32 | m_FlareFadeSpeed: 3 33 | m_HaloTexture: {fileID: 0} 34 | m_SpotCookie: {fileID: 10001, guid: 0000000000000000e000000000000000, type: 0} 35 | m_DefaultReflectionMode: 0 36 | m_DefaultReflectionResolution: 128 37 | m_ReflectionBounces: 1 38 | m_ReflectionIntensity: 1 39 | m_CustomReflection: {fileID: 0} 40 | m_Sun: {fileID: 0} 41 | m_IndirectSpecularColor: {r: 0.44657838, g: 0.49641234, b: 0.57481676, a: 1} 42 | m_UseRadianceAmbientProbe: 0 43 | --- !u!157 &3 44 | LightmapSettings: 45 | m_ObjectHideFlags: 0 46 | serializedVersion: 11 47 | m_GIWorkflowMode: 0 48 | m_GISettings: 49 | serializedVersion: 2 50 | m_BounceScale: 1 51 | m_IndirectOutputScale: 1 52 | m_AlbedoBoost: 1 53 | m_TemporalCoherenceThreshold: 1 54 | m_EnvironmentLightingMode: 0 55 | m_EnableBakedLightmaps: 1 56 | m_EnableRealtimeLightmaps: 1 57 | m_LightmapEditorSettings: 58 | serializedVersion: 10 59 | m_Resolution: 2 60 | m_BakeResolution: 40 61 | m_AtlasSize: 1024 62 | m_AO: 0 63 | m_AOMaxDistance: 1 64 | m_CompAOExponent: 1 65 | m_CompAOExponentDirect: 0 66 | m_Padding: 2 67 | m_LightmapParameters: {fileID: 0} 68 | m_LightmapsBakeMode: 1 69 | m_TextureCompression: 1 70 | m_FinalGather: 0 71 | m_FinalGatherFiltering: 1 72 | m_FinalGatherRayCount: 256 73 | m_ReflectionCompression: 2 74 | m_MixedBakeMode: 2 75 | m_BakeBackend: 1 76 | m_PVRSampling: 1 77 | m_PVRDirectSampleCount: 32 78 | m_PVRSampleCount: 500 79 | m_PVRBounces: 2 80 | m_PVRFilterTypeDirect: 0 81 | m_PVRFilterTypeIndirect: 0 82 | m_PVRFilterTypeAO: 0 83 | m_PVRFilteringMode: 1 84 | m_PVRCulling: 1 85 | m_PVRFilteringGaussRadiusDirect: 1 86 | m_PVRFilteringGaussRadiusIndirect: 5 87 | m_PVRFilteringGaussRadiusAO: 2 88 | m_PVRFilteringAtrousPositionSigmaDirect: 0.5 89 | m_PVRFilteringAtrousPositionSigmaIndirect: 2 90 | m_PVRFilteringAtrousPositionSigmaAO: 1 91 | m_ShowResolutionOverlay: 1 92 | m_LightingDataAsset: {fileID: 0} 93 | m_UseShadowmask: 1 94 | --- !u!196 &4 95 | NavMeshSettings: 96 | serializedVersion: 2 97 | m_ObjectHideFlags: 0 98 | m_BuildSettings: 99 | serializedVersion: 2 100 | agentTypeID: 0 101 | agentRadius: 0.5 102 | agentHeight: 2 103 | agentSlope: 45 104 | agentClimb: 0.4 105 | ledgeDropHeight: 0 106 | maxJumpAcrossDistance: 0 107 | minRegionArea: 2 108 | manualCellSize: 0 109 | cellSize: 0.16666667 110 | manualTileSize: 0 111 | tileSize: 256 112 | accuratePlacement: 0 113 | debug: 114 | m_Flags: 0 115 | m_NavMeshData: {fileID: 0} 116 | --- !u!1 &1278861411 117 | GameObject: 118 | m_ObjectHideFlags: 0 119 | m_CorrespondingSourceObject: {fileID: 0} 120 | m_PrefabInternal: {fileID: 0} 121 | serializedVersion: 6 122 | m_Component: 123 | - component: {fileID: 1278861413} 124 | - component: {fileID: 1278861412} 125 | m_Layer: 0 126 | m_Name: Directional Light 127 | m_TagString: Untagged 128 | m_Icon: {fileID: 0} 129 | m_NavMeshLayer: 0 130 | m_StaticEditorFlags: 0 131 | m_IsActive: 1 132 | --- !u!108 &1278861412 133 | Light: 134 | m_ObjectHideFlags: 0 135 | m_CorrespondingSourceObject: {fileID: 0} 136 | m_PrefabInternal: {fileID: 0} 137 | m_GameObject: {fileID: 1278861411} 138 | m_Enabled: 1 139 | serializedVersion: 8 140 | m_Type: 1 141 | m_Color: {r: 1, g: 0.95686275, b: 0.8392157, a: 1} 142 | m_Intensity: 1 143 | m_Range: 10 144 | m_SpotAngle: 30 145 | m_CookieSize: 10 146 | m_Shadows: 147 | m_Type: 2 148 | m_Resolution: -1 149 | m_CustomResolution: -1 150 | m_Strength: 1 151 | m_Bias: 0.05 152 | m_NormalBias: 0.4 153 | m_NearPlane: 0.2 154 | m_Cookie: {fileID: 0} 155 | m_DrawHalo: 0 156 | m_Flare: {fileID: 0} 157 | m_RenderMode: 0 158 | m_CullingMask: 159 | serializedVersion: 2 160 | m_Bits: 4294967295 161 | m_Lightmapping: 4 162 | m_LightShadowCasterMode: 0 163 | m_AreaSize: {x: 1, y: 1} 164 | m_BounceIntensity: 1 165 | m_ColorTemperature: 6570 166 | m_UseColorTemperature: 0 167 | m_ShadowRadius: 0 168 | m_ShadowAngle: 0 169 | --- !u!4 &1278861413 170 | Transform: 171 | m_ObjectHideFlags: 0 172 | m_CorrespondingSourceObject: {fileID: 0} 173 | m_PrefabInternal: {fileID: 0} 174 | m_GameObject: {fileID: 1278861411} 175 | m_LocalRotation: {x: 0.40821788, y: -0.23456968, z: 0.10938163, w: 0.8754261} 176 | m_LocalPosition: {x: 0, y: 3, z: 0} 177 | m_LocalScale: {x: 1, y: 1, z: 1} 178 | m_Children: [] 179 | m_Father: {fileID: 0} 180 | m_RootOrder: 1 181 | m_LocalEulerAnglesHint: {x: 50, y: -30, z: 0} 182 | --- !u!1 &1470649575 183 | GameObject: 184 | m_ObjectHideFlags: 0 185 | m_CorrespondingSourceObject: {fileID: 0} 186 | m_PrefabInternal: {fileID: 0} 187 | serializedVersion: 6 188 | m_Component: 189 | - component: {fileID: 1470649577} 190 | - component: {fileID: 1470649576} 191 | m_Layer: 0 192 | m_Name: APIAccessObject 193 | m_TagString: Untagged 194 | m_Icon: {fileID: 0} 195 | m_NavMeshLayer: 0 196 | m_StaticEditorFlags: 0 197 | m_IsActive: 1 198 | --- !u!114 &1470649576 199 | MonoBehaviour: 200 | m_ObjectHideFlags: 0 201 | m_CorrespondingSourceObject: {fileID: 0} 202 | m_PrefabInternal: {fileID: 0} 203 | m_GameObject: {fileID: 1470649575} 204 | m_Enabled: 1 205 | m_EditorHideFlags: 0 206 | m_Script: {fileID: 11500000, guid: cc5f975c8b2f54b9e90b113f96648d3d, type: 3} 207 | m_Name: 208 | m_EditorClassIdentifier: 209 | --- !u!4 &1470649577 210 | Transform: 211 | m_ObjectHideFlags: 0 212 | m_CorrespondingSourceObject: {fileID: 0} 213 | m_PrefabInternal: {fileID: 0} 214 | m_GameObject: {fileID: 1470649575} 215 | m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} 216 | m_LocalPosition: {x: 0, y: 0, z: 0} 217 | m_LocalScale: {x: 1, y: 1, z: 1} 218 | m_Children: [] 219 | m_Father: {fileID: 0} 220 | m_RootOrder: 2 221 | m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} 222 | --- !u!1 &1968898974 223 | GameObject: 224 | m_ObjectHideFlags: 0 225 | m_CorrespondingSourceObject: {fileID: 0} 226 | m_PrefabInternal: {fileID: 0} 227 | serializedVersion: 6 228 | m_Component: 229 | - component: {fileID: 1968898977} 230 | - component: {fileID: 1968898976} 231 | - component: {fileID: 1968898975} 232 | m_Layer: 0 233 | m_Name: Main Camera 234 | m_TagString: MainCamera 235 | m_Icon: {fileID: 0} 236 | m_NavMeshLayer: 0 237 | m_StaticEditorFlags: 0 238 | m_IsActive: 1 239 | --- !u!81 &1968898975 240 | AudioListener: 241 | m_ObjectHideFlags: 0 242 | m_CorrespondingSourceObject: {fileID: 0} 243 | m_PrefabInternal: {fileID: 0} 244 | m_GameObject: {fileID: 1968898974} 245 | m_Enabled: 1 246 | --- !u!20 &1968898976 247 | Camera: 248 | m_ObjectHideFlags: 0 249 | m_CorrespondingSourceObject: {fileID: 0} 250 | m_PrefabInternal: {fileID: 0} 251 | m_GameObject: {fileID: 1968898974} 252 | m_Enabled: 1 253 | serializedVersion: 2 254 | m_ClearFlags: 1 255 | m_BackGroundColor: {r: 0.19215687, g: 0.3019608, b: 0.4745098, a: 0} 256 | m_projectionMatrixMode: 1 257 | m_SensorSize: {x: 36, y: 24} 258 | m_LensShift: {x: 0, y: 0} 259 | m_FocalLength: 50 260 | m_NormalizedViewPortRect: 261 | serializedVersion: 2 262 | x: 0 263 | y: 0 264 | width: 1 265 | height: 1 266 | near clip plane: 0.3 267 | far clip plane: 1000 268 | field of view: 60 269 | orthographic: 0 270 | orthographic size: 5 271 | m_Depth: -1 272 | m_CullingMask: 273 | serializedVersion: 2 274 | m_Bits: 4294967295 275 | m_RenderingPath: -1 276 | m_TargetTexture: {fileID: 0} 277 | m_TargetDisplay: 0 278 | m_TargetEye: 3 279 | m_HDR: 1 280 | m_AllowMSAA: 1 281 | m_AllowDynamicResolution: 0 282 | m_ForceIntoRT: 0 283 | m_OcclusionCulling: 1 284 | m_StereoConvergence: 10 285 | m_StereoSeparation: 0.022 286 | --- !u!4 &1968898977 287 | Transform: 288 | m_ObjectHideFlags: 0 289 | m_CorrespondingSourceObject: {fileID: 0} 290 | m_PrefabInternal: {fileID: 0} 291 | m_GameObject: {fileID: 1968898974} 292 | m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} 293 | m_LocalPosition: {x: 0, y: 1, z: -10} 294 | m_LocalScale: {x: 1, y: 1, z: 1} 295 | m_Children: [] 296 | m_Father: {fileID: 0} 297 | m_RootOrder: 0 298 | m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} 299 | -------------------------------------------------------------------------------- /Assets/_Sample/APIAccess/APIAccess.unity.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 80f3ce454182b4999a9c224bb61bc1c9 3 | DefaultImporter: 4 | externalObjects: {} 5 | userData: 6 | assetBundleName: 7 | assetBundleVariant: 8 | -------------------------------------------------------------------------------- /Assets/_Sample/Login.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 7b1b6e28664ca49278826d4d377572af 3 | folderAsset: yes 4 | DefaultImporter: 5 | externalObjects: {} 6 | userData: 7 | assetBundleName: 8 | assetBundleVariant: 9 | -------------------------------------------------------------------------------- /Assets/_Sample/Login/Login.cs: -------------------------------------------------------------------------------- 1 | using System.Collections.Generic; 2 | using Toriki; 3 | using UnityEngine; 4 | 5 | public class Login : MonoBehaviour 6 | { 7 | void Start() 8 | { 9 | TwitterAPI.InitWithLogin( 10 | (nickname, token, secret) => 11 | { 12 | // set access token to another scene API use. 13 | APIAccess.ACCESS_TOKEN = token; 14 | APIAccess.ACCESS_SECRET = secret; 15 | 16 | // tweet API example. 17 | TwitterAPI.Post( 18 | "https://api.twitter.com/1.1/statuses/update.json", 19 | new SortedDictionary 20 | { 21 | {"status", "#LoveToriki"} 22 | }, 23 | result => 24 | { 25 | Debug.Log("update result:" + result); 26 | UnityEngine.SceneManagement.SceneManager.LoadScene("_Sample/APIAccess/APIAccess"); 27 | }, 28 | (code, errors) => 29 | { 30 | Debug.Log("update code:" + code); 31 | } 32 | ); 33 | }, 34 | (errorCode, message) => 35 | { 36 | Debug.Log("login error:" + errorCode + " message:" + message); 37 | } 38 | ); 39 | } 40 | } 41 | -------------------------------------------------------------------------------- /Assets/_Sample/Login/Login.cs.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 72988b385fa7b4c17a1beeacd1be4d7c 3 | MonoImporter: 4 | externalObjects: {} 5 | serializedVersion: 2 6 | defaultReferences: [] 7 | executionOrder: 0 8 | icon: {instanceID: 0} 9 | userData: 10 | assetBundleName: 11 | assetBundleVariant: 12 | -------------------------------------------------------------------------------- /Assets/_Sample/Login/Login.unity: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!29 &1 4 | OcclusionCullingSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 2 7 | m_OcclusionBakeSettings: 8 | smallestOccluder: 5 9 | smallestHole: 0.25 10 | backfaceThreshold: 100 11 | m_SceneGUID: 00000000000000000000000000000000 12 | m_OcclusionCullingData: {fileID: 0} 13 | --- !u!104 &2 14 | RenderSettings: 15 | m_ObjectHideFlags: 0 16 | serializedVersion: 9 17 | m_Fog: 0 18 | m_FogColor: {r: 0.5, g: 0.5, b: 0.5, a: 1} 19 | m_FogMode: 3 20 | m_FogDensity: 0.01 21 | m_LinearFogStart: 0 22 | m_LinearFogEnd: 300 23 | m_AmbientSkyColor: {r: 0.212, g: 0.227, b: 0.259, a: 1} 24 | m_AmbientEquatorColor: {r: 0.114, g: 0.125, b: 0.133, a: 1} 25 | m_AmbientGroundColor: {r: 0.047, g: 0.043, b: 0.035, a: 1} 26 | m_AmbientIntensity: 1 27 | m_AmbientMode: 0 28 | m_SubtractiveShadowColor: {r: 0.42, g: 0.478, b: 0.627, a: 1} 29 | m_SkyboxMaterial: {fileID: 10304, guid: 0000000000000000f000000000000000, type: 0} 30 | m_HaloStrength: 0.5 31 | m_FlareStrength: 1 32 | m_FlareFadeSpeed: 3 33 | m_HaloTexture: {fileID: 0} 34 | m_SpotCookie: {fileID: 10001, guid: 0000000000000000e000000000000000, type: 0} 35 | m_DefaultReflectionMode: 0 36 | m_DefaultReflectionResolution: 128 37 | m_ReflectionBounces: 1 38 | m_ReflectionIntensity: 1 39 | m_CustomReflection: {fileID: 0} 40 | m_Sun: {fileID: 0} 41 | m_IndirectSpecularColor: {r: 0.44657838, g: 0.49641234, b: 0.57481676, a: 1} 42 | m_UseRadianceAmbientProbe: 0 43 | --- !u!157 &3 44 | LightmapSettings: 45 | m_ObjectHideFlags: 0 46 | serializedVersion: 11 47 | m_GIWorkflowMode: 0 48 | m_GISettings: 49 | serializedVersion: 2 50 | m_BounceScale: 1 51 | m_IndirectOutputScale: 1 52 | m_AlbedoBoost: 1 53 | m_TemporalCoherenceThreshold: 1 54 | m_EnvironmentLightingMode: 0 55 | m_EnableBakedLightmaps: 1 56 | m_EnableRealtimeLightmaps: 1 57 | m_LightmapEditorSettings: 58 | serializedVersion: 10 59 | m_Resolution: 2 60 | m_BakeResolution: 40 61 | m_AtlasSize: 1024 62 | m_AO: 0 63 | m_AOMaxDistance: 1 64 | m_CompAOExponent: 1 65 | m_CompAOExponentDirect: 0 66 | m_Padding: 2 67 | m_LightmapParameters: {fileID: 0} 68 | m_LightmapsBakeMode: 1 69 | m_TextureCompression: 1 70 | m_FinalGather: 0 71 | m_FinalGatherFiltering: 1 72 | m_FinalGatherRayCount: 256 73 | m_ReflectionCompression: 2 74 | m_MixedBakeMode: 2 75 | m_BakeBackend: 1 76 | m_PVRSampling: 1 77 | m_PVRDirectSampleCount: 32 78 | m_PVRSampleCount: 500 79 | m_PVRBounces: 2 80 | m_PVRFilterTypeDirect: 0 81 | m_PVRFilterTypeIndirect: 0 82 | m_PVRFilterTypeAO: 0 83 | m_PVRFilteringMode: 1 84 | m_PVRCulling: 1 85 | m_PVRFilteringGaussRadiusDirect: 1 86 | m_PVRFilteringGaussRadiusIndirect: 5 87 | m_PVRFilteringGaussRadiusAO: 2 88 | m_PVRFilteringAtrousPositionSigmaDirect: 0.5 89 | m_PVRFilteringAtrousPositionSigmaIndirect: 2 90 | m_PVRFilteringAtrousPositionSigmaAO: 1 91 | m_ShowResolutionOverlay: 1 92 | m_LightingDataAsset: {fileID: 0} 93 | m_UseShadowmask: 1 94 | --- !u!196 &4 95 | NavMeshSettings: 96 | serializedVersion: 2 97 | m_ObjectHideFlags: 0 98 | m_BuildSettings: 99 | serializedVersion: 2 100 | agentTypeID: 0 101 | agentRadius: 0.5 102 | agentHeight: 2 103 | agentSlope: 45 104 | agentClimb: 0.4 105 | ledgeDropHeight: 0 106 | maxJumpAcrossDistance: 0 107 | minRegionArea: 2 108 | manualCellSize: 0 109 | cellSize: 0.16666667 110 | manualTileSize: 0 111 | tileSize: 256 112 | accuratePlacement: 0 113 | debug: 114 | m_Flags: 0 115 | m_NavMeshData: {fileID: 0} 116 | --- !u!1 &697578114 117 | GameObject: 118 | m_ObjectHideFlags: 0 119 | m_CorrespondingSourceObject: {fileID: 0} 120 | m_PrefabInternal: {fileID: 0} 121 | serializedVersion: 6 122 | m_Component: 123 | - component: {fileID: 697578116} 124 | - component: {fileID: 697578115} 125 | m_Layer: 0 126 | m_Name: Directional Light 127 | m_TagString: Untagged 128 | m_Icon: {fileID: 0} 129 | m_NavMeshLayer: 0 130 | m_StaticEditorFlags: 0 131 | m_IsActive: 1 132 | --- !u!108 &697578115 133 | Light: 134 | m_ObjectHideFlags: 0 135 | m_CorrespondingSourceObject: {fileID: 0} 136 | m_PrefabInternal: {fileID: 0} 137 | m_GameObject: {fileID: 697578114} 138 | m_Enabled: 1 139 | serializedVersion: 8 140 | m_Type: 1 141 | m_Color: {r: 1, g: 0.95686275, b: 0.8392157, a: 1} 142 | m_Intensity: 1 143 | m_Range: 10 144 | m_SpotAngle: 30 145 | m_CookieSize: 10 146 | m_Shadows: 147 | m_Type: 2 148 | m_Resolution: -1 149 | m_CustomResolution: -1 150 | m_Strength: 1 151 | m_Bias: 0.05 152 | m_NormalBias: 0.4 153 | m_NearPlane: 0.2 154 | m_Cookie: {fileID: 0} 155 | m_DrawHalo: 0 156 | m_Flare: {fileID: 0} 157 | m_RenderMode: 0 158 | m_CullingMask: 159 | serializedVersion: 2 160 | m_Bits: 4294967295 161 | m_Lightmapping: 4 162 | m_LightShadowCasterMode: 0 163 | m_AreaSize: {x: 1, y: 1} 164 | m_BounceIntensity: 1 165 | m_ColorTemperature: 6570 166 | m_UseColorTemperature: 0 167 | m_ShadowRadius: 0 168 | m_ShadowAngle: 0 169 | --- !u!4 &697578116 170 | Transform: 171 | m_ObjectHideFlags: 0 172 | m_CorrespondingSourceObject: {fileID: 0} 173 | m_PrefabInternal: {fileID: 0} 174 | m_GameObject: {fileID: 697578114} 175 | m_LocalRotation: {x: 0.40821788, y: -0.23456968, z: 0.10938163, w: 0.8754261} 176 | m_LocalPosition: {x: 0, y: 3, z: 0} 177 | m_LocalScale: {x: 1, y: 1, z: 1} 178 | m_Children: [] 179 | m_Father: {fileID: 0} 180 | m_RootOrder: 1 181 | m_LocalEulerAnglesHint: {x: 50, y: -30, z: 0} 182 | --- !u!1 &1569407955 183 | GameObject: 184 | m_ObjectHideFlags: 0 185 | m_CorrespondingSourceObject: {fileID: 0} 186 | m_PrefabInternal: {fileID: 0} 187 | serializedVersion: 6 188 | m_Component: 189 | - component: {fileID: 1569407956} 190 | - component: {fileID: 1569407957} 191 | m_Layer: 0 192 | m_Name: TwitterLoginObject 193 | m_TagString: Untagged 194 | m_Icon: {fileID: 0} 195 | m_NavMeshLayer: 0 196 | m_StaticEditorFlags: 0 197 | m_IsActive: 1 198 | --- !u!4 &1569407956 199 | Transform: 200 | m_ObjectHideFlags: 0 201 | m_CorrespondingSourceObject: {fileID: 0} 202 | m_PrefabInternal: {fileID: 0} 203 | m_GameObject: {fileID: 1569407955} 204 | m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} 205 | m_LocalPosition: {x: 0, y: 0, z: 0} 206 | m_LocalScale: {x: 1, y: 1, z: 1} 207 | m_Children: [] 208 | m_Father: {fileID: 0} 209 | m_RootOrder: 2 210 | m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} 211 | --- !u!114 &1569407957 212 | MonoBehaviour: 213 | m_ObjectHideFlags: 0 214 | m_CorrespondingSourceObject: {fileID: 0} 215 | m_PrefabInternal: {fileID: 0} 216 | m_GameObject: {fileID: 1569407955} 217 | m_Enabled: 1 218 | m_EditorHideFlags: 0 219 | m_Script: {fileID: 11500000, guid: 72988b385fa7b4c17a1beeacd1be4d7c, type: 3} 220 | m_Name: 221 | m_EditorClassIdentifier: 222 | --- !u!1 &2060337238 223 | GameObject: 224 | m_ObjectHideFlags: 0 225 | m_CorrespondingSourceObject: {fileID: 0} 226 | m_PrefabInternal: {fileID: 0} 227 | serializedVersion: 6 228 | m_Component: 229 | - component: {fileID: 2060337242} 230 | - component: {fileID: 2060337241} 231 | - component: {fileID: 2060337240} 232 | m_Layer: 0 233 | m_Name: Main Camera 234 | m_TagString: MainCamera 235 | m_Icon: {fileID: 0} 236 | m_NavMeshLayer: 0 237 | m_StaticEditorFlags: 0 238 | m_IsActive: 1 239 | --- !u!81 &2060337240 240 | AudioListener: 241 | m_ObjectHideFlags: 0 242 | m_CorrespondingSourceObject: {fileID: 0} 243 | m_PrefabInternal: {fileID: 0} 244 | m_GameObject: {fileID: 2060337238} 245 | m_Enabled: 1 246 | --- !u!20 &2060337241 247 | Camera: 248 | m_ObjectHideFlags: 0 249 | m_CorrespondingSourceObject: {fileID: 0} 250 | m_PrefabInternal: {fileID: 0} 251 | m_GameObject: {fileID: 2060337238} 252 | m_Enabled: 1 253 | serializedVersion: 2 254 | m_ClearFlags: 1 255 | m_BackGroundColor: {r: 0.19215687, g: 0.3019608, b: 0.4745098, a: 0} 256 | m_projectionMatrixMode: 1 257 | m_SensorSize: {x: 36, y: 24} 258 | m_LensShift: {x: 0, y: 0} 259 | m_FocalLength: 50 260 | m_NormalizedViewPortRect: 261 | serializedVersion: 2 262 | x: 0 263 | y: 0 264 | width: 1 265 | height: 1 266 | near clip plane: 0.3 267 | far clip plane: 1000 268 | field of view: 60 269 | orthographic: 0 270 | orthographic size: 5 271 | m_Depth: -1 272 | m_CullingMask: 273 | serializedVersion: 2 274 | m_Bits: 4294967295 275 | m_RenderingPath: -1 276 | m_TargetTexture: {fileID: 0} 277 | m_TargetDisplay: 0 278 | m_TargetEye: 3 279 | m_HDR: 1 280 | m_AllowMSAA: 1 281 | m_AllowDynamicResolution: 0 282 | m_ForceIntoRT: 0 283 | m_OcclusionCulling: 1 284 | m_StereoConvergence: 10 285 | m_StereoSeparation: 0.022 286 | --- !u!4 &2060337242 287 | Transform: 288 | m_ObjectHideFlags: 0 289 | m_CorrespondingSourceObject: {fileID: 0} 290 | m_PrefabInternal: {fileID: 0} 291 | m_GameObject: {fileID: 2060337238} 292 | m_LocalRotation: {x: 0, y: 0, z: 0, w: 1} 293 | m_LocalPosition: {x: 0, y: 1, z: -10} 294 | m_LocalScale: {x: 1, y: 1, z: 1} 295 | m_Children: [] 296 | m_Father: {fileID: 0} 297 | m_RootOrder: 0 298 | m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0} 299 | -------------------------------------------------------------------------------- /Assets/_Sample/Login/Login.unity.meta: -------------------------------------------------------------------------------- 1 | fileFormatVersion: 2 2 | guid: 69f9ddb5c7aa4419ab8134a3aca42511 3 | DefaultImporter: 4 | externalObjects: {} 5 | userData: 6 | assetBundleName: 7 | assetBundleVariant: 8 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 sassembla 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. -------------------------------------------------------------------------------- /Packages/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "dependencies": { 3 | "com.unity.2d.sprite": "1.0.0", 4 | "com.unity.2d.tilemap": "1.0.0", 5 | "com.unity.analytics": "3.5.3", 6 | "com.unity.collab-proxy": "1.5.7", 7 | "com.unity.ext.nunit": "1.0.6", 8 | "com.unity.ide.rider": "2.0.7", 9 | "com.unity.ide.visualstudio": "2.0.8", 10 | "com.unity.ide.vscode": "1.2.3", 11 | "com.unity.purchasing": "3.2.1", 12 | "com.unity.test-framework": "1.1.24", 13 | "com.unity.textmeshpro": "3.0.6", 14 | "com.unity.timeline": "1.4.8", 15 | "com.unity.ugui": "1.0.0", 16 | "com.unity.modules.ai": "1.0.0", 17 | "com.unity.modules.androidjni": "1.0.0", 18 | "com.unity.modules.animation": "1.0.0", 19 | "com.unity.modules.assetbundle": "1.0.0", 20 | "com.unity.modules.audio": "1.0.0", 21 | "com.unity.modules.cloth": "1.0.0", 22 | "com.unity.modules.director": "1.0.0", 23 | "com.unity.modules.imageconversion": "1.0.0", 24 | "com.unity.modules.imgui": "1.0.0", 25 | "com.unity.modules.jsonserialize": "1.0.0", 26 | "com.unity.modules.particlesystem": "1.0.0", 27 | "com.unity.modules.physics": "1.0.0", 28 | "com.unity.modules.physics2d": "1.0.0", 29 | "com.unity.modules.screencapture": "1.0.0", 30 | "com.unity.modules.terrain": "1.0.0", 31 | "com.unity.modules.terrainphysics": "1.0.0", 32 | "com.unity.modules.tilemap": "1.0.0", 33 | "com.unity.modules.ui": "1.0.0", 34 | "com.unity.modules.uielements": "1.0.0", 35 | "com.unity.modules.umbra": "1.0.0", 36 | "com.unity.modules.unityanalytics": "1.0.0", 37 | "com.unity.modules.unitywebrequest": "1.0.0", 38 | "com.unity.modules.unitywebrequestassetbundle": "1.0.0", 39 | "com.unity.modules.unitywebrequestaudio": "1.0.0", 40 | "com.unity.modules.unitywebrequesttexture": "1.0.0", 41 | "com.unity.modules.unitywebrequestwww": "1.0.0", 42 | "com.unity.modules.vehicles": "1.0.0", 43 | "com.unity.modules.video": "1.0.0", 44 | "com.unity.modules.vr": "1.0.0", 45 | "com.unity.modules.wind": "1.0.0", 46 | "com.unity.modules.xr": "1.0.0" 47 | } 48 | } 49 | -------------------------------------------------------------------------------- /ProjectSettings/AudioManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!11 &1 4 | AudioManager: 5 | m_ObjectHideFlags: 0 6 | m_Volume: 1 7 | Rolloff Scale: 1 8 | Doppler Factor: 1 9 | Default Speaker Mode: 2 10 | m_SampleRate: 0 11 | m_DSPBufferSize: 1024 12 | m_VirtualVoiceCount: 512 13 | m_RealVoiceCount: 32 14 | m_SpatializerPlugin: 15 | m_AmbisonicDecoderPlugin: 16 | m_DisableAudio: 0 17 | m_VirtualizeEffects: 1 18 | -------------------------------------------------------------------------------- /ProjectSettings/ClusterInputManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!236 &1 4 | ClusterInputManager: 5 | m_ObjectHideFlags: 0 6 | m_Inputs: [] 7 | -------------------------------------------------------------------------------- /ProjectSettings/DynamicsManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!55 &1 4 | PhysicsManager: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 7 7 | m_Gravity: {x: 0, y: -9.81, z: 0} 8 | m_DefaultMaterial: {fileID: 0} 9 | m_BounceThreshold: 2 10 | m_SleepThreshold: 0.005 11 | m_DefaultContactOffset: 0.01 12 | m_DefaultSolverIterations: 6 13 | m_DefaultSolverVelocityIterations: 1 14 | m_QueriesHitBackfaces: 0 15 | m_QueriesHitTriggers: 1 16 | m_EnableAdaptiveForce: 0 17 | m_ClothInterCollisionDistance: 0 18 | m_ClothInterCollisionStiffness: 0 19 | m_ContactsGeneration: 1 20 | m_LayerCollisionMatrix: ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 21 | m_AutoSimulation: 1 22 | m_AutoSyncTransforms: 1 23 | m_ClothInterCollisionSettingsToggle: 0 24 | m_ContactPairsMode: 0 25 | m_BroadphaseType: 0 26 | m_WorldBounds: 27 | m_Center: {x: 0, y: 0, z: 0} 28 | m_Extent: {x: 250, y: 250, z: 250} 29 | m_WorldSubdivisions: 8 30 | -------------------------------------------------------------------------------- /ProjectSettings/EditorBuildSettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!1045 &1 4 | EditorBuildSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 2 7 | m_Scenes: 8 | - enabled: 1 9 | path: Assets/_Sample/Login/Login.unity 10 | guid: 69f9ddb5c7aa4419ab8134a3aca42511 11 | - enabled: 1 12 | path: Assets/_Sample/APIAccess/APIAccess.unity 13 | guid: 80f3ce454182b4999a9c224bb61bc1c9 14 | m_configObjects: {} 15 | -------------------------------------------------------------------------------- /ProjectSettings/EditorSettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!159 &1 4 | EditorSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 7 7 | m_ExternalVersionControlSupport: Hidden Meta Files 8 | m_SerializationMode: 2 9 | m_LineEndingsForNewScripts: 1 10 | m_DefaultBehaviorMode: 0 11 | m_SpritePackerMode: 0 12 | m_SpritePackerPaddingPower: 1 13 | m_EtcTextureCompressorBehavior: 1 14 | m_EtcTextureFastCompressor: 1 15 | m_EtcTextureNormalCompressor: 2 16 | m_EtcTextureBestCompressor: 4 17 | m_ProjectGenerationIncludedExtensions: txt;xml;fnt;cd;asmdef;rsp 18 | m_ProjectGenerationRootNamespace: 19 | m_UserGeneratedProjectSuffix: 20 | m_CollabEditorSettings: 21 | inProgressEnabled: 1 22 | m_EnableTextureStreamingInPlayMode: 1 23 | -------------------------------------------------------------------------------- /ProjectSettings/GraphicsSettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!30 &1 4 | GraphicsSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 12 7 | m_Deferred: 8 | m_Mode: 1 9 | m_Shader: {fileID: 69, guid: 0000000000000000f000000000000000, type: 0} 10 | m_DeferredReflections: 11 | m_Mode: 1 12 | m_Shader: {fileID: 74, guid: 0000000000000000f000000000000000, type: 0} 13 | m_ScreenSpaceShadows: 14 | m_Mode: 1 15 | m_Shader: {fileID: 64, guid: 0000000000000000f000000000000000, type: 0} 16 | m_LegacyDeferred: 17 | m_Mode: 1 18 | m_Shader: {fileID: 63, guid: 0000000000000000f000000000000000, type: 0} 19 | m_DepthNormals: 20 | m_Mode: 1 21 | m_Shader: {fileID: 62, guid: 0000000000000000f000000000000000, type: 0} 22 | m_MotionVectors: 23 | m_Mode: 1 24 | m_Shader: {fileID: 75, guid: 0000000000000000f000000000000000, type: 0} 25 | m_LightHalo: 26 | m_Mode: 1 27 | m_Shader: {fileID: 105, guid: 0000000000000000f000000000000000, type: 0} 28 | m_LensFlare: 29 | m_Mode: 1 30 | m_Shader: {fileID: 102, guid: 0000000000000000f000000000000000, type: 0} 31 | m_AlwaysIncludedShaders: 32 | - {fileID: 7, guid: 0000000000000000f000000000000000, type: 0} 33 | - {fileID: 15104, guid: 0000000000000000f000000000000000, type: 0} 34 | - {fileID: 15105, guid: 0000000000000000f000000000000000, type: 0} 35 | - {fileID: 15106, guid: 0000000000000000f000000000000000, type: 0} 36 | - {fileID: 10753, guid: 0000000000000000f000000000000000, type: 0} 37 | - {fileID: 10770, guid: 0000000000000000f000000000000000, type: 0} 38 | - {fileID: 10783, guid: 0000000000000000f000000000000000, type: 0} 39 | - {fileID: 16000, guid: 0000000000000000f000000000000000, type: 0} 40 | - {fileID: 17000, guid: 0000000000000000f000000000000000, type: 0} 41 | m_PreloadedShaders: [] 42 | m_SpritesDefaultMaterial: {fileID: 10754, guid: 0000000000000000f000000000000000, 43 | type: 0} 44 | m_CustomRenderPipeline: {fileID: 0} 45 | m_TransparencySortMode: 0 46 | m_TransparencySortAxis: {x: 0, y: 0, z: 1} 47 | m_DefaultRenderingPath: 1 48 | m_DefaultMobileRenderingPath: 1 49 | m_TierSettings: [] 50 | m_LightmapStripping: 0 51 | m_FogStripping: 0 52 | m_InstancingStripping: 0 53 | m_LightmapKeepPlain: 1 54 | m_LightmapKeepDirCombined: 1 55 | m_LightmapKeepDynamicPlain: 1 56 | m_LightmapKeepDynamicDirCombined: 1 57 | m_LightmapKeepShadowMask: 1 58 | m_LightmapKeepSubtractive: 1 59 | m_FogKeepLinear: 1 60 | m_FogKeepExp: 1 61 | m_FogKeepExp2: 1 62 | m_AlbedoSwatchInfos: [] 63 | m_LightsUseLinearIntensity: 0 64 | m_LightsUseColorTemperature: 0 65 | -------------------------------------------------------------------------------- /ProjectSettings/InputManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!13 &1 4 | InputManager: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 2 7 | m_Axes: 8 | - serializedVersion: 3 9 | m_Name: Horizontal 10 | descriptiveName: 11 | descriptiveNegativeName: 12 | negativeButton: left 13 | positiveButton: right 14 | altNegativeButton: a 15 | altPositiveButton: d 16 | gravity: 3 17 | dead: 0.001 18 | sensitivity: 3 19 | snap: 1 20 | invert: 0 21 | type: 0 22 | axis: 0 23 | joyNum: 0 24 | - serializedVersion: 3 25 | m_Name: Vertical 26 | descriptiveName: 27 | descriptiveNegativeName: 28 | negativeButton: down 29 | positiveButton: up 30 | altNegativeButton: s 31 | altPositiveButton: w 32 | gravity: 3 33 | dead: 0.001 34 | sensitivity: 3 35 | snap: 1 36 | invert: 0 37 | type: 0 38 | axis: 0 39 | joyNum: 0 40 | - serializedVersion: 3 41 | m_Name: Fire1 42 | descriptiveName: 43 | descriptiveNegativeName: 44 | negativeButton: 45 | positiveButton: left ctrl 46 | altNegativeButton: 47 | altPositiveButton: mouse 0 48 | gravity: 1000 49 | dead: 0.001 50 | sensitivity: 1000 51 | snap: 0 52 | invert: 0 53 | type: 0 54 | axis: 0 55 | joyNum: 0 56 | - serializedVersion: 3 57 | m_Name: Fire2 58 | descriptiveName: 59 | descriptiveNegativeName: 60 | negativeButton: 61 | positiveButton: left alt 62 | altNegativeButton: 63 | altPositiveButton: mouse 1 64 | gravity: 1000 65 | dead: 0.001 66 | sensitivity: 1000 67 | snap: 0 68 | invert: 0 69 | type: 0 70 | axis: 0 71 | joyNum: 0 72 | - serializedVersion: 3 73 | m_Name: Fire3 74 | descriptiveName: 75 | descriptiveNegativeName: 76 | negativeButton: 77 | positiveButton: left shift 78 | altNegativeButton: 79 | altPositiveButton: mouse 2 80 | gravity: 1000 81 | dead: 0.001 82 | sensitivity: 1000 83 | snap: 0 84 | invert: 0 85 | type: 0 86 | axis: 0 87 | joyNum: 0 88 | - serializedVersion: 3 89 | m_Name: Jump 90 | descriptiveName: 91 | descriptiveNegativeName: 92 | negativeButton: 93 | positiveButton: space 94 | altNegativeButton: 95 | altPositiveButton: 96 | gravity: 1000 97 | dead: 0.001 98 | sensitivity: 1000 99 | snap: 0 100 | invert: 0 101 | type: 0 102 | axis: 0 103 | joyNum: 0 104 | - serializedVersion: 3 105 | m_Name: Mouse X 106 | descriptiveName: 107 | descriptiveNegativeName: 108 | negativeButton: 109 | positiveButton: 110 | altNegativeButton: 111 | altPositiveButton: 112 | gravity: 0 113 | dead: 0 114 | sensitivity: 0.1 115 | snap: 0 116 | invert: 0 117 | type: 1 118 | axis: 0 119 | joyNum: 0 120 | - serializedVersion: 3 121 | m_Name: Mouse Y 122 | descriptiveName: 123 | descriptiveNegativeName: 124 | negativeButton: 125 | positiveButton: 126 | altNegativeButton: 127 | altPositiveButton: 128 | gravity: 0 129 | dead: 0 130 | sensitivity: 0.1 131 | snap: 0 132 | invert: 0 133 | type: 1 134 | axis: 1 135 | joyNum: 0 136 | - serializedVersion: 3 137 | m_Name: Mouse ScrollWheel 138 | descriptiveName: 139 | descriptiveNegativeName: 140 | negativeButton: 141 | positiveButton: 142 | altNegativeButton: 143 | altPositiveButton: 144 | gravity: 0 145 | dead: 0 146 | sensitivity: 0.1 147 | snap: 0 148 | invert: 0 149 | type: 1 150 | axis: 2 151 | joyNum: 0 152 | - serializedVersion: 3 153 | m_Name: Horizontal 154 | descriptiveName: 155 | descriptiveNegativeName: 156 | negativeButton: 157 | positiveButton: 158 | altNegativeButton: 159 | altPositiveButton: 160 | gravity: 0 161 | dead: 0.19 162 | sensitivity: 1 163 | snap: 0 164 | invert: 0 165 | type: 2 166 | axis: 0 167 | joyNum: 0 168 | - serializedVersion: 3 169 | m_Name: Vertical 170 | descriptiveName: 171 | descriptiveNegativeName: 172 | negativeButton: 173 | positiveButton: 174 | altNegativeButton: 175 | altPositiveButton: 176 | gravity: 0 177 | dead: 0.19 178 | sensitivity: 1 179 | snap: 0 180 | invert: 1 181 | type: 2 182 | axis: 1 183 | joyNum: 0 184 | - serializedVersion: 3 185 | m_Name: Fire1 186 | descriptiveName: 187 | descriptiveNegativeName: 188 | negativeButton: 189 | positiveButton: joystick button 0 190 | altNegativeButton: 191 | altPositiveButton: 192 | gravity: 1000 193 | dead: 0.001 194 | sensitivity: 1000 195 | snap: 0 196 | invert: 0 197 | type: 0 198 | axis: 0 199 | joyNum: 0 200 | - serializedVersion: 3 201 | m_Name: Fire2 202 | descriptiveName: 203 | descriptiveNegativeName: 204 | negativeButton: 205 | positiveButton: joystick button 1 206 | altNegativeButton: 207 | altPositiveButton: 208 | gravity: 1000 209 | dead: 0.001 210 | sensitivity: 1000 211 | snap: 0 212 | invert: 0 213 | type: 0 214 | axis: 0 215 | joyNum: 0 216 | - serializedVersion: 3 217 | m_Name: Fire3 218 | descriptiveName: 219 | descriptiveNegativeName: 220 | negativeButton: 221 | positiveButton: joystick button 2 222 | altNegativeButton: 223 | altPositiveButton: 224 | gravity: 1000 225 | dead: 0.001 226 | sensitivity: 1000 227 | snap: 0 228 | invert: 0 229 | type: 0 230 | axis: 0 231 | joyNum: 0 232 | - serializedVersion: 3 233 | m_Name: Jump 234 | descriptiveName: 235 | descriptiveNegativeName: 236 | negativeButton: 237 | positiveButton: joystick button 3 238 | altNegativeButton: 239 | altPositiveButton: 240 | gravity: 1000 241 | dead: 0.001 242 | sensitivity: 1000 243 | snap: 0 244 | invert: 0 245 | type: 0 246 | axis: 0 247 | joyNum: 0 248 | - serializedVersion: 3 249 | m_Name: Submit 250 | descriptiveName: 251 | descriptiveNegativeName: 252 | negativeButton: 253 | positiveButton: return 254 | altNegativeButton: 255 | altPositiveButton: joystick button 0 256 | gravity: 1000 257 | dead: 0.001 258 | sensitivity: 1000 259 | snap: 0 260 | invert: 0 261 | type: 0 262 | axis: 0 263 | joyNum: 0 264 | - serializedVersion: 3 265 | m_Name: Submit 266 | descriptiveName: 267 | descriptiveNegativeName: 268 | negativeButton: 269 | positiveButton: enter 270 | altNegativeButton: 271 | altPositiveButton: space 272 | gravity: 1000 273 | dead: 0.001 274 | sensitivity: 1000 275 | snap: 0 276 | invert: 0 277 | type: 0 278 | axis: 0 279 | joyNum: 0 280 | - serializedVersion: 3 281 | m_Name: Cancel 282 | descriptiveName: 283 | descriptiveNegativeName: 284 | negativeButton: 285 | positiveButton: escape 286 | altNegativeButton: 287 | altPositiveButton: joystick button 1 288 | gravity: 1000 289 | dead: 0.001 290 | sensitivity: 1000 291 | snap: 0 292 | invert: 0 293 | type: 0 294 | axis: 0 295 | joyNum: 0 296 | -------------------------------------------------------------------------------- /ProjectSettings/NavMeshAreas.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!126 &1 4 | NavMeshProjectSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 2 7 | areas: 8 | - name: Walkable 9 | cost: 1 10 | - name: Not Walkable 11 | cost: 1 12 | - name: Jump 13 | cost: 2 14 | - name: 15 | cost: 1 16 | - name: 17 | cost: 1 18 | - name: 19 | cost: 1 20 | - name: 21 | cost: 1 22 | - name: 23 | cost: 1 24 | - name: 25 | cost: 1 26 | - name: 27 | cost: 1 28 | - name: 29 | cost: 1 30 | - name: 31 | cost: 1 32 | - name: 33 | cost: 1 34 | - name: 35 | cost: 1 36 | - name: 37 | cost: 1 38 | - name: 39 | cost: 1 40 | - name: 41 | cost: 1 42 | - name: 43 | cost: 1 44 | - name: 45 | cost: 1 46 | - name: 47 | cost: 1 48 | - name: 49 | cost: 1 50 | - name: 51 | cost: 1 52 | - name: 53 | cost: 1 54 | - name: 55 | cost: 1 56 | - name: 57 | cost: 1 58 | - name: 59 | cost: 1 60 | - name: 61 | cost: 1 62 | - name: 63 | cost: 1 64 | - name: 65 | cost: 1 66 | - name: 67 | cost: 1 68 | - name: 69 | cost: 1 70 | - name: 71 | cost: 1 72 | m_LastAgentTypeID: -887442657 73 | m_Settings: 74 | - serializedVersion: 2 75 | agentTypeID: 0 76 | agentRadius: 0.5 77 | agentHeight: 2 78 | agentSlope: 45 79 | agentClimb: 0.75 80 | ledgeDropHeight: 0 81 | maxJumpAcrossDistance: 0 82 | minRegionArea: 2 83 | manualCellSize: 0 84 | cellSize: 0.16666667 85 | manualTileSize: 0 86 | tileSize: 256 87 | accuratePlacement: 0 88 | debug: 89 | m_Flags: 0 90 | m_SettingNames: 91 | - Humanoid 92 | -------------------------------------------------------------------------------- /ProjectSettings/Physics2DSettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!19 &1 4 | Physics2DSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 3 7 | m_Gravity: {x: 0, y: -9.81} 8 | m_DefaultMaterial: {fileID: 0} 9 | m_VelocityIterations: 8 10 | m_PositionIterations: 3 11 | m_VelocityThreshold: 1 12 | m_MaxLinearCorrection: 0.2 13 | m_MaxAngularCorrection: 8 14 | m_MaxTranslationSpeed: 100 15 | m_MaxRotationSpeed: 360 16 | m_BaumgarteScale: 0.2 17 | m_BaumgarteTimeOfImpactScale: 0.75 18 | m_TimeToSleep: 0.5 19 | m_LinearSleepTolerance: 0.01 20 | m_AngularSleepTolerance: 2 21 | m_DefaultContactOffset: 0.01 22 | m_JobOptions: 23 | serializedVersion: 2 24 | useMultithreading: 0 25 | useConsistencySorting: 0 26 | m_InterpolationPosesPerJob: 100 27 | m_NewContactsPerJob: 30 28 | m_CollideContactsPerJob: 100 29 | m_ClearFlagsPerJob: 200 30 | m_ClearBodyForcesPerJob: 200 31 | m_SyncDiscreteFixturesPerJob: 50 32 | m_SyncContinuousFixturesPerJob: 50 33 | m_FindNearestContactsPerJob: 100 34 | m_UpdateTriggerContactsPerJob: 100 35 | m_IslandSolverCostThreshold: 100 36 | m_IslandSolverBodyCostScale: 1 37 | m_IslandSolverContactCostScale: 10 38 | m_IslandSolverJointCostScale: 10 39 | m_IslandSolverBodiesPerJob: 50 40 | m_IslandSolverContactsPerJob: 50 41 | m_AutoSimulation: 1 42 | m_QueriesHitTriggers: 1 43 | m_QueriesStartInColliders: 1 44 | m_CallbacksOnDisable: 1 45 | m_AutoSyncTransforms: 1 46 | m_AlwaysShowColliders: 0 47 | m_ShowColliderSleep: 1 48 | m_ShowColliderContacts: 0 49 | m_ShowColliderAABB: 0 50 | m_ContactArrowScale: 0.2 51 | m_ColliderAwakeColor: {r: 0.5686275, g: 0.95686275, b: 0.54509807, a: 0.7529412} 52 | m_ColliderAsleepColor: {r: 0.5686275, g: 0.95686275, b: 0.54509807, a: 0.36078432} 53 | m_ColliderContactColor: {r: 1, g: 0, b: 1, a: 0.6862745} 54 | m_ColliderAABBColor: {r: 1, g: 1, b: 0, a: 0.2509804} 55 | m_LayerCollisionMatrix: ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff 56 | -------------------------------------------------------------------------------- /ProjectSettings/PresetManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!1386491679 &1 4 | PresetManager: 5 | m_ObjectHideFlags: 0 6 | m_DefaultList: [] 7 | -------------------------------------------------------------------------------- /ProjectSettings/ProjectSettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!129 &1 4 | PlayerSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 18 7 | productGUID: e70d9bfd99ba24fffb59fd9dd77207a0 8 | AndroidProfiler: 0 9 | AndroidFilterTouchesWhenObscured: 0 10 | AndroidEnableSustainedPerformanceMode: 0 11 | defaultScreenOrientation: 4 12 | targetDevice: 2 13 | useOnDemandResources: 0 14 | accelerometerFrequency: 60 15 | companyName: DefaultCompany 16 | productName: toriki 17 | defaultCursor: {fileID: 0} 18 | cursorHotspot: {x: 0, y: 0} 19 | m_SplashScreenBackgroundColor: {r: 0.13725491, g: 0.12156863, b: 0.1254902, a: 1} 20 | m_ShowUnitySplashScreen: 1 21 | m_ShowUnitySplashLogo: 1 22 | m_SplashScreenOverlayOpacity: 1 23 | m_SplashScreenAnimation: 1 24 | m_SplashScreenLogoStyle: 1 25 | m_SplashScreenDrawMode: 0 26 | m_SplashScreenBackgroundAnimationZoom: 1 27 | m_SplashScreenLogoAnimationZoom: 1 28 | m_SplashScreenBackgroundLandscapeAspect: 1 29 | m_SplashScreenBackgroundPortraitAspect: 1 30 | m_SplashScreenBackgroundLandscapeUvs: 31 | serializedVersion: 2 32 | x: 0 33 | y: 0 34 | width: 1 35 | height: 1 36 | m_SplashScreenBackgroundPortraitUvs: 37 | serializedVersion: 2 38 | x: 0 39 | y: 0 40 | width: 1 41 | height: 1 42 | m_SplashScreenLogos: [] 43 | m_VirtualRealitySplashScreen: {fileID: 0} 44 | m_HolographicTrackingLossScreen: {fileID: 0} 45 | defaultScreenWidth: 1024 46 | defaultScreenHeight: 768 47 | defaultScreenWidthWeb: 960 48 | defaultScreenHeightWeb: 600 49 | m_StereoRenderingPath: 0 50 | m_ActiveColorSpace: 0 51 | m_MTRendering: 1 52 | m_StackTraceTypes: 010000000100000001000000010000000100000001000000 53 | iosShowActivityIndicatorOnLoading: -1 54 | androidShowActivityIndicatorOnLoading: -1 55 | displayResolutionDialog: 1 56 | iosUseCustomAppBackgroundBehavior: 0 57 | iosAllowHTTPDownload: 1 58 | allowedAutorotateToPortrait: 1 59 | allowedAutorotateToPortraitUpsideDown: 1 60 | allowedAutorotateToLandscapeRight: 1 61 | allowedAutorotateToLandscapeLeft: 1 62 | useOSAutorotation: 1 63 | use32BitDisplayBuffer: 1 64 | preserveFramebufferAlpha: 0 65 | disableDepthAndStencilBuffers: 0 66 | androidStartInFullscreen: 1 67 | androidRenderOutsideSafeArea: 1 68 | androidUseSwappy: 0 69 | androidBlitType: 0 70 | defaultIsNativeResolution: 1 71 | macRetinaSupport: 1 72 | runInBackground: 0 73 | captureSingleScreen: 0 74 | muteOtherAudioSources: 0 75 | Prepare IOS For Recording: 0 76 | Force IOS Speakers When Recording: 0 77 | deferSystemGesturesMode: 0 78 | hideHomeButton: 0 79 | submitAnalytics: 1 80 | usePlayerLog: 1 81 | bakeCollisionMeshes: 0 82 | forceSingleInstance: 0 83 | useFlipModelSwapchain: 1 84 | resizableWindow: 0 85 | useMacAppStoreValidation: 0 86 | macAppStoreCategory: public.app-category.games 87 | gpuSkinning: 0 88 | graphicsJobs: 0 89 | xboxPIXTextureCapture: 0 90 | xboxEnableAvatar: 0 91 | xboxEnableKinect: 0 92 | xboxEnableKinectAutoTracking: 0 93 | xboxEnableFitness: 0 94 | visibleInBackground: 1 95 | allowFullscreenSwitch: 1 96 | graphicsJobMode: 0 97 | fullscreenMode: 1 98 | xboxSpeechDB: 0 99 | xboxEnableHeadOrientation: 0 100 | xboxEnableGuest: 0 101 | xboxEnablePIXSampling: 0 102 | metalFramebufferOnly: 0 103 | xboxOneResolution: 0 104 | xboxOneSResolution: 0 105 | xboxOneXResolution: 3 106 | xboxOneMonoLoggingLevel: 0 107 | xboxOneLoggingLevel: 1 108 | xboxOneDisableEsram: 0 109 | xboxOnePresentImmediateThreshold: 0 110 | switchQueueCommandMemory: 0 111 | switchQueueControlMemory: 16384 112 | switchQueueComputeMemory: 262144 113 | switchNVNShaderPoolsGranularity: 33554432 114 | switchNVNDefaultPoolsGranularity: 16777216 115 | switchNVNOtherPoolsGranularity: 16777216 116 | vulkanEnableSetSRGBWrite: 0 117 | m_SupportedAspectRatios: 118 | 4:3: 1 119 | 5:4: 1 120 | 16:10: 1 121 | 16:9: 1 122 | Others: 1 123 | bundleVersion: 1.0 124 | preloadedAssets: [] 125 | metroInputSource: 0 126 | wsaTransparentSwapchain: 0 127 | m_HolographicPauseOnTrackingLoss: 1 128 | xboxOneDisableKinectGpuReservation: 0 129 | xboxOneEnable7thCore: 1 130 | vrSettings: 131 | cardboard: 132 | depthFormat: 0 133 | enableTransitionView: 0 134 | daydream: 135 | depthFormat: 0 136 | useSustainedPerformanceMode: 0 137 | enableVideoLayer: 0 138 | useProtectedVideoMemory: 0 139 | minimumSupportedHeadTracking: 0 140 | maximumSupportedHeadTracking: 1 141 | hololens: 142 | depthFormat: 1 143 | depthBufferSharingEnabled: 0 144 | lumin: 145 | depthFormat: 0 146 | frameTiming: 2 147 | enableGLCache: 0 148 | glCacheMaxBlobSize: 524288 149 | glCacheMaxFileSize: 8388608 150 | oculus: 151 | sharedDepthBuffer: 0 152 | dashSupport: 0 153 | lowOverheadMode: 0 154 | protectedContext: 0 155 | v2Signing: 0 156 | enable360StereoCapture: 0 157 | isWsaHolographicRemotingEnabled: 0 158 | protectGraphicsMemory: 0 159 | enableFrameTimingStats: 0 160 | useHDRDisplay: 0 161 | m_ColorGamuts: 00000000 162 | targetPixelDensity: 30 163 | resolutionScalingMode: 0 164 | androidSupportedAspectRatio: 1 165 | androidMaxAspectRatio: 2.1 166 | applicationIdentifier: 167 | iPhone: com.kissaki.test 168 | buildNumber: {} 169 | AndroidBundleVersionCode: 1 170 | AndroidMinSdkVersion: 16 171 | AndroidTargetSdkVersion: 0 172 | AndroidPreferredInstallLocation: 1 173 | aotOptions: 174 | stripEngineCode: 1 175 | iPhoneStrippingLevel: 0 176 | iPhoneScriptCallOptimization: 0 177 | ForceInternetPermission: 0 178 | ForceSDCardPermission: 0 179 | CreateWallpaper: 0 180 | APKExpansionFiles: 0 181 | keepLoadedShadersAlive: 0 182 | StripUnusedMeshComponents: 0 183 | VertexChannelCompressionMask: 4054 184 | iPhoneSdkVersion: 988 185 | iOSTargetOSVersionString: 9.0 186 | tvOSSdkVersion: 0 187 | tvOSRequireExtendedGameController: 0 188 | tvOSTargetOSVersionString: 9.0 189 | uIPrerenderedIcon: 0 190 | uIRequiresPersistentWiFi: 0 191 | uIRequiresFullScreen: 1 192 | uIStatusBarHidden: 1 193 | uIExitOnSuspend: 0 194 | uIStatusBarStyle: 0 195 | iPhoneSplashScreen: {fileID: 0} 196 | iPhoneHighResSplashScreen: {fileID: 0} 197 | iPhoneTallHighResSplashScreen: {fileID: 0} 198 | iPhone47inSplashScreen: {fileID: 0} 199 | iPhone55inPortraitSplashScreen: {fileID: 0} 200 | iPhone55inLandscapeSplashScreen: {fileID: 0} 201 | iPhone58inPortraitSplashScreen: {fileID: 0} 202 | iPhone58inLandscapeSplashScreen: {fileID: 0} 203 | iPadPortraitSplashScreen: {fileID: 0} 204 | iPadHighResPortraitSplashScreen: {fileID: 0} 205 | iPadLandscapeSplashScreen: {fileID: 0} 206 | iPadHighResLandscapeSplashScreen: {fileID: 0} 207 | iPhone65inPortraitSplashScreen: {fileID: 0} 208 | iPhone65inLandscapeSplashScreen: {fileID: 0} 209 | iPhone61inPortraitSplashScreen: {fileID: 0} 210 | iPhone61inLandscapeSplashScreen: {fileID: 0} 211 | appleTVSplashScreen: {fileID: 0} 212 | appleTVSplashScreen2x: {fileID: 0} 213 | tvOSSmallIconLayers: [] 214 | tvOSSmallIconLayers2x: [] 215 | tvOSLargeIconLayers: [] 216 | tvOSLargeIconLayers2x: [] 217 | tvOSTopShelfImageLayers: [] 218 | tvOSTopShelfImageLayers2x: [] 219 | tvOSTopShelfImageWideLayers: [] 220 | tvOSTopShelfImageWideLayers2x: [] 221 | iOSLaunchScreenType: 0 222 | iOSLaunchScreenPortrait: {fileID: 0} 223 | iOSLaunchScreenLandscape: {fileID: 0} 224 | iOSLaunchScreenBackgroundColor: 225 | serializedVersion: 2 226 | rgba: 0 227 | iOSLaunchScreenFillPct: 100 228 | iOSLaunchScreenSize: 100 229 | iOSLaunchScreenCustomXibPath: 230 | iOSLaunchScreeniPadType: 0 231 | iOSLaunchScreeniPadImage: {fileID: 0} 232 | iOSLaunchScreeniPadBackgroundColor: 233 | serializedVersion: 2 234 | rgba: 0 235 | iOSLaunchScreeniPadFillPct: 100 236 | iOSLaunchScreeniPadSize: 100 237 | iOSLaunchScreeniPadCustomXibPath: 238 | iOSUseLaunchScreenStoryboard: 0 239 | iOSLaunchScreenCustomStoryboardPath: 240 | iOSDeviceRequirements: [] 241 | iOSURLSchemes: [] 242 | iOSBackgroundModes: 0 243 | iOSMetalForceHardShadows: 0 244 | metalEditorSupport: 1 245 | metalAPIValidation: 1 246 | iOSRenderExtraFrameOnPause: 0 247 | appleDeveloperTeamID: 248 | iOSManualSigningProvisioningProfileID: 249 | tvOSManualSigningProvisioningProfileID: 250 | iOSManualSigningProvisioningProfileType: 0 251 | tvOSManualSigningProvisioningProfileType: 0 252 | appleEnableAutomaticSigning: 0 253 | iOSRequireARKit: 0 254 | iOSAutomaticallyDetectAndAddCapabilities: 1 255 | appleEnableProMotion: 0 256 | clonedFromGUID: 00000000000000000000000000000000 257 | templatePackageId: 258 | templateDefaultScene: 259 | AndroidTargetArchitectures: 1 260 | AndroidSplashScreenScale: 0 261 | androidSplashScreen: {fileID: 0} 262 | AndroidKeystoreName: '{inproject}: ' 263 | AndroidKeyaliasName: 264 | AndroidBuildApkPerCpuArchitecture: 0 265 | AndroidTVCompatibility: 1 266 | AndroidIsGame: 1 267 | AndroidEnableTango: 0 268 | androidEnableBanner: 1 269 | androidUseLowAccuracyLocation: 0 270 | androidUseCustomKeystore: 0 271 | m_AndroidBanners: 272 | - width: 320 273 | height: 180 274 | banner: {fileID: 0} 275 | androidGamepadSupportLevel: 0 276 | AndroidValidateAppBundleSize: 1 277 | AndroidAppBundleSizeToValidate: 150 278 | resolutionDialogBanner: {fileID: 0} 279 | m_BuildTargetIcons: [] 280 | m_BuildTargetPlatformIcons: [] 281 | m_BuildTargetBatching: [] 282 | m_BuildTargetGraphicsAPIs: [] 283 | m_BuildTargetVRSettings: [] 284 | openGLRequireES31: 0 285 | openGLRequireES31AEP: 0 286 | openGLRequireES32: 0 287 | vuforiaEnabled: 0 288 | m_TemplateCustomTags: {} 289 | mobileMTRendering: 290 | Android: 1 291 | iPhone: 1 292 | tvOS: 1 293 | m_BuildTargetGroupLightmapEncodingQuality: [] 294 | m_BuildTargetGroupLightmapSettings: [] 295 | playModeTestRunnerEnabled: 0 296 | runPlayModeTestAsEditModeTest: 0 297 | actionOnDotNetUnhandledException: 1 298 | enableInternalProfiler: 0 299 | logObjCUncaughtExceptions: 1 300 | enableCrashReportAPI: 0 301 | cameraUsageDescription: 302 | locationUsageDescription: 303 | microphoneUsageDescription: 304 | switchNetLibKey: 305 | switchSocketMemoryPoolSize: 6144 306 | switchSocketAllocatorPoolSize: 128 307 | switchSocketConcurrencyLimit: 14 308 | switchScreenResolutionBehavior: 2 309 | switchUseCPUProfiler: 0 310 | switchApplicationID: 0x01004b9000490000 311 | switchNSODependencies: 312 | switchTitleNames_0: 313 | switchTitleNames_1: 314 | switchTitleNames_2: 315 | switchTitleNames_3: 316 | switchTitleNames_4: 317 | switchTitleNames_5: 318 | switchTitleNames_6: 319 | switchTitleNames_7: 320 | switchTitleNames_8: 321 | switchTitleNames_9: 322 | switchTitleNames_10: 323 | switchTitleNames_11: 324 | switchTitleNames_12: 325 | switchTitleNames_13: 326 | switchTitleNames_14: 327 | switchPublisherNames_0: 328 | switchPublisherNames_1: 329 | switchPublisherNames_2: 330 | switchPublisherNames_3: 331 | switchPublisherNames_4: 332 | switchPublisherNames_5: 333 | switchPublisherNames_6: 334 | switchPublisherNames_7: 335 | switchPublisherNames_8: 336 | switchPublisherNames_9: 337 | switchPublisherNames_10: 338 | switchPublisherNames_11: 339 | switchPublisherNames_12: 340 | switchPublisherNames_13: 341 | switchPublisherNames_14: 342 | switchIcons_0: {fileID: 0} 343 | switchIcons_1: {fileID: 0} 344 | switchIcons_2: {fileID: 0} 345 | switchIcons_3: {fileID: 0} 346 | switchIcons_4: {fileID: 0} 347 | switchIcons_5: {fileID: 0} 348 | switchIcons_6: {fileID: 0} 349 | switchIcons_7: {fileID: 0} 350 | switchIcons_8: {fileID: 0} 351 | switchIcons_9: {fileID: 0} 352 | switchIcons_10: {fileID: 0} 353 | switchIcons_11: {fileID: 0} 354 | switchIcons_12: {fileID: 0} 355 | switchIcons_13: {fileID: 0} 356 | switchIcons_14: {fileID: 0} 357 | switchSmallIcons_0: {fileID: 0} 358 | switchSmallIcons_1: {fileID: 0} 359 | switchSmallIcons_2: {fileID: 0} 360 | switchSmallIcons_3: {fileID: 0} 361 | switchSmallIcons_4: {fileID: 0} 362 | switchSmallIcons_5: {fileID: 0} 363 | switchSmallIcons_6: {fileID: 0} 364 | switchSmallIcons_7: {fileID: 0} 365 | switchSmallIcons_8: {fileID: 0} 366 | switchSmallIcons_9: {fileID: 0} 367 | switchSmallIcons_10: {fileID: 0} 368 | switchSmallIcons_11: {fileID: 0} 369 | switchSmallIcons_12: {fileID: 0} 370 | switchSmallIcons_13: {fileID: 0} 371 | switchSmallIcons_14: {fileID: 0} 372 | switchManualHTML: 373 | switchAccessibleURLs: 374 | switchLegalInformation: 375 | switchMainThreadStackSize: 1048576 376 | switchPresenceGroupId: 377 | switchLogoHandling: 0 378 | switchReleaseVersion: 0 379 | switchDisplayVersion: 1.0.0 380 | switchStartupUserAccount: 0 381 | switchTouchScreenUsage: 0 382 | switchSupportedLanguagesMask: 0 383 | switchLogoType: 0 384 | switchApplicationErrorCodeCategory: 385 | switchUserAccountSaveDataSize: 0 386 | switchUserAccountSaveDataJournalSize: 0 387 | switchApplicationAttribute: 0 388 | switchCardSpecSize: -1 389 | switchCardSpecClock: -1 390 | switchRatingsMask: 0 391 | switchRatingsInt_0: 0 392 | switchRatingsInt_1: 0 393 | switchRatingsInt_2: 0 394 | switchRatingsInt_3: 0 395 | switchRatingsInt_4: 0 396 | switchRatingsInt_5: 0 397 | switchRatingsInt_6: 0 398 | switchRatingsInt_7: 0 399 | switchRatingsInt_8: 0 400 | switchRatingsInt_9: 0 401 | switchRatingsInt_10: 0 402 | switchRatingsInt_11: 0 403 | switchRatingsInt_12: 0 404 | switchLocalCommunicationIds_0: 405 | switchLocalCommunicationIds_1: 406 | switchLocalCommunicationIds_2: 407 | switchLocalCommunicationIds_3: 408 | switchLocalCommunicationIds_4: 409 | switchLocalCommunicationIds_5: 410 | switchLocalCommunicationIds_6: 411 | switchLocalCommunicationIds_7: 412 | switchParentalControl: 0 413 | switchAllowsScreenshot: 1 414 | switchAllowsVideoCapturing: 1 415 | switchAllowsRuntimeAddOnContentInstall: 0 416 | switchDataLossConfirmation: 0 417 | switchUserAccountLockEnabled: 0 418 | switchSystemResourceMemory: 16777216 419 | switchSupportedNpadStyles: 3 420 | switchNativeFsCacheSize: 32 421 | switchIsHoldTypeHorizontal: 0 422 | switchSupportedNpadCount: 8 423 | switchSocketConfigEnabled: 0 424 | switchTcpInitialSendBufferSize: 32 425 | switchTcpInitialReceiveBufferSize: 64 426 | switchTcpAutoSendBufferSizeMax: 256 427 | switchTcpAutoReceiveBufferSizeMax: 256 428 | switchUdpSendBufferSize: 9 429 | switchUdpReceiveBufferSize: 42 430 | switchSocketBufferEfficiency: 4 431 | switchSocketInitializeEnabled: 1 432 | switchNetworkInterfaceManagerInitializeEnabled: 1 433 | switchPlayerConnectionEnabled: 1 434 | ps4NPAgeRating: 12 435 | ps4NPTitleSecret: 436 | ps4NPTrophyPackPath: 437 | ps4ParentalLevel: 11 438 | ps4ContentID: ED1633-NPXX51362_00-0000000000000000 439 | ps4Category: 0 440 | ps4MasterVersion: 01.00 441 | ps4AppVersion: 01.00 442 | ps4AppType: 0 443 | ps4ParamSfxPath: 444 | ps4VideoOutPixelFormat: 0 445 | ps4VideoOutInitialWidth: 1920 446 | ps4VideoOutBaseModeInitialWidth: 1920 447 | ps4VideoOutReprojectionRate: 60 448 | ps4PronunciationXMLPath: 449 | ps4PronunciationSIGPath: 450 | ps4BackgroundImagePath: 451 | ps4StartupImagePath: 452 | ps4StartupImagesFolder: 453 | ps4IconImagesFolder: 454 | ps4SaveDataImagePath: 455 | ps4SdkOverride: 456 | ps4BGMPath: 457 | ps4ShareFilePath: 458 | ps4ShareOverlayImagePath: 459 | ps4PrivacyGuardImagePath: 460 | ps4NPtitleDatPath: 461 | ps4RemotePlayKeyAssignment: -1 462 | ps4RemotePlayKeyMappingDir: 463 | ps4PlayTogetherPlayerCount: 0 464 | ps4EnterButtonAssignment: 2 465 | ps4ApplicationParam1: 0 466 | ps4ApplicationParam2: 0 467 | ps4ApplicationParam3: 0 468 | ps4ApplicationParam4: 0 469 | ps4DownloadDataSize: 0 470 | ps4GarlicHeapSize: 2048 471 | ps4ProGarlicHeapSize: 2560 472 | playerPrefsMaxSize: 32768 473 | ps4Passcode: PN2qmWqBlQ9wQj99nsQzldVI5ZuGXbEW 474 | ps4pnSessions: 1 475 | ps4pnPresence: 1 476 | ps4pnFriends: 1 477 | ps4pnGameCustomData: 1 478 | playerPrefsSupport: 0 479 | enableApplicationExit: 0 480 | resetTempFolder: 1 481 | restrictedAudioUsageRights: 0 482 | ps4UseResolutionFallback: 0 483 | ps4ReprojectionSupport: 0 484 | ps4UseAudio3dBackend: 0 485 | ps4SocialScreenEnabled: 0 486 | ps4ScriptOptimizationLevel: 2 487 | ps4Audio3dVirtualSpeakerCount: 14 488 | ps4attribCpuUsage: 0 489 | ps4PatchPkgPath: 490 | ps4PatchLatestPkgPath: 491 | ps4PatchChangeinfoPath: 492 | ps4PatchDayOne: 0 493 | ps4attribUserManagement: 0 494 | ps4attribMoveSupport: 0 495 | ps4attrib3DSupport: 0 496 | ps4attribShareSupport: 0 497 | ps4attribExclusiveVR: 0 498 | ps4disableAutoHideSplash: 0 499 | ps4videoRecordingFeaturesUsed: 0 500 | ps4contentSearchFeaturesUsed: 0 501 | ps4attribEyeToEyeDistanceSettingVR: 0 502 | ps4IncludedModules: [] 503 | monoEnv: 504 | splashScreenBackgroundSourceLandscape: {fileID: 0} 505 | splashScreenBackgroundSourcePortrait: {fileID: 0} 506 | blurSplashScreenBackground: 1 507 | spritePackerPolicy: 508 | webGLMemorySize: 256 509 | webGLExceptionSupport: 1 510 | webGLNameFilesAsHashes: 0 511 | webGLDataCaching: 1 512 | webGLDebugSymbols: 0 513 | webGLEmscriptenArgs: 514 | webGLModulesDirectory: 515 | webGLTemplate: APPLICATION:Default 516 | webGLAnalyzeBuildSize: 0 517 | webGLUseEmbeddedResources: 0 518 | webGLCompressionFormat: 1 519 | webGLLinkerTarget: 1 520 | webGLThreadsSupport: 0 521 | webGLWasmStreaming: 0 522 | scriptingDefineSymbols: {} 523 | platformArchitecture: {} 524 | scriptingBackend: {} 525 | il2cppCompilerConfiguration: {} 526 | managedStrippingLevel: {} 527 | incrementalIl2cppBuild: {} 528 | allowUnsafeCode: 0 529 | additionalIl2CppArgs: 530 | scriptingRuntimeVersion: 1 531 | gcIncremental: 0 532 | gcWBarrierValidation: 0 533 | apiCompatibilityLevelPerPlatform: {} 534 | m_RenderingPath: 1 535 | m_MobileRenderingPath: 1 536 | metroPackageName: toriki 537 | metroPackageVersion: 538 | metroCertificatePath: 539 | metroCertificatePassword: 540 | metroCertificateSubject: 541 | metroCertificateIssuer: 542 | metroCertificateNotAfter: 0000000000000000 543 | metroApplicationDescription: toriki 544 | wsaImages: {} 545 | metroTileShortName: 546 | metroTileShowName: 0 547 | metroMediumTileShowName: 0 548 | metroLargeTileShowName: 0 549 | metroWideTileShowName: 0 550 | metroSupportStreamingInstall: 0 551 | metroLastRequiredScene: 0 552 | metroDefaultTileSize: 1 553 | metroTileForegroundText: 2 554 | metroTileBackgroundColor: {r: 0.13333334, g: 0.17254902, b: 0.21568628, a: 0} 555 | metroSplashScreenBackgroundColor: {r: 0.12941177, g: 0.17254902, b: 0.21568628, 556 | a: 1} 557 | metroSplashScreenUseBackgroundColor: 0 558 | platformCapabilities: {} 559 | metroTargetDeviceFamilies: {} 560 | metroFTAName: 561 | metroFTAFileTypes: [] 562 | metroProtocolName: 563 | XboxOneProductId: 564 | XboxOneUpdateKey: 565 | XboxOneSandboxId: 566 | XboxOneContentId: 567 | XboxOneTitleId: 568 | XboxOneSCId: 569 | XboxOneGameOsOverridePath: 570 | XboxOnePackagingOverridePath: 571 | XboxOneAppManifestOverridePath: 572 | XboxOneVersion: 1.0.0.0 573 | XboxOnePackageEncryption: 0 574 | XboxOnePackageUpdateGranularity: 2 575 | XboxOneDescription: 576 | XboxOneLanguage: 577 | - enus 578 | XboxOneCapability: [] 579 | XboxOneGameRating: {} 580 | XboxOneIsContentPackage: 0 581 | XboxOneEnableGPUVariability: 1 582 | XboxOneSockets: {} 583 | XboxOneSplashScreen: {fileID: 0} 584 | XboxOneAllowedProductIds: [] 585 | XboxOnePersistentLocalStorageSize: 0 586 | XboxOneXTitleMemory: 8 587 | xboxOneScriptCompiler: 1 588 | XboxOneOverrideIdentityName: 589 | vrEditorSettings: 590 | daydream: 591 | daydreamIconForeground: {fileID: 0} 592 | daydreamIconBackground: {fileID: 0} 593 | cloudServicesEnabled: {} 594 | luminIcon: 595 | m_Name: 596 | m_ModelFolderPath: 597 | m_PortalFolderPath: 598 | luminCert: 599 | m_CertPath: 600 | m_SignPackage: 1 601 | luminIsChannelApp: 0 602 | luminVersion: 603 | m_VersionCode: 1 604 | m_VersionName: 605 | facebookSdkVersion: 7.9.4 606 | facebookAppId: 607 | facebookCookies: 1 608 | facebookLogging: 1 609 | facebookStatus: 1 610 | facebookXfbml: 0 611 | facebookFrictionlessRequests: 1 612 | apiCompatibilityLevel: 6 613 | cloudProjectId: 614 | framebufferDepthMemorylessMode: 0 615 | projectName: 616 | organizationId: 617 | cloudEnabled: 0 618 | enableNativePlatformBackendsForNewInputSystem: 0 619 | disableOldInputManagerSupport: 0 620 | legacyClampBlendShapeWeights: 1 621 | -------------------------------------------------------------------------------- /ProjectSettings/ProjectVersion.txt: -------------------------------------------------------------------------------- 1 | m_EditorVersion: 2020.3.12f1 2 | m_EditorVersionWithRevision: 2020.3.12f1 (b3b2c6512326) 3 | -------------------------------------------------------------------------------- /ProjectSettings/QualitySettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!47 &1 4 | QualitySettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 5 7 | m_CurrentQuality: 5 8 | m_QualitySettings: 9 | - serializedVersion: 2 10 | name: Very Low 11 | pixelLightCount: 0 12 | shadows: 0 13 | shadowResolution: 0 14 | shadowProjection: 1 15 | shadowCascades: 1 16 | shadowDistance: 15 17 | shadowNearPlaneOffset: 3 18 | shadowCascade2Split: 0.33333334 19 | shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} 20 | shadowmaskMode: 0 21 | blendWeights: 1 22 | textureQuality: 1 23 | anisotropicTextures: 0 24 | antiAliasing: 0 25 | softParticles: 0 26 | softVegetation: 0 27 | realtimeReflectionProbes: 0 28 | billboardsFaceCameraPosition: 0 29 | vSyncCount: 0 30 | lodBias: 0.3 31 | maximumLODLevel: 0 32 | streamingMipmapsActive: 0 33 | streamingMipmapsAddAllCameras: 1 34 | streamingMipmapsMemoryBudget: 512 35 | streamingMipmapsRenderersPerFrame: 512 36 | streamingMipmapsMaxLevelReduction: 2 37 | streamingMipmapsMaxFileIORequests: 1024 38 | particleRaycastBudget: 4 39 | asyncUploadTimeSlice: 2 40 | asyncUploadBufferSize: 4 41 | resolutionScalingFixedDPIFactor: 1 42 | excludedTargetPlatforms: [] 43 | - serializedVersion: 2 44 | name: Low 45 | pixelLightCount: 0 46 | shadows: 0 47 | shadowResolution: 0 48 | shadowProjection: 1 49 | shadowCascades: 1 50 | shadowDistance: 20 51 | shadowNearPlaneOffset: 3 52 | shadowCascade2Split: 0.33333334 53 | shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} 54 | shadowmaskMode: 0 55 | blendWeights: 2 56 | textureQuality: 0 57 | anisotropicTextures: 0 58 | antiAliasing: 0 59 | softParticles: 0 60 | softVegetation: 0 61 | realtimeReflectionProbes: 0 62 | billboardsFaceCameraPosition: 0 63 | vSyncCount: 0 64 | lodBias: 0.4 65 | maximumLODLevel: 0 66 | streamingMipmapsActive: 0 67 | streamingMipmapsAddAllCameras: 1 68 | streamingMipmapsMemoryBudget: 512 69 | streamingMipmapsRenderersPerFrame: 512 70 | streamingMipmapsMaxLevelReduction: 2 71 | streamingMipmapsMaxFileIORequests: 1024 72 | particleRaycastBudget: 16 73 | asyncUploadTimeSlice: 2 74 | asyncUploadBufferSize: 4 75 | resolutionScalingFixedDPIFactor: 1 76 | excludedTargetPlatforms: [] 77 | - serializedVersion: 2 78 | name: Medium 79 | pixelLightCount: 1 80 | shadows: 1 81 | shadowResolution: 0 82 | shadowProjection: 1 83 | shadowCascades: 1 84 | shadowDistance: 20 85 | shadowNearPlaneOffset: 3 86 | shadowCascade2Split: 0.33333334 87 | shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} 88 | shadowmaskMode: 0 89 | blendWeights: 2 90 | textureQuality: 0 91 | anisotropicTextures: 1 92 | antiAliasing: 0 93 | softParticles: 0 94 | softVegetation: 0 95 | realtimeReflectionProbes: 0 96 | billboardsFaceCameraPosition: 0 97 | vSyncCount: 1 98 | lodBias: 0.7 99 | maximumLODLevel: 0 100 | streamingMipmapsActive: 0 101 | streamingMipmapsAddAllCameras: 1 102 | streamingMipmapsMemoryBudget: 512 103 | streamingMipmapsRenderersPerFrame: 512 104 | streamingMipmapsMaxLevelReduction: 2 105 | streamingMipmapsMaxFileIORequests: 1024 106 | particleRaycastBudget: 64 107 | asyncUploadTimeSlice: 2 108 | asyncUploadBufferSize: 4 109 | resolutionScalingFixedDPIFactor: 1 110 | excludedTargetPlatforms: [] 111 | - serializedVersion: 2 112 | name: High 113 | pixelLightCount: 2 114 | shadows: 2 115 | shadowResolution: 1 116 | shadowProjection: 1 117 | shadowCascades: 2 118 | shadowDistance: 40 119 | shadowNearPlaneOffset: 3 120 | shadowCascade2Split: 0.33333334 121 | shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} 122 | shadowmaskMode: 1 123 | blendWeights: 2 124 | textureQuality: 0 125 | anisotropicTextures: 1 126 | antiAliasing: 0 127 | softParticles: 0 128 | softVegetation: 1 129 | realtimeReflectionProbes: 1 130 | billboardsFaceCameraPosition: 1 131 | vSyncCount: 1 132 | lodBias: 1 133 | maximumLODLevel: 0 134 | streamingMipmapsActive: 0 135 | streamingMipmapsAddAllCameras: 1 136 | streamingMipmapsMemoryBudget: 512 137 | streamingMipmapsRenderersPerFrame: 512 138 | streamingMipmapsMaxLevelReduction: 2 139 | streamingMipmapsMaxFileIORequests: 1024 140 | particleRaycastBudget: 256 141 | asyncUploadTimeSlice: 2 142 | asyncUploadBufferSize: 4 143 | resolutionScalingFixedDPIFactor: 1 144 | excludedTargetPlatforms: [] 145 | - serializedVersion: 2 146 | name: Very High 147 | pixelLightCount: 3 148 | shadows: 2 149 | shadowResolution: 2 150 | shadowProjection: 1 151 | shadowCascades: 2 152 | shadowDistance: 70 153 | shadowNearPlaneOffset: 3 154 | shadowCascade2Split: 0.33333334 155 | shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} 156 | shadowmaskMode: 1 157 | blendWeights: 4 158 | textureQuality: 0 159 | anisotropicTextures: 2 160 | antiAliasing: 2 161 | softParticles: 1 162 | softVegetation: 1 163 | realtimeReflectionProbes: 1 164 | billboardsFaceCameraPosition: 1 165 | vSyncCount: 1 166 | lodBias: 1.5 167 | maximumLODLevel: 0 168 | streamingMipmapsActive: 0 169 | streamingMipmapsAddAllCameras: 1 170 | streamingMipmapsMemoryBudget: 512 171 | streamingMipmapsRenderersPerFrame: 512 172 | streamingMipmapsMaxLevelReduction: 2 173 | streamingMipmapsMaxFileIORequests: 1024 174 | particleRaycastBudget: 1024 175 | asyncUploadTimeSlice: 2 176 | asyncUploadBufferSize: 4 177 | resolutionScalingFixedDPIFactor: 1 178 | excludedTargetPlatforms: [] 179 | - serializedVersion: 2 180 | name: Ultra 181 | pixelLightCount: 4 182 | shadows: 2 183 | shadowResolution: 2 184 | shadowProjection: 1 185 | shadowCascades: 4 186 | shadowDistance: 150 187 | shadowNearPlaneOffset: 3 188 | shadowCascade2Split: 0.33333334 189 | shadowCascade4Split: {x: 0.06666667, y: 0.2, z: 0.46666667} 190 | shadowmaskMode: 1 191 | blendWeights: 4 192 | textureQuality: 0 193 | anisotropicTextures: 2 194 | antiAliasing: 2 195 | softParticles: 1 196 | softVegetation: 1 197 | realtimeReflectionProbes: 1 198 | billboardsFaceCameraPosition: 1 199 | vSyncCount: 1 200 | lodBias: 2 201 | maximumLODLevel: 0 202 | streamingMipmapsActive: 0 203 | streamingMipmapsAddAllCameras: 1 204 | streamingMipmapsMemoryBudget: 512 205 | streamingMipmapsRenderersPerFrame: 512 206 | streamingMipmapsMaxLevelReduction: 2 207 | streamingMipmapsMaxFileIORequests: 1024 208 | particleRaycastBudget: 4096 209 | asyncUploadTimeSlice: 2 210 | asyncUploadBufferSize: 4 211 | resolutionScalingFixedDPIFactor: 1 212 | excludedTargetPlatforms: [] 213 | m_PerPlatformDefaultQuality: 214 | Android: 2 215 | Nintendo 3DS: 5 216 | Nintendo Switch: 5 217 | PS4: 5 218 | PSP2: 2 219 | Standalone: 5 220 | WebGL: 3 221 | Windows Store Apps: 5 222 | XboxOne: 5 223 | iPhone: 2 224 | tvOS: 2 225 | -------------------------------------------------------------------------------- /ProjectSettings/TagManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!78 &1 4 | TagManager: 5 | serializedVersion: 2 6 | tags: [] 7 | layers: 8 | - Default 9 | - TransparentFX 10 | - Ignore Raycast 11 | - 12 | - Water 13 | - UI 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 | m_SortingLayers: 41 | - name: Default 42 | uniqueID: 0 43 | locked: 0 44 | -------------------------------------------------------------------------------- /ProjectSettings/TimeManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!5 &1 4 | TimeManager: 5 | m_ObjectHideFlags: 0 6 | Fixed Timestep: 0.02 7 | Maximum Allowed Timestep: 0.33333334 8 | m_TimeScale: 1 9 | Maximum Particle Timestep: 0.03 10 | -------------------------------------------------------------------------------- /ProjectSettings/UnityConnectSettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!310 &1 4 | UnityConnectSettings: 5 | m_ObjectHideFlags: 0 6 | m_Enabled: 1 7 | m_TestMode: 0 8 | m_TestEventUrl: 9 | m_TestConfigUrl: 10 | m_TestInitMode: 0 11 | CrashReportingSettings: 12 | m_EventUrl: https://perf-events.cloud.unity3d.com/api/events/crashes 13 | m_NativeEventUrl: https://perf-events.cloud.unity3d.com/symbolicate 14 | m_Enabled: 0 15 | m_CaptureEditorExceptions: 1 16 | UnityPurchasingSettings: 17 | m_Enabled: 0 18 | m_TestMode: 0 19 | UnityAnalyticsSettings: 20 | m_Enabled: 0 21 | m_InitializeOnStartup: 1 22 | m_TestMode: 0 23 | m_TestEventUrl: 24 | m_TestConfigUrl: 25 | UnityAdsSettings: 26 | m_Enabled: 0 27 | m_InitializeOnStartup: 1 28 | m_TestMode: 0 29 | m_IosGameId: 30 | m_AndroidGameId: 31 | m_GameIds: {} 32 | m_GameId: 33 | PerformanceReportingSettings: 34 | m_Enabled: 0 35 | -------------------------------------------------------------------------------- /ProjectSettings/VFXManager.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!937362698 &1 4 | VFXManager: 5 | m_ObjectHideFlags: 0 6 | m_IndirectShader: {fileID: 0} 7 | m_CopyBufferShader: {fileID: 0} 8 | m_SortShader: {fileID: 0} 9 | m_RenderPipeSettingsPath: 10 | m_FixedTimeStep: 0.016666668 11 | m_MaxDeltaTime: 0.05 12 | -------------------------------------------------------------------------------- /ProjectSettings/XRSettings.asset: -------------------------------------------------------------------------------- 1 | { 2 | "m_SettingKeys": [ 3 | "VR Device Disabled", 4 | "VR Device User Alert" 5 | ], 6 | "m_SettingValues": [ 7 | "False", 8 | "False" 9 | ] 10 | } -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # Toriki 2 | 3 | Tori(the Twitter Bird in Japanese) kit -> Toriki. 4 | 5 | Ultra lightweight Twitter tool for Unity. supports the SingleSignOn with Twitter app and Twitter API invocation. 6 | 7 | Currently, Toriki requires Twitter application in supported platflorms. 8 | 9 | 10 | ## supported platforms 11 | 12 | * iOS 13 | * Android 14 | * WebGL(under development.) 15 | 16 | with Unity 2018.x or later. 17 | 18 | 19 | ## installation 20 | Use UnityPackage in [releases](https://github.com/sassembla/toriki/releases). 21 | 22 | 23 | ## usage 24 | 25 | ### 1. setup Twitter ConsumerKey and ConsumerSecret 26 | 27 | ```csharp 28 | static TwitterSettings() 29 | { 30 | ConsumerKey = string.Empty;// change here. 31 | ConsumerSecret = string.Empty;// change here. 32 | 33 | if (string.IsNullOrEmpty(ConsumerKey)) 34 | { 35 | Debug.Log("ConsumerKey is null. please write some code for setting ConsumerKey."); 36 | } 37 | 38 | if (string.IsNullOrEmpty(ConsumerSecret)) 39 | { 40 | Debug.Log("ConsumerSecret is null. please write some code for setting ConsumerSecret."); 41 | } 42 | } 43 | ``` 44 | 45 | ### 2. Log in to Twitter 46 | 47 | get AccessToken & AccessTokenSecret from Twitter. 48 | 49 | ```csharp 50 | TwitterAPI.InitWithLogin( 51 | (nickname, token, secret) => 52 | { 53 | // nickname, accesstoken, accesstokensecret is available. 54 | // also TwitterAPI is ready now. 55 | }, 56 | (errorCode, message) => 57 | { 58 | // failed to log in to Twitter. 59 | Debug.Log("login error:" + errorCode + " message:" + message); 60 | } 61 | ``` 62 | 63 | or 64 | 65 | log in with stored AccessToken & AccessTokenSecret. 66 | 67 | ```csharp 68 | TwitterAPI.InitWithToken("ACCESS_TOKEN", "ACCESS_SECRET"); 69 | ``` 70 | 71 | 72 | ### 3. Use Twitter API 73 | 74 | after log in to Twitter, you can use Twitter APIs. 75 | 76 | ```csharp 77 | // tweet API example. 78 | TwitterAPI.Post( 79 | "https://api.twitter.com/1.1/statuses/update.json", 80 | new SortedDictionary 81 | { 82 | {"status", "#LoveToriki. "} 83 | }, 84 | result => 85 | { 86 | Debug.Log("update result:" + result); 87 | }, 88 | (code, errors) => 89 | { 90 | Debug.Log("update code:" + code); 91 | } 92 | ); 93 | ``` 94 | 95 | ## license 96 | [license](https://github.com/sassembla/toriki/blob/master/LICENSE) 97 | 98 | -------------------------------------------------------------------------------- /Toriki.unitypackage: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/sassembla/toriki/6cdbe4c014b6ad85bf35a915e859ad70d56631ae/Toriki.unitypackage -------------------------------------------------------------------------------- /UserSettings/EditorUserSettings.asset: -------------------------------------------------------------------------------- 1 | %YAML 1.1 2 | %TAG !u! tag:unity3d.com,2011: 3 | --- !u!162 &1 4 | EditorUserSettings: 5 | m_ObjectHideFlags: 0 6 | serializedVersion: 4 7 | m_ConfigSettings: 8 | vcSharedLogLevel: 9 | value: 0d5e400f0650 10 | flags: 0 11 | m_VCAutomaticAdd: 1 12 | m_VCDebugCom: 0 13 | m_VCDebugCmd: 0 14 | m_VCDebugOut: 0 15 | m_SemanticMergeMode: 2 16 | m_VCShowFailedCheckout: 1 17 | m_VCOverwriteFailedCheckoutAssets: 1 18 | m_VCProjectOverlayIcons: 1 19 | m_VCHierarchyOverlayIcons: 1 20 | m_VCOtherOverlayIcons: 1 21 | m_VCAllowAsyncUpdate: 1 22 | -------------------------------------------------------------------------------- /toriki.sln: -------------------------------------------------------------------------------- 1 |  2 | Microsoft Visual Studio Solution File, Format Version 11.00 3 | # Visual Studio 2010 4 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Assembly-CSharp", "Assembly-CSharp.csproj", "{766ED6AC-BC8A-9CF1-A5BA-F54F6B7E5788}" 5 | EndProject 6 | Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "Assembly-CSharp-Editor", "Assembly-CSharp-Editor.csproj", "{2498AC1A-08D3-2FA2-CA4A-72130C18CBCD}" 7 | EndProject 8 | Global 9 | GlobalSection(SolutionConfigurationPlatforms) = preSolution 10 | Debug|Any CPU = Debug|Any CPU 11 | Release|Any CPU = Release|Any CPU 12 | EndGlobalSection 13 | GlobalSection(ProjectConfigurationPlatforms) = postSolution 14 | {766ED6AC-BC8A-9CF1-A5BA-F54F6B7E5788}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 15 | {766ED6AC-BC8A-9CF1-A5BA-F54F6B7E5788}.Debug|Any CPU.Build.0 = Debug|Any CPU 16 | {766ED6AC-BC8A-9CF1-A5BA-F54F6B7E5788}.Release|Any CPU.ActiveCfg = Release|Any CPU 17 | {766ED6AC-BC8A-9CF1-A5BA-F54F6B7E5788}.Release|Any CPU.Build.0 = Release|Any CPU 18 | {2498AC1A-08D3-2FA2-CA4A-72130C18CBCD}.Debug|Any CPU.ActiveCfg = Debug|Any CPU 19 | {2498AC1A-08D3-2FA2-CA4A-72130C18CBCD}.Debug|Any CPU.Build.0 = Debug|Any CPU 20 | {2498AC1A-08D3-2FA2-CA4A-72130C18CBCD}.Release|Any CPU.ActiveCfg = Release|Any CPU 21 | {2498AC1A-08D3-2FA2-CA4A-72130C18CBCD}.Release|Any CPU.Build.0 = Release|Any CPU 22 | EndGlobalSection 23 | GlobalSection(SolutionProperties) = preSolution 24 | HideSolutionNode = FALSE 25 | EndGlobalSection 26 | GlobalSection(MonoDevelopProperties) = preSolution 27 | StartupItem = Assembly-CSharp.csproj 28 | EndGlobalSection 29 | EndGlobal 30 | --------------------------------------------------------------------------------