├── .gitignore ├── CHANGELOG.txt ├── DefaultIcon-ios.png ├── DefaultIcon.png ├── LICENSE ├── MarketplaceArtwork.png ├── README.md ├── app ├── README.md ├── alloy.js ├── assets │ ├── Matrices.txt │ ├── Prime_Numbers.txt │ ├── a.txt │ ├── android │ │ ├── appicon.png │ │ ├── default.png │ │ └── images │ │ │ ├── res-long-land-hdpi │ │ │ └── default.png │ │ │ ├── res-long-land-ldpi │ │ │ └── default.png │ │ │ ├── res-long-land-mdpi │ │ │ └── default.png │ │ │ ├── res-long-port-hdpi │ │ │ └── default.png │ │ │ ├── res-long-port-ldpi │ │ │ └── default.png │ │ │ ├── res-notlong-land-hdpi │ │ │ └── default.png │ │ │ ├── res-notlong-land-ldpi │ │ │ └── default.png │ │ │ ├── res-notlong-land-mdpi │ │ │ └── default.png │ │ │ ├── res-notlong-port-hdpi │ │ │ └── default.png │ │ │ ├── res-notlong-port-ldpi │ │ │ └── default.png │ │ │ └── res-notlong-port-mdpi │ │ │ └── default.png │ ├── image.jpg │ ├── iphone │ │ ├── Default-568h@2x.png │ │ ├── Default-667h@2x.png │ │ ├── Default-Landscape-736h@3x.png │ │ ├── Default-Landscape.png │ │ ├── Default-Landscape@2x.png │ │ ├── Default-Portrait-736h@3x.png │ │ ├── Default-Portrait.png │ │ ├── Default-Portrait@2x.png │ │ ├── Default.png │ │ └── Default@2x.png │ ├── mobileweb │ │ ├── appicon.png │ │ ├── apple_startup_images │ │ │ ├── Default-Landscape.jpg │ │ │ ├── Default-Landscape.png │ │ │ ├── Default-Portrait.jpg │ │ │ ├── Default-Portrait.png │ │ │ ├── Default.jpg │ │ │ ├── Default.png │ │ │ └── README │ │ └── splash │ │ │ ├── README │ │ │ ├── appc.png │ │ │ ├── splash.css │ │ │ ├── splash.html │ │ │ └── titanium.png │ ├── video.mp4 │ └── word.docx ├── config.json ├── controllers │ ├── index.js │ └── infoWin.js ├── lib │ ├── dropboxAPIv2.js │ └── tidropbox.js ├── styles │ ├── app.tss │ ├── index.tss │ └── infoWin.tss └── views │ ├── index.xml │ └── infoWin.xml ├── dist ├── ti.dropbox-commonjs-1.0.0.zip ├── ti.dropbox-commonjs-1.1.0.zip ├── ti.dropbox-commonjs-1.1.1.zip ├── ti.dropbox-commonjs-1.2.0.zip ├── ti.dropbox-commonjs-1.3.0.zip ├── ti.dropbox-commonjs-2.0.0.zip ├── ti.dropbox-commonjs-3.0.0.zip ├── ti.dropbox-commonjs-4.0.0.zip ├── ti.dropbox-commonjs-4.1.0.zip ├── ti.dropbox-commonjs-5.0.0.zip └── ti.dropbox-commonjs-6.0.0.zip ├── iTunesConnect.png ├── modules ├── android │ └── ti.deeply │ │ └── 3.0.0 │ │ ├── LICENSE │ │ ├── Ti.Deeply.json │ │ ├── documentation │ │ └── index.html │ │ ├── example │ │ └── app.js │ │ ├── m2repository │ │ └── ti │ │ │ └── deeply │ │ │ ├── 3.0.0 │ │ │ ├── deeply-3.0.0.aar │ │ │ ├── deeply-3.0.0.aar.md5 │ │ │ ├── deeply-3.0.0.aar.sha1 │ │ │ ├── deeply-3.0.0.aar.sha256 │ │ │ ├── deeply-3.0.0.aar.sha512 │ │ │ ├── deeply-3.0.0.pom │ │ │ ├── deeply-3.0.0.pom.md5 │ │ │ ├── deeply-3.0.0.pom.sha1 │ │ │ ├── deeply-3.0.0.pom.sha256 │ │ │ └── deeply-3.0.0.pom.sha512 │ │ │ ├── maven-metadata.xml │ │ │ ├── maven-metadata.xml.md5 │ │ │ ├── maven-metadata.xml.sha1 │ │ │ ├── maven-metadata.xml.sha256 │ │ │ └── maven-metadata.xml.sha512 │ │ ├── manifest │ │ └── timodule.xml ├── commonjs │ └── ti.dropbox │ │ └── 6.0.0 │ │ ├── LICENSE │ │ ├── manifest │ │ ├── package.json │ │ └── ti.dropbox.js └── iphone │ └── com.mobmaxime.tiwebview │ └── 0.2 │ ├── LICENSE │ ├── documentation │ └── index.html │ ├── example │ └── app.js │ ├── libcom.mobmaxime.tiwebview.a │ ├── manifest │ └── module.xcconfig ├── package-lock.json ├── package.json ├── plugins └── ti.alloy │ ├── hooks │ ├── alloy.js │ └── deepclean.js │ └── plugin.py └── tiapp.xml /.gitignore: -------------------------------------------------------------------------------- 1 | .DS_Store 2 | Resources 3 | build.log 4 | build 5 | npm-debug.log 6 | tmp 7 | .map 8 | .project 9 | .settings 10 | Thumbs.db 11 | /i18n 12 | /platform 13 | -------------------------------------------------------------------------------- /CHANGELOG.txt: -------------------------------------------------------------------------------- 1 | v. 4.1.0 2 | - New method to retrieve access_token 3 | v. 4.0.0 4 | - New method to retrieve access_token 5 | v. 3.0.0 6 | - files/lock_file_batch 7 | - files/search updated to v2; 8 | - files/search/continue 9 | - files/unlock_file_batch 10 | - files/copy updated to v2 11 | - files/create_folder updated to v2 12 | - files/delete updated to v2 13 | - files/move updated to v2 14 | -------------------------------------------------------------------------------- /DefaultIcon-ios.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/DefaultIcon-ios.png -------------------------------------------------------------------------------- /DefaultIcon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/DefaultIcon.png -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | Copyright 2008-2013 Appcelerator, Inc. 2 | 3 | Licensed under the Apache License, Version 2.0 (the "License"); 4 | you may not use this file except in compliance with the License. 5 | You may obtain a copy of the License at 6 | 7 | http://www.apache.org/licenses/LICENSE-2.0 8 | 9 | (or the full text of the license is below) 10 | 11 | Unless required by applicable law or agreed to in writing, software 12 | distributed under the License is distributed on an "AS IS" BASIS, 13 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14 | See the License for the specific language governing permissions and 15 | limitations under the License. 16 | 17 | 18 | 19 | Apache License 20 | Version 2.0, January 2004 21 | http://www.apache.org/licenses/ 22 | 23 | TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION 24 | 25 | 1. Definitions. 26 | 27 | "License" shall mean the terms and conditions for use, reproduction, 28 | and distribution as defined by Sections 1 through 9 of this document. 29 | 30 | "Licensor" shall mean the copyright owner or entity authorized by 31 | the copyright owner that is granting the License. 32 | 33 | "Legal Entity" shall mean the union of the acting entity and all 34 | other entities that control, are controlled by, or are under common 35 | control with that entity. For the purposes of this definition, 36 | "control" means (i) the power, direct or indirect, to cause the 37 | direction or management of such entity, whether by contract or 38 | otherwise, or (ii) ownership of fifty percent (50%) or more of the 39 | outstanding shares, or (iii) beneficial ownership of such entity. 40 | 41 | "You" (or "Your") shall mean an individual or Legal Entity 42 | exercising permissions granted by this License. 43 | 44 | "Source" form shall mean the preferred form for making modifications, 45 | including but not limited to software source code, documentation 46 | source, and configuration files. 47 | 48 | "Object" form shall mean any form resulting from mechanical 49 | transformation or translation of a Source form, including but 50 | not limited to compiled object code, generated documentation, 51 | and conversions to other media types. 52 | 53 | "Work" shall mean the work of authorship, whether in Source or 54 | Object form, made available under the License, as indicated by a 55 | copyright notice that is included in or attached to the work 56 | (an example is provided in the Appendix below). 57 | 58 | "Derivative Works" shall mean any work, whether in Source or Object 59 | form, that is based on (or derived from) the Work and for which the 60 | editorial revisions, annotations, elaborations, or other modifications 61 | represent, as a whole, an original work of authorship. For the purposes 62 | of this License, Derivative Works shall not include works that remain 63 | separable from, or merely link (or bind by name) to the interfaces of, 64 | the Work and Derivative Works thereof. 65 | 66 | "Contribution" shall mean any work of authorship, including 67 | the original version of the Work and any modifications or additions 68 | to that Work or Derivative Works thereof, that is intentionally 69 | submitted to Licensor for inclusion in the Work by the copyright owner 70 | or by an individual or Legal Entity authorized to submit on behalf of 71 | the copyright owner. For the purposes of this definition, "submitted" 72 | means any form of electronic, verbal, or written communication sent 73 | to the Licensor or its representatives, including but not limited to 74 | communication on electronic mailing lists, source code control systems, 75 | and issue tracking systems that are managed by, or on behalf of, the 76 | Licensor for the purpose of discussing and improving the Work, but 77 | excluding communication that is conspicuously marked or otherwise 78 | designated in writing by the copyright owner as "Not a Contribution." 79 | 80 | "Contributor" shall mean Licensor and any individual or Legal Entity 81 | on behalf of whom a Contribution has been received by Licensor and 82 | subsequently incorporated within the Work. 83 | 84 | 2. Grant of Copyright License. Subject to the terms and conditions of 85 | this License, each Contributor hereby grants to You a perpetual, 86 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 87 | copyright license to reproduce, prepare Derivative Works of, 88 | publicly display, publicly perform, sublicense, and distribute the 89 | Work and such Derivative Works in Source or Object form. 90 | 91 | 3. Grant of Patent License. Subject to the terms and conditions of 92 | this License, each Contributor hereby grants to You a perpetual, 93 | worldwide, non-exclusive, no-charge, royalty-free, irrevocable 94 | (except as stated in this section) patent license to make, have made, 95 | use, offer to sell, sell, import, and otherwise transfer the Work, 96 | where such license applies only to those patent claims licensable 97 | by such Contributor that are necessarily infringed by their 98 | Contribution(s) alone or by combination of their Contribution(s) 99 | with the Work to which such Contribution(s) was submitted. If You 100 | institute patent litigation against any entity (including a 101 | cross-claim or counterclaim in a lawsuit) alleging that the Work 102 | or a Contribution incorporated within the Work constitutes direct 103 | or contributory patent infringement, then any patent licenses 104 | granted to You under this License for that Work shall terminate 105 | as of the date such litigation is filed. 106 | 107 | 4. Redistribution. You may reproduce and distribute copies of the 108 | Work or Derivative Works thereof in any medium, with or without 109 | modifications, and in Source or Object form, provided that You 110 | meet the following conditions: 111 | 112 | (a) You must give any other recipients of the Work or 113 | Derivative Works a copy of this License; and 114 | 115 | (b) You must cause any modified files to carry prominent notices 116 | stating that You changed the files; and 117 | 118 | (c) You must retain, in the Source form of any Derivative Works 119 | that You distribute, all copyright, patent, trademark, and 120 | attribution notices from the Source form of the Work, 121 | excluding those notices that do not pertain to any part of 122 | the Derivative Works; and 123 | 124 | (d) If the Work includes a "NOTICE" text file as part of its 125 | distribution, then any Derivative Works that You distribute must 126 | include a readable copy of the attribution notices contained 127 | within such NOTICE file, excluding those notices that do not 128 | pertain to any part of the Derivative Works, in at least one 129 | of the following places: within a NOTICE text file distributed 130 | as part of the Derivative Works; within the Source form or 131 | documentation, if provided along with the Derivative Works; or, 132 | within a display generated by the Derivative Works, if and 133 | wherever such third-party notices normally appear. The contents 134 | of the NOTICE file are for informational purposes only and 135 | do not modify the License. You may add Your own attribution 136 | notices within Derivative Works that You distribute, alongside 137 | or as an addendum to the NOTICE text from the Work, provided 138 | that such additional attribution notices cannot be construed 139 | as modifying the License. 140 | 141 | You may add Your own copyright statement to Your modifications and 142 | may provide additional or different license terms and conditions 143 | for use, reproduction, or distribution of Your modifications, or 144 | for any such Derivative Works as a whole, provided Your use, 145 | reproduction, and distribution of the Work otherwise complies with 146 | the conditions stated in this License. 147 | 148 | 5. Submission of Contributions. Unless You explicitly state otherwise, 149 | any Contribution intentionally submitted for inclusion in the Work 150 | by You to the Licensor shall be under the terms and conditions of 151 | this License, without any additional terms or conditions. 152 | Notwithstanding the above, nothing herein shall supersede or modify 153 | the terms of any separate license agreement you may have executed 154 | with Licensor regarding such Contributions. 155 | 156 | 6. Trademarks. This License does not grant permission to use the trade 157 | names, trademarks, service marks, or product names of the Licensor, 158 | except as required for reasonable and customary use in describing the 159 | origin of the Work and reproducing the content of the NOTICE file. 160 | 161 | 7. Disclaimer of Warranty. Unless required by applicable law or 162 | agreed to in writing, Licensor provides the Work (and each 163 | Contributor provides its Contributions) on an "AS IS" BASIS, 164 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or 165 | implied, including, without limitation, any warranties or conditions 166 | of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A 167 | PARTICULAR PURPOSE. You are solely responsible for determining the 168 | appropriateness of using or redistributing the Work and assume any 169 | risks associated with Your exercise of permissions under this License. 170 | 171 | 8. Limitation of Liability. In no event and under no legal theory, 172 | whether in tort (including negligence), contract, or otherwise, 173 | unless required by applicable law (such as deliberate and grossly 174 | negligent acts) or agreed to in writing, shall any Contributor be 175 | liable to You for damages, including any direct, indirect, special, 176 | incidental, or consequential damages of any character arising as a 177 | result of this License or out of the use or inability to use the 178 | Work (including but not limited to damages for loss of goodwill, 179 | work stoppage, computer failure or malfunction, or any and all 180 | other commercial damages or losses), even if such Contributor 181 | has been advised of the possibility of such damages. 182 | 183 | 9. Accepting Warranty or Additional Liability. While redistributing 184 | the Work or Derivative Works thereof, You may choose to offer, 185 | and charge a fee for, acceptance of support, warranty, indemnity, 186 | or other liability obligations and/or rights consistent with this 187 | License. However, in accepting such obligations, You may act only 188 | on Your own behalf and on Your sole responsibility, not on behalf 189 | of any other Contributor, and only if You agree to indemnify, 190 | defend, and hold each Contributor harmless for any liability 191 | incurred by, or claims asserted against, such Contributor by reason 192 | of your accepting any such warranty or additional liability. 193 | 194 | END OF TERMS AND CONDITIONS 195 | 196 | APPENDIX: How to apply the Apache License to your work. 197 | 198 | To apply the Apache License to your work, attach the following 199 | boilerplate notice, with the fields enclosed by brackets "[]" 200 | replaced with your own identifying information. (Don't include 201 | the brackets!) The text should be enclosed in the appropriate 202 | comment syntax for the file format. We also recommend that a 203 | file or class name and description of purpose be included on the 204 | same "printed page" as the copyright notice for easier 205 | identification within third-party archives. 206 | 207 | Copyright [yyyy] [name of copyright owner] 208 | 209 | Licensed under the Apache License, Version 2.0 (the "License"); 210 | you may not use this file except in compliance with the License. 211 | You may obtain a copy of the License at 212 | 213 | http://www.apache.org/licenses/LICENSE-2.0 214 | 215 | Unless required by applicable law or agreed to in writing, software 216 | distributed under the License is distributed on an "AS IS" BASIS, 217 | WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 218 | See the License for the specific language governing permissions and 219 | limitations under the License. 220 | -------------------------------------------------------------------------------- /MarketplaceArtwork.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/MarketplaceArtwork.png -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | 2 | 3 | # Titanium Appcelerator Javascript Dropbox API v2 4 | 5 | I needed a library that would use the new Dropbox API v2. 6 | Not finding any, I decided to create this **module/document**, which uses the [Dropbox API v2 HTTP] . 7 | 8 | This module uses OAuth 2.0 authorization token flow, then you must first [create a Dropbox App key]. 9 | For each API method, it is available the complete documentation and a test. You can also consult the official documentation directly ;) 10 | 11 | Enjoy 12 | 13 | Vittorio Sorbera, AstrovicApps 14 | http://www.astrovicapps.com 15 | 16 | ## Table of contents 17 | 18 | - [Download](#download) 19 | - [Requirements](#requirements) 20 | - [tiapp.xml](#tiapp.xml) 21 | - [Methods](#methods) 22 | - [Example of use](#example-of-use) 23 | - [Screenshots](#screenshots) 24 | - [Todos](#todos) 25 | - [Guidelines for pull requests](#guidelines-for-pull-requests) 26 | - [License](#license) 27 | 28 | --- 29 | 30 | ## Download 31 | Download the [latest release ZIP-file](https://github.com/Astrovic/TiDropboxAPIv2/releases) and consult the [Titanium Documentation](https://titaniumsdk.com/guide/Titanium_SDK/Titanium_SDK_How-tos/Using_Modules/Using_a_Module.html) on how install it. 32 | 33 | ## Requirements 34 | - The `ti.webdialog` module 35 | - The [`ti.deeply`](https://github.com/miniman42/ti.deeply) module (Android only) 36 | - Dropbox requires a redirect URI set to the Dropbox Console App, in order to get a valid token. This url is the same one you will use in the `redirectUri` parameter of the `TiDropbox.init()` method. 37 | In this project I use the redirect URI https://astrovicapps.com/_apptest/tidropbox_cb.html. You will have to create your own and host it somewhere. 38 | You can use the contents of my **tidropbox_cb.html** file. You just need to replace `const scheme = "dropbox";` with the one used in you **tiapp.xml**: 39 | 40 | ```html 41 | 42 | 43 | 44 | 45 | 71 | 72 | 73 |
74 | 75 | 76 | 77 | 78 |
79 | 80 | 81 | ``` 82 | 83 | ## tiapp.xml 84 | The login flow to obtain the token requires the use of the system browser. In order to get back to the app, you need to add an activity to your android manifest, which will be used by the **ti.deeply** module, and a public.mime-type string on iOS. 85 | iOS `public.mime-type` key string, Android `android:scheme` value and `app_mime_scheme` value must be the ones you use in the **tidropbox_cb.html** redirect URI file: 86 | 87 | |tidropbox_cb.html|tiapp.xml iOS|tiapp.xml Android|TiDropbox.init()| 88 | |--|--|--|--| 89 | |`scheme` value|`public.mime-type` key string|`android:scheme` value|`app_mime_scheme` value| 90 | 91 | ```xml 92 | 93 | true 94 | true 95 | 96 | UTExportedTypeDeclarations 97 | 98 | 99 | UTTypeTagSpecification 100 | 101 | public.mime-type 102 | tidropbox 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | ti.dropbox 128 | ti.webdialog 129 | ti.deeply 130 | 131 | ``` 132 | 133 | ## Methods 134 | - [init(parameters)](#--init) 135 | - [generateAuthUrl(callback)](#--generateauthurl) 136 | - [callMethod(parameters)](#--callmethod) 137 | - [revokeAccessToken(callback)](#--revokeaccesstoken) 138 | 139 | ### - init 140 | **`TiDropbox.init(parameters)`** 141 | |Parameters|Type|Required|Description | 142 | |--|--|--|--| 143 | | **APP_KEY** | *String* | ✅ | App key in Dropbox Console App| 144 | | **APP_SECRET** | *String* | ✅ | App secret in Dropbox Console App| 145 | | **redirectUri** | *String* | ✅ | One of your OAuth2 Redirect URIs set to Dropbox Console App | 146 | | **response_type** | *String* | ✅ | `code` or `token`. Token flow expires after 4 hours | 147 | | **app_mime_scheme** | *String* | ✅ | App mime/scheme set to tiapp.xml and used inside your redirect URI page (**https://../tidropbox_cb.html**) to be able to get back to the app after login| 148 | 149 | You need a [Dropbox App key], and a `redirectUri` which must be configured on **Redirect URIs** field of your Dropbox App Settings, on *OAuth 2* section. 150 | ```js 151 | var TiDropbox = require("ti.dropbox").TiDropbox; 152 | TiDropbox.init({ 153 | APP_KEY: '', /**/ 154 | APP_SECRET: '', /**/ 155 | redirectUri: 'https://astrovicapps.com/_apptest/tidropbox_cb.html', /**/ 156 | response_type: "code", // "token" or "code". Token flow expires after 4 hours! 157 | app_mime_scheme: "tidropbox" // **/ 158 | }); 159 | ``` 160 | ### - generateAuthUrl 161 | **`TiDropbox.generateAuthUrl(callback)`** 162 | | Callback parameters| Type |Description | 163 | |--|--|--| 164 | | **success** | *Boolean* | Response result| 165 | | **access_token** | *String* | Access token key| 166 | | **msg** | *String* | Description of the response result | 167 | 168 | This allows you to generate a token to be able to invoke methods. 169 | 170 | ```js 171 | TiDropbox.generateAuthUrl(function(e){ 172 | if(e.success){ 173 | // I'm logged, now I can call any method 174 | Titanium.UI.createAlertDialog({ 175 | title: "AUTH SUCCESS", 176 | message: e.msg + "\n" + "Your access token is: " + e.access_token, 177 | buttonNames: ['OK'] 178 | }).show(); 179 | }else{ 180 | Titanium.UI.createAlertDialog({ 181 | title: "AUTH PROBLEM", 182 | message: e.msg, 183 | buttonNames: ['OK'] 184 | }).show(); 185 | }; 186 | }); 187 | ``` 188 | ### - callMethod 189 | **`TiDropbox.callMethod(parameters)`** 190 | |Parameters|Type|Required|Description | 191 | |--|--|--|--| 192 | | **methodStr** | *String* | ✅ | Represent API target. It contains Dropbox's namespace and method name: `"files/upload"` or `"sharing/share_folder"` or more at [/lib/dropboxAPIv2.js]| 193 | | **paramsObj** | *Object* | ✅ | Parameters object, depends on resource field| 194 | | **fileBin** | *Blob/null* | ✅ | File to upload, depends on resource field | 195 | | **onSuccessCallback** | *Function* | ✅ | Callback on succes | 196 | | **onErrorCallback** | *Function* | ✅ | Callback on error | 197 | | **callMethodXhrObjCallback** | *Function* | | Return directly the *TiDropbox.xhr* object of the current `TiDropbox.callMethod`, so you can invoke all xhr methods you need: abort, onload, onsendstream, ecc.. | 198 | 199 | After obtaining a valid token, you can call any method: 200 | ```js 201 | // Upload the a.txt file to my app's Dropbox home 202 | TiDropbox.callMethod({ 203 | methodStr: "files/upload", 204 | paramsObj: { 205 | path: "/a.txt", 206 | mode: "add", 207 | autorename: true, 208 | mute: false 209 | }, 210 | fileBin: Ti.Filesystem.getFile(Ti.Filesystem.resourcesDirectory, "a.txt").read(), 211 | onSuccessCallback: (xhr) => { 212 | console.log("onSuccessCallback checkins response-> " + xhr.responseText); 213 | }, 214 | onErrorCallback: (e) => { 215 | console.error("onErrorCallback checkins response-> " + JSON.stringify(e)); 216 | if (JSON.stringify(e).indexOf("invalid_access_token") != -1) { 217 | //The session has expired, I need a new token }; 218 | // Do something... 219 | } 220 | }, 221 | callMethodXhrObjCallback: (currentCallMethodXhr) => { 222 | currentCallMethodXhr.onsendstream = function (e) { 223 | if (e.progress) { 224 | console.log(JSON.stringify('Upload progress --> ' + (e.progress * 100) + '%')); 225 | } 226 | } 227 | } 228 | }); 229 | ``` 230 | 231 | ### - revokeAccessToken 232 | **`TiDropbox.revokeAccessToken(callback)`** 233 | | Callback parameters| Type |Description | 234 | |--|--|--| 235 | | **success** | *Boolean* | Response result| 236 | | **access_token** | *String* | Access token key| 237 | | **msg** | *String* | Description of the response result | 238 | 239 | Revoke the access token. 240 | ```js 241 | TiDropbox.revokeAccessToken(function (e) { 242 | if (e.success) { 243 | // Logout, do something... 244 | Titanium.UI.createAlertDialog({ 245 | title: "REVOKE AUTH SUCCESS", 246 | message: e.msg, 247 | buttonNames: ['OK'] 248 | }).show(); 249 | } else { 250 | Titanium.UI.createAlertDialog({ 251 | title: "REVOKE AUTH PROBLEM", 252 | message: e.msg, 253 | buttonNames: ['OK'] 254 | }).show(); 255 | }; 256 | }); 257 | ``` 258 | 259 | That's all! :) 260 | 261 | # Example of use 262 | ### File upload 263 | ```js 264 | var TiDropbox = require("ti.dropbox").TiDropbox; 265 | TiDropbox.init({ 266 | APP_KEY: '', /**/ 267 | APP_SECRET: '', /**/ 268 | redirectUri: 'https://astrovicapps.com/_apptest/tidropbox_cb.html', /**/ 269 | response_type: "code", // "token" or "code". Token flow expires after 4 hours! 270 | app_mime_scheme: "tidropbox" // **/ 271 | }); 272 | 273 | // Check if I have a token 274 | if (Ti.App.Properties.getString('DROPBOX_TOKENS', null)) { 275 | login(); 276 | } else { 277 | TiDropbox.revokeAccessToken(function () { 278 | // Logout, do something... 279 | }); 280 | }; 281 | 282 | function login() { 283 | TiDropbox.generateAuthUrl(function (e) { 284 | if (e.success) { 285 | // I'm logged, now I can call any method (/lib/dropboxAPIv2.js) 286 | // For example, if I want upload a.txt file on Dropbox App root folder 287 | fileUpload(); 288 | } else { 289 | Titanium.UI.createAlertDialog({ 290 | title: "AUTH PROBLEM", 291 | message: e.msg, 292 | buttonNames: ['OK'] 293 | }).show(); 294 | }; 295 | }); 296 | }; 297 | 298 | function fileUpload() { 299 | 300 | TiDropbox.callMethod({ 301 | methodStr: "files/upload", 302 | paramsObj: { 303 | path: "/a.txt", 304 | mode: "add", 305 | autorename: true, 306 | mute: false 307 | }, 308 | fileBin: Ti.Filesystem.getFile(Ti.Filesystem.resourcesDirectory, "a.txt").read(), 309 | onSuccessCallback: onSuccessCallback, 310 | onErrorCallback: onErrorCallback, 311 | callMethodXhrObjCallback: callMethodXhrObjCallback 312 | }); 313 | 314 | // callback functions 315 | function onSuccessCallback(xhr) { 316 | Ti.API.info("onSuccessCallback checkins response-> " + xhr.responseText); 317 | Titanium.UI.createAlertDialog({ 318 | title: "METHOD SUCCESS", 319 | message: xhr.responseText, 320 | buttonNames: ['OK'] 321 | }).show(); 322 | }; 323 | 324 | function onErrorCallback(e) { 325 | Ti.API.info("onErrorCallback checkins response-> " + JSON.stringify(e)); 326 | Titanium.UI.createAlertDialog({ 327 | title: "METHOD FAILED", 328 | message: JSON.stringify(e), 329 | buttonNames: ['OK'] 330 | }).show(); 331 | if (JSON.stringify(e).indexOf("invalid_access_token") != -1) { 332 | //The session has expired, I need a new token 333 | Ti.App.Properties.setString('DROPBOX_TOKENS', null); 334 | login(); 335 | }; 336 | }; 337 | 338 | function callMethodXhrObjCallback(currentCallMethodXhr) { 339 | currentCallMethodXhr.onsendstream = function (e) { 340 | Ti.API.debug(JSON.stringify(e)); 341 | if (e.progress) { 342 | Ti.API.debug(JSON.stringify('Upload progress --> ' + (e.progress * 100) + '%')); 343 | } 344 | }; 345 | }; 346 | }; 347 | ``` 348 | 349 | ### File download 350 | ```js 351 | var TiDropbox = require("ti.dropbox").TiDropbox; 352 | TiDropbox.init({ 353 | APP_KEY: '', /**/ 354 | APP_SECRET: '', /**/ 355 | redirectUri: 'https://astrovicapps.com/_apptest/tidropbox_cb.html', /**/ 356 | response_type: "code", // "token" or "code". Token flow expires after 4 hours! 357 | app_mime_scheme: "tidropbox" // **/ 358 | }); 359 | 360 | // Check if I have a token 361 | if (Ti.App.Properties.getString('DROPBOX_TOKENS', null)) { 362 | login(); 363 | } else { 364 | TiDropbox.revokeAccessToken(function () { 365 | // Logout, do something... 366 | }); 367 | }; 368 | 369 | function login() { 370 | TiDropbox.generateAuthUrl(function () { 371 | if (e.success) { 372 | // I'm logged, now I can call any method (/lib/dropboxAPIv2.js) 373 | // For example, if I want download Prime_Numbers.txt file from Dropbox App 374 | downloadFile(); 375 | } else { 376 | Titanium.UI.createAlertDialog({ 377 | title: "AUTH PROBLEM", 378 | message: e.msg, 379 | buttonNames: ['OK'] 380 | }).show(); 381 | }; 382 | }); 383 | }; 384 | 385 | function downloadFile() { 386 | 387 | TiDropbox.callMethod({ 388 | methodStr: "files/download", 389 | paramsObj: { 390 | path: "/Homework/math/Prime_Numbers.txt" 391 | }, 392 | fileBin: null, 393 | onSuccessCallback: onSuccessCallback, 394 | onErrorCallback: onErrorCallback, 395 | callMethodXhrObjCallback: callMethodXhrObjCallback 396 | }); 397 | 398 | // callback functions 399 | function onSuccessCallback(xhr) { 400 | Ti.API.debug("onSuccessCallback checkins response-> " + xhr.responseText); 401 | 402 | // Write downloaded data in a file 403 | if (xhr.responseData) { 404 | var filePath = Titanium.Filesystem.applicationDataDirectory + "myDownloadedFile.txt"; 405 | var f = Titanium.Filesystem.getFile(filePath); 406 | f.write(xhr.responseData); 407 | 408 | // I check if I saved the file properly 409 | setTimeout(function () { 410 | Ti.API.debug(filePath + " exists? ---> " + file.exists()); 411 | if (f.exists()) { 412 | if (OS_IOS) { 413 | Ti.UI.iOS.createDocumentViewer({ 414 | url: filePath 415 | }).show(); 416 | }; 417 | } else { 418 | Titanium.UI.createAlertDialog({ 419 | title: "DOWNLOAD FAILED", 420 | message: "Something went wrong in the file writing...", 421 | buttonNames: ['OK'] 422 | }).show(); 423 | }; 424 | }, 1000); 425 | }; 426 | }; 427 | 428 | function onErrorCallback(e) { 429 | Ti.API.debug("onErrorCallback checkins response-> " + JSON.stringify(e)); 430 | Titanium.UI.createAlertDialog({ 431 | title: "METHOD FAILED", 432 | message: JSON.stringify(e), 433 | buttonNames: ['OK'] 434 | }).show(); 435 | if (JSON.stringify(e).indexOf("invalid_access_token") != -1) { 436 | //The session has expired, I need a new token 437 | Ti.App.Properties.setString('DROPBOX_TOKENS', null); 438 | login(); 439 | }; 440 | }; 441 | 442 | function callMethodXhrObjCallback(currentCallMethodXhr) { 443 | currentCallMethodXhr.onsendstream = function (e) { 444 | if (e.progress) { 445 | console.log(JSON.stringify('Upload progress --> ' + (e.progress * 100) + '%')); 446 | } 447 | } 448 | } 449 | } 450 | ``` 451 | 452 | Download and build this project to test other methods 453 | 454 | 455 | # Screenshots 456 | 457 | 458 | 459 | 460 | 461 | 462 | 463 | 464 | 465 | 466 | 467 | 468 | 469 | 470 | 471 | 472 | ### Todos 473 | 474 | - OAauth 2 code flow ✅ DONE! 475 | 476 | # Guidelines for pull requests 477 | 478 | Every contribution and pull requests are welcome! This repository is a **module/document**. So you can contribute both to the documentation, that to new versions of the module. 479 | 480 | ### Pull requests for new module version 481 | If you want to create a new module version, to edit or add new methods, **do not edit the [`modules/`](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/modules) folder directly! But you have to delete [`modules/commonjs`](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/modules/commonjs) folder.** You should edit the 482 | source files in [**`/lib`**](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/app/lib) folder instead. 483 | 484 | After making your changes, to create a new version of the module you have to follow the following steps: 485 | 486 | - Increase the version number in [package.json](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/package.json) file, in the root folder. 487 | - Uses [Titaniumifier](https://github.com/smclab/titaniumifier) to generate the zip module, with the command: 488 | 489 | `$ titaniumifier --in . --out ./dist` 490 | - Import your new **ti.dropbox-commonjs-x.x.x.zip** module in the project. This will create the [**`modules/commonjs`**](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/modules/commonjs) folder you had removed earlier, with the new version of the module. 491 | 492 | All done :) Now you can send your pull request. 493 | 494 | License 495 | ---- 496 | **Copyright (c) 2016-23 Vittorio Sorbera, AstrovicApps** 497 | 498 | Permission is hereby granted, free of charge, to any person obtaining a copy 499 | of this software and associated documentation files (the "Software"), to deal 500 | in the Software without restriction, including without limitation the rights 501 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 502 | copies of the Software, and to permit persons to whom the Software is 503 | furnished to do so, subject to the following conditions: 504 | 505 | The above copyright notice and this permission notice shall be included in 506 | all copies or substantial portions of the Software. 507 | 508 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 509 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 510 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 511 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 512 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 513 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 514 | THE SOFTWARE. 515 | 516 | [//]: # (These are reference links used in the body of this note and get stripped out when the markdown processor does its job. There is no need to format nicely because it shouldn't be seen. Thanks SO - http://stackoverflow.com/questions/4823468/store-comments-in-markdown-syntax) 517 | 518 | [Dropbox API v2 HTTP]: 519 | [create a Dropbox App key]: 520 | [Dropbox App key]: 521 | [/lib/dropboxAPIv2.js]: 522 | -------------------------------------------------------------------------------- /app/README.md: -------------------------------------------------------------------------------- 1 | 2 | 3 | # Titanium Appcelerator Javascript Dropbox API v2 4 | 5 | I needed a library that would use the new Dropbox API v2. 6 | Not finding any, I decided to create this **module/document**, which uses the [Dropbox API v2 HTTP] . 7 | 8 | This module uses OAuth 2.0 authorization token flow, then you must first [create a Dropbox App key]. 9 | For each API method, it is available the complete documentation and a test. You can also consult the official documentation directly ;) 10 | 11 | Enjoy 12 | 13 | Vittorio Sorbera, AstrovicApps 14 | http://www.astrovicapps.com 15 | 16 | ## Table of contents 17 | 18 | - [Download](#download) 19 | - [Requirements](#requirements) 20 | - [tiapp.xml](#tiapp.xml) 21 | - [Methods](#methods) 22 | - [Example of use](#example-of-use) 23 | - [Screenshots](#screenshots) 24 | - [Todos](#todos) 25 | - [Guidelines for pull requests](#guidelines-for-pull-requests) 26 | - [License](#license) 27 | 28 | --- 29 | 30 | ## Download 31 | Download the [latest release ZIP-file](https://github.com/Astrovic/TiDropboxAPIv2/releases) and consult the [Titanium Documentation](https://titaniumsdk.com/guide/Titanium_SDK/Titanium_SDK_How-tos/Using_Modules/Using_a_Module.html) on how install it. 32 | 33 | ## Requirements 34 | - The `ti.webdialog` module 35 | - The [`ti.deeply`](https://github.com/miniman42/ti.deeply) module (Android only) 36 | - Dropbox requires a redirect URI set to the Dropbox Console App, in order to get a valid token. This url is the same one you will use in the `redirectUri` parameter of the `TiDropbox.init()` method. 37 | In this project I use the redirect URI https://astrovicapps.com/_apptest/tidropbox_cb.html. You will have to create your own and host it somewhere. 38 | You can use the contents of my **tidropbox_cb.html** file. You just need to replace `const scheme = "dropbox";` with the one used in you **tiapp.xml**: 39 | 40 | ```html 41 | 42 | 43 | 44 | 45 | 71 | 72 | 73 |
74 | 75 | 76 | 77 | 78 |
79 | 80 | 81 | ``` 82 | 83 | ## tiapp.xml 84 | The login flow to obtain the token requires the use of the system browser. In order to get back to the app, you need to add an activity to your android manifest, which will be used by the **ti.deeply** module, and a public.mime-type string on iOS. 85 | iOS `public.mime-type` key string, Android `android:scheme` value and `app_mime_scheme` value must be the ones you use in the **tidropbox_cb.html** redirect URI file: 86 | 87 | |tidropbox_cb.html|tiapp.xml iOS|tiapp.xml Android|TiDropbox.init()| 88 | |--|--|--|--| 89 | |`scheme` value|`public.mime-type` key string|`android:scheme` value|`app_mime_scheme` value| 90 | 91 | ```xml 92 | 93 | true 94 | true 95 | 96 | UTExportedTypeDeclarations 97 | 98 | 99 | UTTypeTagSpecification 100 | 101 | public.mime-type 102 | tidropbox 103 | 104 | 105 | 106 | 107 | 108 | 109 | 110 | 111 | 112 | 114 | 115 | 116 | 117 | 118 | 119 | 120 | 121 | 122 | 123 | 124 | 125 | 126 | 127 | ti.dropbox 128 | ti.webdialog 129 | ti.deeply 130 | 131 | ``` 132 | 133 | ## Methods 134 | - [init(parameters)](#--init) 135 | - [generateAuthUrl(callback)](#--generateauthurl) 136 | - [callMethod(parameters)](#--callmethod) 137 | - [revokeAccessToken(callback)](#--revokeaccesstoken) 138 | 139 | ### - init 140 | **`TiDropbox.init(parameters)`** 141 | |Parameters|Type|Required|Description | 142 | |--|--|--|--| 143 | | **APP_KEY** | *String* | ✅ | App key in Dropbox Console App| 144 | | **APP_SECRET** | *String* | ✅ | App secret in Dropbox Console App| 145 | | **redirectUri** | *String* | ✅ | One of your OAuth2 Redirect URIs set to Dropbox Console App | 146 | | **response_type** | *String* | ✅ | `code` or `token`. Token flow expires after 4 hours | 147 | | **app_mime_scheme** | *String* | ✅ | App mime/scheme set to tiapp.xml and used inside your redirect URI page (**https://../tidropbox_cb.html**) to be able to get back to the app after login| 148 | 149 | You need a [Dropbox App key], and a `redirectUri` which must be configured on **Redirect URIs** field of your Dropbox App Settings, on *OAuth 2* section. 150 | ```js 151 | var TiDropbox = require("ti.dropbox").TiDropbox; 152 | TiDropbox.init({ 153 | APP_KEY: '', /**/ 154 | APP_SECRET: '', /**/ 155 | redirectUri: 'https://astrovicapps.com/_apptest/tidropbox_cb.html', /**/ 156 | response_type: "code", // "token" or "code". Token flow expires after 4 hours! 157 | app_mime_scheme: "tidropbox" // **/ 158 | }); 159 | ``` 160 | ### - generateAuthUrl 161 | **`TiDropbox.generateAuthUrl(callback)`** 162 | | Callback parameters| Type |Description | 163 | |--|--|--| 164 | | **success** | *Boolean* | Response result| 165 | | **access_token** | *String* | Access token key| 166 | | **msg** | *String* | Description of the response result | 167 | 168 | This allows you to generate a token to be able to invoke methods. 169 | 170 | ```js 171 | TiDropbox.generateAuthUrl(function(e){ 172 | if(e.success){ 173 | // I'm logged, now I can call any method 174 | Titanium.UI.createAlertDialog({ 175 | title: "AUTH SUCCESS", 176 | message: e.msg + "\n" + "Your access token is: " + e.access_token, 177 | buttonNames: ['OK'] 178 | }).show(); 179 | }else{ 180 | Titanium.UI.createAlertDialog({ 181 | title: "AUTH PROBLEM", 182 | message: e.msg, 183 | buttonNames: ['OK'] 184 | }).show(); 185 | }; 186 | }); 187 | ``` 188 | ### - callMethod 189 | **`TiDropbox.callMethod(parameters)`** 190 | |Parameters|Type|Required|Description | 191 | |--|--|--|--| 192 | | **methodStr** | *String* | ✅ | Represent API target. It contains Dropbox's namespace and method name: `"files/upload"` or `"sharing/share_folder"` or more at [/lib/dropboxAPIv2.js]| 193 | | **paramsObj** | *Object* | ✅ | Parameters object, depends on resource field| 194 | | **fileBin** | *Blob/null* | ✅ | File to upload, depends on resource field | 195 | | **onSuccessCallback** | *Function* | ✅ | Callback on succes | 196 | | **onErrorCallback** | *Function* | ✅ | Callback on error | 197 | | **callMethodXhrObjCallback** | *Function* | | Return directly the *TiDropbox.xhr* object of the current `TiDropbox.callMethod`, so you can invoke all xhr methods you need: abort, onload, onsendstream, ecc.. | 198 | 199 | After obtaining a valid token, you can call any method: 200 | ```js 201 | // Upload the a.txt file to my app's Dropbox home 202 | TiDropbox.callMethod({ 203 | methodStr: "files/upload", 204 | paramsObj: { 205 | path: "/a.txt", 206 | mode: "add", 207 | autorename: true, 208 | mute: false 209 | }, 210 | fileBin: Ti.Filesystem.getFile(Ti.Filesystem.resourcesDirectory, "a.txt").read(), 211 | onSuccessCallback: (xhr) => { 212 | console.log("onSuccessCallback checkins response-> " + xhr.responseText); 213 | }, 214 | onErrorCallback: (e) => { 215 | console.error("onErrorCallback checkins response-> " + JSON.stringify(e)); 216 | if (JSON.stringify(e).indexOf("invalid_access_token") != -1) { 217 | //The session has expired, I need a new token }; 218 | // Do something... 219 | } 220 | }, 221 | callMethodXhrObjCallback: (currentCallMethodXhr) => { 222 | currentCallMethodXhr.onsendstream = function (e) { 223 | if (e.progress) { 224 | console.log(JSON.stringify('Upload progress --> ' + (e.progress * 100) + '%')); 225 | } 226 | } 227 | } 228 | }); 229 | ``` 230 | 231 | ### - revokeAccessToken 232 | **`TiDropbox.revokeAccessToken(callback)`** 233 | | Callback parameters| Type |Description | 234 | |--|--|--| 235 | | **success** | *Boolean* | Response result| 236 | | **access_token** | *String* | Access token key| 237 | | **msg** | *String* | Description of the response result | 238 | 239 | Revoke the access token. 240 | ```js 241 | TiDropbox.revokeAccessToken(function (e) { 242 | if (e.success) { 243 | // Logout, do something... 244 | Titanium.UI.createAlertDialog({ 245 | title: "REVOKE AUTH SUCCESS", 246 | message: e.msg, 247 | buttonNames: ['OK'] 248 | }).show(); 249 | } else { 250 | Titanium.UI.createAlertDialog({ 251 | title: "REVOKE AUTH PROBLEM", 252 | message: e.msg, 253 | buttonNames: ['OK'] 254 | }).show(); 255 | }; 256 | }); 257 | ``` 258 | 259 | That's all! :) 260 | 261 | # Example of use 262 | ### File upload 263 | ```js 264 | var TiDropbox = require("ti.dropbox").TiDropbox; 265 | TiDropbox.init({ 266 | APP_KEY: '', /**/ 267 | APP_SECRET: '', /**/ 268 | redirectUri: 'https://astrovicapps.com/_apptest/tidropbox_cb.html', /**/ 269 | response_type: "code", // "token" or "code". Token flow expires after 4 hours! 270 | app_mime_scheme: "tidropbox" // **/ 271 | }); 272 | 273 | // Check if I have a token 274 | if (Ti.App.Properties.getString('DROPBOX_TOKENS', null)) { 275 | login(); 276 | } else { 277 | TiDropbox.revokeAccessToken(function () { 278 | // Logout, do something... 279 | }); 280 | }; 281 | 282 | function login() { 283 | TiDropbox.generateAuthUrl(function (e) { 284 | if (e.success) { 285 | // I'm logged, now I can call any method (/lib/dropboxAPIv2.js) 286 | // For example, if I want upload a.txt file on Dropbox App root folder 287 | fileUpload(); 288 | } else { 289 | Titanium.UI.createAlertDialog({ 290 | title: "AUTH PROBLEM", 291 | message: e.msg, 292 | buttonNames: ['OK'] 293 | }).show(); 294 | }; 295 | }); 296 | }; 297 | 298 | function fileUpload() { 299 | 300 | TiDropbox.callMethod({ 301 | methodStr: "files/upload", 302 | paramsObj: { 303 | path: "/a.txt", 304 | mode: "add", 305 | autorename: true, 306 | mute: false 307 | }, 308 | fileBin: Ti.Filesystem.getFile(Ti.Filesystem.resourcesDirectory, "a.txt").read(), 309 | onSuccessCallback: onSuccessCallback, 310 | onErrorCallback: onErrorCallback, 311 | callMethodXhrObjCallback: callMethodXhrObjCallback 312 | }); 313 | 314 | // callback functions 315 | function onSuccessCallback(xhr) { 316 | Ti.API.info("onSuccessCallback checkins response-> " + xhr.responseText); 317 | Titanium.UI.createAlertDialog({ 318 | title: "METHOD SUCCESS", 319 | message: xhr.responseText, 320 | buttonNames: ['OK'] 321 | }).show(); 322 | }; 323 | 324 | function onErrorCallback(e) { 325 | Ti.API.info("onErrorCallback checkins response-> " + JSON.stringify(e)); 326 | Titanium.UI.createAlertDialog({ 327 | title: "METHOD FAILED", 328 | message: JSON.stringify(e), 329 | buttonNames: ['OK'] 330 | }).show(); 331 | if (JSON.stringify(e).indexOf("invalid_access_token") != -1) { 332 | //The session has expired, I need a new token 333 | Ti.App.Properties.setString('DROPBOX_TOKENS', null); 334 | login(); 335 | }; 336 | }; 337 | 338 | function callMethodXhrObjCallback(currentCallMethodXhr) { 339 | currentCallMethodXhr.onsendstream = function (e) { 340 | Ti.API.debug(JSON.stringify(e)); 341 | if (e.progress) { 342 | Ti.API.debug(JSON.stringify('Upload progress --> ' + (e.progress * 100) + '%')); 343 | } 344 | }; 345 | }; 346 | }; 347 | ``` 348 | 349 | ### File download 350 | ```js 351 | var TiDropbox = require("ti.dropbox").TiDropbox; 352 | TiDropbox.init({ 353 | APP_KEY: '', /**/ 354 | APP_SECRET: '', /**/ 355 | redirectUri: 'https://astrovicapps.com/_apptest/tidropbox_cb.html', /**/ 356 | response_type: "code", // "token" or "code". Token flow expires after 4 hours! 357 | app_mime_scheme: "tidropbox" // **/ 358 | }); 359 | 360 | // Check if I have a token 361 | if (Ti.App.Properties.getString('DROPBOX_TOKENS', null)) { 362 | login(); 363 | } else { 364 | TiDropbox.revokeAccessToken(function () { 365 | // Logout, do something... 366 | }); 367 | }; 368 | 369 | function login() { 370 | TiDropbox.generateAuthUrl(function () { 371 | if (e.success) { 372 | // I'm logged, now I can call any method (/lib/dropboxAPIv2.js) 373 | // For example, if I want download Prime_Numbers.txt file from Dropbox App 374 | downloadFile(); 375 | } else { 376 | Titanium.UI.createAlertDialog({ 377 | title: "AUTH PROBLEM", 378 | message: e.msg, 379 | buttonNames: ['OK'] 380 | }).show(); 381 | }; 382 | }); 383 | }; 384 | 385 | function downloadFile() { 386 | 387 | TiDropbox.callMethod({ 388 | methodStr: "files/download", 389 | paramsObj: { 390 | path: "/Homework/math/Prime_Numbers.txt" 391 | }, 392 | fileBin: null, 393 | onSuccessCallback: onSuccessCallback, 394 | onErrorCallback: onErrorCallback, 395 | callMethodXhrObjCallback: callMethodXhrObjCallback 396 | }); 397 | 398 | // callback functions 399 | function onSuccessCallback(xhr) { 400 | Ti.API.debug("onSuccessCallback checkins response-> " + xhr.responseText); 401 | 402 | // Write downloaded data in a file 403 | if (xhr.responseData) { 404 | var filePath = Titanium.Filesystem.applicationDataDirectory + "myDownloadedFile.txt"; 405 | var f = Titanium.Filesystem.getFile(filePath); 406 | f.write(xhr.responseData); 407 | 408 | // I check if I saved the file properly 409 | setTimeout(function () { 410 | Ti.API.debug(filePath + " exists? ---> " + file.exists()); 411 | if (f.exists()) { 412 | if (OS_IOS) { 413 | Ti.UI.iOS.createDocumentViewer({ 414 | url: filePath 415 | }).show(); 416 | }; 417 | } else { 418 | Titanium.UI.createAlertDialog({ 419 | title: "DOWNLOAD FAILED", 420 | message: "Something went wrong in the file writing...", 421 | buttonNames: ['OK'] 422 | }).show(); 423 | }; 424 | }, 1000); 425 | }; 426 | }; 427 | 428 | function onErrorCallback(e) { 429 | Ti.API.debug("onErrorCallback checkins response-> " + JSON.stringify(e)); 430 | Titanium.UI.createAlertDialog({ 431 | title: "METHOD FAILED", 432 | message: JSON.stringify(e), 433 | buttonNames: ['OK'] 434 | }).show(); 435 | if (JSON.stringify(e).indexOf("invalid_access_token") != -1) { 436 | //The session has expired, I need a new token 437 | Ti.App.Properties.setString('DROPBOX_TOKENS', null); 438 | login(); 439 | }; 440 | }; 441 | 442 | function callMethodXhrObjCallback(currentCallMethodXhr) { 443 | currentCallMethodXhr.onsendstream = function (e) { 444 | if (e.progress) { 445 | console.log(JSON.stringify('Upload progress --> ' + (e.progress * 100) + '%')); 446 | } 447 | } 448 | } 449 | } 450 | ``` 451 | 452 | Download and build this project to test other methods 453 | 454 | 455 | # Screenshots 456 | 457 | 458 | 459 | 460 | 461 | 462 | 463 | 464 | 465 | 466 | 467 | 468 | 469 | 470 | 471 | 472 | ### Todos 473 | 474 | - OAauth 2 code flow ✅ DONE! 475 | 476 | # Guidelines for pull requests 477 | 478 | Every contribution and pull requests are welcome! This repository is a **module/document**. So you can contribute both to the documentation, that to new versions of the module. 479 | 480 | ### Pull requests for new module version 481 | If you want to create a new module version, to edit or add new methods, **do not edit the [`modules/`](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/modules) folder directly! But you have to delete [`modules/commonjs`](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/modules/commonjs) folder.** You should edit the 482 | source files in [**`/lib`**](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/app/lib) folder instead. 483 | 484 | After making your changes, to create a new version of the module you have to follow the following steps: 485 | 486 | - Increase the version number in [package.json](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/package.json) file, in the root folder. 487 | - Uses [Titaniumifier](https://github.com/smclab/titaniumifier) to generate the zip module, with the command: 488 | 489 | `$ titaniumifier --in . --out ./dist` 490 | - Import your new **ti.dropbox-commonjs-x.x.x.zip** module in the project. This will create the [**`modules/commonjs`**](https://github.com/Astrovic/TiDropboxAPIv2/tree/master/modules/commonjs) folder you had removed earlier, with the new version of the module. 491 | 492 | All done :) Now you can send your pull request. 493 | 494 | License 495 | ---- 496 | **Copyright (c) 2016-23 Vittorio Sorbera, AstrovicApps** 497 | 498 | Permission is hereby granted, free of charge, to any person obtaining a copy 499 | of this software and associated documentation files (the "Software"), to deal 500 | in the Software without restriction, including without limitation the rights 501 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 502 | copies of the Software, and to permit persons to whom the Software is 503 | furnished to do so, subject to the following conditions: 504 | 505 | The above copyright notice and this permission notice shall be included in 506 | all copies or substantial portions of the Software. 507 | 508 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 509 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 510 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 511 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 512 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 513 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 514 | THE SOFTWARE. 515 | 516 | [//]: # (These are reference links used in the body of this note and get stripped out when the markdown processor does its job. There is no need to format nicely because it shouldn't be seen. Thanks SO - http://stackoverflow.com/questions/4823468/store-comments-in-markdown-syntax) 517 | 518 | [Dropbox API v2 HTTP]: 519 | [create a Dropbox App key]: 520 | [Dropbox App key]: 521 | [/lib/dropboxAPIv2.js]: 522 | -------------------------------------------------------------------------------- /app/alloy.js: -------------------------------------------------------------------------------- 1 | // The contents of this file will be executed before any of 2 | // your view controllers are ever executed, including the index. 3 | // You have access to all functionality on the `Alloy` namespace. 4 | // 5 | // This is a great place to do any initialization for your app 6 | // or create any global variables/functions that you'd like to 7 | // make available throughout your app. You can easily make things 8 | // accessible globally by attaching them to the `Alloy.Globals` 9 | // object. For example: 10 | // 11 | // Alloy.Globals.someGlobalFunction = function(){}; 12 | -------------------------------------------------------------------------------- /app/assets/Matrices.txt: -------------------------------------------------------------------------------- 1 | This is a test file :) -------------------------------------------------------------------------------- /app/assets/Prime_Numbers.txt: -------------------------------------------------------------------------------- 1 | This is a test file :) -------------------------------------------------------------------------------- /app/assets/a.txt: -------------------------------------------------------------------------------- 1 | This is a test file :) -------------------------------------------------------------------------------- /app/assets/android/appicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/appicon.png -------------------------------------------------------------------------------- /app/assets/android/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-long-land-hdpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-long-land-hdpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-long-land-ldpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-long-land-ldpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-long-land-mdpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-long-land-mdpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-long-port-hdpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-long-port-hdpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-long-port-ldpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-long-port-ldpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-notlong-land-hdpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-notlong-land-hdpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-notlong-land-ldpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-notlong-land-ldpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-notlong-land-mdpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-notlong-land-mdpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-notlong-port-hdpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-notlong-port-hdpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-notlong-port-ldpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-notlong-port-ldpi/default.png -------------------------------------------------------------------------------- /app/assets/android/images/res-notlong-port-mdpi/default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/android/images/res-notlong-port-mdpi/default.png -------------------------------------------------------------------------------- /app/assets/image.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/image.jpg -------------------------------------------------------------------------------- /app/assets/iphone/Default-568h@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-568h@2x.png -------------------------------------------------------------------------------- /app/assets/iphone/Default-667h@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-667h@2x.png -------------------------------------------------------------------------------- /app/assets/iphone/Default-Landscape-736h@3x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-Landscape-736h@3x.png -------------------------------------------------------------------------------- /app/assets/iphone/Default-Landscape.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-Landscape.png -------------------------------------------------------------------------------- /app/assets/iphone/Default-Landscape@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-Landscape@2x.png -------------------------------------------------------------------------------- /app/assets/iphone/Default-Portrait-736h@3x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-Portrait-736h@3x.png -------------------------------------------------------------------------------- /app/assets/iphone/Default-Portrait.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-Portrait.png -------------------------------------------------------------------------------- /app/assets/iphone/Default-Portrait@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default-Portrait@2x.png -------------------------------------------------------------------------------- /app/assets/iphone/Default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default.png -------------------------------------------------------------------------------- /app/assets/iphone/Default@2x.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/iphone/Default@2x.png -------------------------------------------------------------------------------- /app/assets/mobileweb/appicon.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/mobileweb/appicon.png -------------------------------------------------------------------------------- /app/assets/mobileweb/apple_startup_images/Default-Landscape.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/mobileweb/apple_startup_images/Default-Landscape.jpg -------------------------------------------------------------------------------- /app/assets/mobileweb/apple_startup_images/Default-Landscape.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/mobileweb/apple_startup_images/Default-Landscape.png -------------------------------------------------------------------------------- /app/assets/mobileweb/apple_startup_images/Default-Portrait.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/mobileweb/apple_startup_images/Default-Portrait.jpg -------------------------------------------------------------------------------- /app/assets/mobileweb/apple_startup_images/Default-Portrait.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/mobileweb/apple_startup_images/Default-Portrait.png -------------------------------------------------------------------------------- /app/assets/mobileweb/apple_startup_images/Default.jpg: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/mobileweb/apple_startup_images/Default.jpg -------------------------------------------------------------------------------- /app/assets/mobileweb/apple_startup_images/Default.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/Astrovic/TiDropboxAPIv2/492cbd8a0b86a9712622c97af5a07528c063306a/app/assets/mobileweb/apple_startup_images/Default.png -------------------------------------------------------------------------------- /app/assets/mobileweb/apple_startup_images/README: -------------------------------------------------------------------------------- 1 | These startup images are used by iPhone and iPad apps that are installed to the 2 | home screen. These images are displayed before the splash screen is displayed. 3 | 4 | If you want to create a new splash screen, it is recommended that you start by 5 | modifying the files in the adjacent "splash" folder, then take screenshots of 6 | device, crop, and save into this directory. This is the best way to avoid visual 7 | artifacts when the app transitions from the Apple startup images to the splash 8 | screen assets. 9 | 10 | IMPORTANT! Only one file format of each unique filename will be copied. PNG is 11 | preferred over JPG. In other words, if "Default.png" exists, it will be copied 12 | instead of "Default.jpg". -------------------------------------------------------------------------------- /app/assets/mobileweb/splash/README: -------------------------------------------------------------------------------- 1 | This folder contains assets to make the startup splash screen assets. Splash 2 | screens are made up of HTML and CSS. This allows you the flexibility to 3 | customize your splash screen to fit a variety of screen sizes and orientations. 4 | 5 | 6 | splash.html 7 | ----------- 8 | Contains an HTML fragment that is inserted into a div tag with an id="splash". 9 | You can choose to leave this file empty. You can put