<!doctype html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1" /> <link rel="stylesheet" href="../style.css" type="text/css" /> <title>Links</title> <script type="text/javascript"> function findLang(){ let href = location.href; for(let i=href.length-1;i>0;i--){ if('/'==href.charAt(i) && '/'==href.charAt(i-3)) return i; } return 0; } function nav2(page){ let i = findLang(); location.href = location.href.substring(0,i+1)+page; } function nav2Lang(lang){ let i = findLang(); let href = location.href; location.href = location.href.substring(0,i-2)+lang+location.href.substring(i); } </script> </head> <body> <header class='header'> <a class="logo" href="javascript:void(0)" onclick="return nav2('index.html')">Home</a> <a class="logo" href="javascript:void(0)" onclick="return nav2('tags/index.html')">Tags</a> <a class="logo" href="javascript:void(0)" onclick="return nav2Lang('zh')">简体中文</a> <nav> </nav> </header> <br /> <div class="container"> <h1 class="title">Links <br> <span class="subtitle"></span> </h1> <ul class="tags"> </ul> <p>Click the following links to install menus popped by long pressing the bookmark button (with star as icon):<br> <a href="i:0gdefault.link::More bookmarks:file:///data/data/info.torapp.uweb/files/bookmark/ {let as=document.getElementsByTagName('a');for(let i=as.length-1;i>=0;i--){let h=as[i].href;if(h.startsWith('file:')&&h.endsWith('.html'))as[i].href=h.substring(0,h.length-4)%2B'search';}}%0A">Classified bookmarks</a></p> <p><a href="i:0gdefault.link::vpn:i:1dandroid.net.vpn.SETTINGS:::%0A">VPN</a></p> <p><a href="i:0gdefault.link::profile_config::cprofile . files .conf%0A">Switch configuration</a></p> <p><a href="i:0gdefault.link::Wait msg:i:1w%0A">Wait for network msg</a></p> <p><a href="i:0gdefault.link::Certificate info:i:1c%0A">Certificate info</a></p> <p><a href="i:0gdefault.link::Backup2Box: {let path=`%f`;let iSlash=path.lastIndexOf('/',path.length-2);let f;if('/'!=path[path.length-1])f=path.substring(iSlash+1);else f=path.substring(iSlash+1,path.length-1);location.href='i:0e'+path+':https://dav.box.com/dav/'+f+'.tgz';}%0A">Backup to box.com</a></p> <p><a href="i:0gdefault.link::restoreFromBox: {let path=`%f`;let iSlash=path.lastIndexOf('/',path.length-2);let f;if('/'!=path[path.length-1])f=path.substring(iSlash+1);else f=path.substring(iSlash+1,path.length-1);location.href='i:0dhttps://dav.box.com/dav/'+f+'.tgz';}%0A">Restore from box.com</a></p> <p><a href="i:0gdefault.link::up2Box: {let path=`%f`;let iSlash=path.lastIndexOf('/',path.length-2);let f;if('/'!=path[path.length-1])f=path.substring(iSlash+1);else f=path.substring(iSlash+1,path.length-1)+'.tgz';location.href='i:0u'+path+':https://dav.box.com/dav/'+f;}%0A">upload to box.com</a></p> <p><a href="../searchurl/webdav.html">More webdav link menu items</a></p> <p><a href="i:0gdefault.link::web fullscreen: location.href='i:5fsetTimeout(()=>document.documentElement.requestFullscreen(),50);';%0A">Web fullscreen</a></p> <p>Long pressing the bookmark button in <a href="../index.html">uweb browser</a> will popup menus defined in file "default.link". The file format is as follows:<br> [Menu name]:[one or more links delimited by " \n "]</p> <p>and each link has the following format:<br> [url][space][javascript code]</p> <p>in which space and later parts are optional. url and later parts support <a href="../cmd/index.html">"%u","%s" etc.</a>. The javascript code will be executed after url is fully loaded.</p> <p>url supports all standard scheme (http(s):,javascript: etc.) and uweb internal schemes ( ':' as second character in the url ) and special links that begins with ':'.</p> <p>uweb browser will handle local file urls (file:///) specially for some file types:</p> <ul> <li>.js file(same as <a href="../longclick/index.html">long pressing hypertext to execute js file</a>): If the ".js" file begins with "//", then uweb browser will load the site following "//" and execute the following js code.</li> </ul> <p><a href="../gesture/index.html">default.gesture</a> and default.button have the exactly same file format. ".gesture" files define gestures while ".button" define bottom toolbar button pressing actions from the last button to the first.</p> <p>proxy config:<br> httpproxy::010[proxy host]:[port]<br> socks5::011[socks host]:[port]<br> noproxy::010:</p> <h3 id="special-links-beginning-with-">special links beginning with ':'</h3> <ul> <li> <p>:0000<br> Extend cookie expiracy to 70 years, may be denied by server.</p> </li> <li> <p>:0003<br> Toggle fullscreen mode</p> </li> <li> <p>:0004<br> Rotate the screen</p> </li> <li> <p>:001[fileurl]<br> Scan the fileurl and add it to media storage</p> </li> <li> <p>:002[url]<br> Show the secure cookie</p> </li> <li> <p>:010[proxy host]:[port]<br> Config http proxy, ":010:" to disable any proxy.</p> </li> <li> <p>:011[socks host]:[port]<br> Socks proxy</p> </li> </ul> <h4 id="commands">commands</h4> <ul> <li> <p>:![command line]<br> The command line could be a ".js", ".sh" or other executable with arguments. Ex. ":!s g keyword" could invoke "s.js" executable with the whole string as arguments ("s.sh" or "s" if file exists, here "g" as google search engine); ":! g keyword" would invoke the file ".js" or ".sh" as executable.</p> <p>For regular (non-js) executables, the standard output of the command line will be treated as lines of web urls.</p> <p><a href="i:0hs.sh:../searchurl/txt/web.sh">Click to install the example file "s.sh"</a><br> <a href="i:0h.js:../searchurl/txt/web.js">Click to install the example file ".js"</a></p> </li> <li> <p>:c[command]</p> <ul> <li>close<br> ":cclose" to close the current window/tab.</li> <li>profile [parent folder] [file/folder] [optional ID]<br> Ex. ":cprofile . files" to switch configurations</li> </ul> </li> <li> <p>:p [width in milliInch]x[height] [top margin]:[right margin]:[bottom margin]:[left margin]<br> Generate/Print PDF file in the "/sdcard/Download" folder, all units are milliinch.<br> Ex. ":p x" or ":px" for screen width and infinite height (as long vector screenshot).<br> ":p x[height]" or ":px[height]" for screen width.</p> </li> </ul> <h3 id="i-internal-links">"i:" internal links:</h3> <ul> <li> <p>i:0b[path]:[url]<br> Extract remote content (tar/tgz/zip) under the folder [path]. If [path] ends with "/", then put unzipped file under the folder "[path]/[file name stem]" (for zipped files only, not for tar/tgz).</p> </li> <li> <p>i:0m[bookmarklet index|prefix|?postfix|/.../localfile|c[cssFlag]]:[url]<br> Visiting url and execute the uweb browser internal bookmarklet that keeps valid for all urls under the path of [url].</p> <ul> <li>[bookmarklet index] must have two/three digits. The first two digits are used as index of bootmarklet. For example, "00" as the first local bookmarklet; "01" as the first remote script; then "02" as the second local bookmarklet, ... The third digit is uplevel, 1 to make bookmarklet valid for parent path of [url].</li> <li>c[cssFlag]: For example, "c12" will apply the third and fourth global CSS (12=2^2+2^3).</li> <li>[?postfix]: the real visited url is "[url]+[?postfix]".</li> <li>[/.../localfile]: load the local html/js file that processes [url]. The first character of the local html file must be "<".</li> <li>All other cases will be treated as [prefix], the real visited url is "[prefix]+[url]".</li> </ul> </li> <li> <p>i:15[string]<br> Set address bar text to be [string].</p> </li> <li> <p>i:16[mimetype]:[Action Name]:[App Name]:[Activity Name]<br> Use third party app as input</p> </li> <li> <p>i:18[extended mimetype]:[range]:[url]<br> Read partial data from url.<br> <range>: the format is same as related http header, such as "500-1000,-300".<br> <extended mimetype>: standard mimetype or mimetype followed by ".<filename>". In the later case, the file in uweb configuration folder will be appended to the fetched data.</p> </li> <li> <p>i:19[string]<br> Append [string] to the address bar text.</p> </li> <li> <p>i:1c<br> Show web certificate.</p> </li> <li> <p>i:1d<action>:<type>:<Category>:<data><br> Launch app for specific <action>.</p> </li> <li> <p>i:1w<br> Wait to receive url from the network and open the url.</p> </li> <li> <p>i:1w1<br> Wait to receive url from the network and open the url (not showing ip)</p> </li> <li> <p>i:1e<br> Open file manager for removable SDCARD download folder</p> </li> <li> <p>i:50[path]:[string]<br> Save [string] as file</p> </li> <li> <p>i:51[path]:[url]<br> Save [url] to ".autoc" file.</p> </li> <li> <p>i:52[path]:[url]<br> Save bookmark.</p> </li> <li> <p>i:53[path]:[string]<br> Save notes.</p> </li> <li> <p>i:54[path]:[url]<br> Save as search engine.</p> </li> <li> <p>i:55[path]:[url]<br> Save as link.</p> </li> <li> <p>i:56[string]<br> Use [string] as user input on web page.</p> </li> <li> <p>i:57[jscode]<br> execute [jscode], even when js is disabled for the web page.</p> </li> <li> <p>i:58[url]<br> Save to the desktop.</p> </li> <li> <p>i:5a[filename]<br> Receive content from network to the file.</p> </li> <li> <p>i:5b[string]<br> Copy [string] to the clipboard.</p> </li> <li> <p>i:5c[url]<br> Change auto page turning internal url to be [url].</p> </li> <li> <p>i:5d[file url]<br> Open the file url compatible to other browsers.</p> </li> <li> <p>i:5e[string]<br> TTS</p> </li> <li> <p>i:5f[videourl]<br> play video fullscreen. if videourl is empty, then make following requestFullscreen() work.</p> </li> <li> <p>i:5h[?postfix:|/regex/replacement:][url]<br> force html for [url] visiting</p> <ul> <li>[?postfix:] : the real url visited is "[url]+[?postfix]"</li> <li>[/regex/replacement:]: execute regular expression replacement for the "[url]", then visit the resulting url.</li> </ul> </li> <li> <p>i:5i[url]<br> Use the existing tab for the url with possible different url hash part.</p> </li> <li> <p>i:5j[string]<br> if [string] is file url, then send the file/folder to network, otherwise send [string] to network.</p> </li> <li> <p>i:5p[videourl]<br> play video in external player</p> </li> <li> <p>i:60[path]:[url]<br> If existing local file, then open it or visit the [url].</p> </li> <li> <p>i:62[path]:[js code]<br> Evaluate the [js code] and save the returned string to file.</p> </li> <li> <p>i:63[bookmarklet index]:[url]<br> Visiting url and execute the bookmarklet. Only uweb predefined local bookmarlets are allowed.</p> </li> <li> <p>i:6i[js file path relative to configuration folder]:[url]<br> Similar to i:5i, except executing the js file after possible url hash change.</p> </li> <li> <p>i:70[url]:[auto page turning url]<br> Visiting [url], but use the second url as auto paging url.</p> </li> </ul> </div> </body> </html>