https://www.u.tools/ Dev Docs: https://www.u.tools/docs/developer/welcome.html - [Questions](#questions) - [Manifest](#manifest) - [Dev](#dev) - [preload.js](#preloadjs) - [Use Third Party Packages](#use-third-party-packages) - [uTools API](#utools-api) - [uTools DB API](#utools-db-api) - [uTools Browser API](#utools-browser-api) - [uTools Server API](#utools-server-api) - [注意事项](#注意事项) - [App Storage](#app-storage) ## Questions 1. How does uTools render UI? 2. How does uTools allow plugins to access system API? ## Manifest ```json title="plugin.json" { "main": "index.html", "logo": "logo.png", "features": [ { "code": "hello", "explain": "hello world", "cmds": ["hello", "你好"] } ] } ``` - `main` is the entry point. - `features` is a list of features - `features.code` id code to distinguish features - `features.cmds`: command list to trigger the feature (中文会自动支持 拼音及拼音首字母,无须重复添加) - `"platform": ["win32", "darwin", "linux"]` optional ## Dev The dev tools provided by uTools can load plugin for testing and bundle into `.ups` file which can be installed and shared. Like Alfred's workflow file. Example: https://github.com/uTools-Labs/utools-tutorials/tree/main/utools-helloworld-example Doc: https://www.u.tools/docs/developer/debug.html Set `main` to a local url for development to achieve hot reload. ```json { "development": { "main": "http://127.0.0.1:8080/index.html" } } ``` ## preload.js https://www.u.tools/docs/developer/preload.html > 当你在 `plugin.json` 中配置了 `preload` 属性,将载入对应的预加载脚本。 > > 在传统的 web 开发中,所有的 javascript 脚本都在浏览器沙盒中运行,权限被严格限制,所能实现的功能非常有限。 > > 通过 `preload.js` 能够帮你突破沙盒限制,进入一个崭新的 JavaScript 世界。 `preload.js` is used to preload script and bypass sandbox limitation. `preload.js` can access `nodejs`, `electron`, `uTools` API. APIs can be plugged into `window` object so that other JS code can access these APIs. ```js // 开发者可以暴露自定义 API 供后加载脚本使用 // preload.js 中使用 nodejs const { readFileSync } = require("fs"); window.readConfig = function () { const data = readFileSync("./config.json"); return data; }; // index.html 后加载的内容可以使用 window.readConfig() 方法,但不能使用 Node.js 特性 console.log(window.readConfig()); // 正常执行 console.log(readFileSync("./config.json")); // 报错 ``` ```js function readFileAsync(filePath, encoding) { return new Promise((resolve, reject) => { require("fs").readFile(filePath, encoding, (error, data) => { if (error) { reject(error); } else { resolve(data); } }); }); } window.services = { readFile: (inputPath, encoding = "utf8") => { return readFileAsync(inputPath, encoding); }, }; ``` `window.services.readFile` get's access to read files beyond the constraint by sandbox. ## Use Third Party Packages > 通过源码方式使用第三方库 > > Through source code Download the library into `/public` ## uTools API This is a wrapper for some common functions. 在插件应用初始化完成时,uTools 会自动在你的 window 对象上挂载 utools 对象。 ```js // 复制单个文件 utools.copyFile("/path/to/file"); // 复制多个文件 utools.copyFile(["/path/to/file1", "/path/to/file2"]); // 路径 utools.copyImage("/path/to/img.png"); // base64 utools.copyImage(""); ``` ### uTools DB API Data persistance. ```js // 创建 utools.db.put({ _id: "demo", data: "demo", }); // 返回 {id: "demo", ok: true, rev: "1-05c9b92e6f24287dc1f4ec79d9a34fa8"} // 更新 utools.db.put({ _id: "demo", data: "demo", _rev: "1-05c9b92e6f24287dc1f4ec79d9a34fa8", }); // 异步方式更新 utools.db.promises.put({ _id: "demo", data: "demo", _rev: "1-05c9b92e6f24287dc1f4ec79d9a34fa8", }); utools.db.get("demo"); // 返回 {_id: "demo", _rev: "3-9836c5c68af5aef618e17d615882942a", data: "demo"} utools.db.remove("demo"); // 返回 {id: "demo", ok: true, rev: "2-effe5dbc23dffc180d8411b23f3108fb"} ``` ### uTools Browser API > uTools browser 简称 ubrowser,是根据 uTools 的特性,量身打造的一个可编程浏览器。利用 ubrowser 可以轻而易举连接一切互联网服务,且与 uTools 完美结合。 ubrowser 拥有优雅的链式调用接口,可以用口语化的数行代码,实现一系列匪夷所思的操作。例如: 1. RPA 自动化脚本 2. 网页魔改 3. 网页抓取 ```js // 打开"必应" 并搜索 "uTools" utools.ubrowser .goto("https://cn.bing.com") .value("#sb_form_q", "uTools") .click("#sb_form_go") .run({ width: 1000, height: 600 }); ``` This is interesting. This should be very simple. The browser window is loaded in a electron window, the API is just a wrapper around DOM APIs. There is also `setCookies(cookies)` and `removeCookies(name)` API. `evaluate(func, ...params)` allows developers to eval JS function. ```js .evaluate((param1, param2) => { return document.querySelector('div').innerText }, 'param1', 'param2') ``` ### uTools Server API > 通过 uTools 的服务端 API,可以将你的应用和 uTools 用户关联,实现帐号互通、接收支付通知、查询用户支付记录等,为保护密钥安全,请仅在服务端调用接口。 APIs for account and payment. Regular API wrapper for web requests, skip. ## 注意事项 1. uTools 插件应用中不受跨域影响,可以访问任意网址。 2. 无需网页考虑兼容性问题,基于(Chromium 91 和 Node 14) 3. 在插件应用开发模式中,可以使用 http 协议加载远程资源( js、css )。当打包成 uTools 插件应用后,所有的静态资源都应该在包内,否则会加载失败。 4. 在打包目录中,请勿包含 `.git` `.js.map` `.css.map` 文件。 ## App Storage On Mac, the app data is stored in `/Users/<user>/Library/Application Support/uTools`. Clipboard data stored in `clipboard-data/1715136702505/data`. The number is the timestamp. In the `data` file, there is encoded (and potentially encrypted clipboard data). Here is the tree structure with 2 layers of folders. ``` . ├── Cache │ └── Cache_Data ├── Code Cache │ ├── js │ └── wasm ├── Cookies ├── Cookies-journal ├── Local Storage │ └── leveldb ├── Network Persistent State ├── Partitions │ └── %3Cutools%3E ├── Preferences ├── SingletonCookie -> 11472625255256702255 ├── SingletonLock -> f4d488789185-8643 ├── SingletonSocket -> /var/folders/f7/7c6q0gh121vdyh86bv192wpc0000gn/T/scoped_dirCsNUE2/SingletonSocket ├── blob_storage │ └── 37646b27-ee51-41e8-a51d-91b911b09c42 ├── clipboard-data │ └── 1715136702505 ├── database │ └── default ├── plugins │ ├── 170c1ee16af97ded0bdde9e7eb60294b.asar │ ├── 5522e367c63f3d5490807c01b442211d.asar │ ├── 668b903f4bcdf240dd228aab904f3892.asar │ ├── 6ee51b94a1ffd0d90edfc1f3c2460f06.asar │ ├── 6ee51b94a1ffd0d90edfc1f3c2460f06.asar.unpacked │ ├── 878f2055a6213f3e8f4c38a8109e077c.asar │ ├── 878f2055a6213f3e8f4c38a8109e077c.asar.unpacked │ ├── 9325e4f7566857c5e4633eb2b1b564fc.asar │ ├── b5a1343f92233a09aa4499f1a3389a12.asar │ ├── b5a1343f92233a09aa4499f1a3389a12.asar.unpacked │ ├── d030e1e61e13bf54f1b393938e80242c.asar │ ├── e332887c9a7b922489ee3dba816901b1.asar │ └── installs └── settings ``` WASM is used, node addons are used. The app is built on Electron.