/* * * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. * */ (function() { //For browser platform: not all browsers use overrided `resolveLocalFileSystemURL`. function checkBrowser() { if (cordova.platformId === "browser" && require('./isChrome')()) { module.exports.resolveLocalFileSystemURL = window.resolveLocalFileSystemURL || window.webkitResolveLocalFileSystemURL; return true; } return false; } if (checkBrowser()) { return; } var argscheck = require('cordova/argscheck'), DirectoryEntry = require('./DirectoryEntry'), FileEntry = require('./FileEntry'), FileError = require('./FileError'), exec = require('cordova/exec'); var fileSystems = require('./fileSystems'); /** * Look up file system Entry referred to by local URI. * @param {DOMString} uri URI referring to a local file or directory * @param successCallback invoked with Entry object corresponding to URI * @param errorCallback invoked if error occurs retrieving file system entry */ module.exports.resolveLocalFileSystemURL = module.exports.resolveLocalFileSystemURL || function(uri, successCallback, errorCallback) { argscheck.checkArgs('sFF', 'resolveLocalFileSystemURI', arguments); // error callback var fail = function(error) { if (errorCallback) { errorCallback(new FileError(error)); } }; // sanity check for 'not:valid:filename' or '/not:valid:filename' // file.spec.12 window.resolveLocalFileSystemURI should error (ENCODING_ERR) when resolving invalid URI with leading /. if(!uri || uri.split(":").length > 2) { setTimeout( function() { fail(FileError.ENCODING_ERR); },0); return; } // if successful, return either a file or directory entry var success = function(entry) { if (entry) { if (successCallback) { // create appropriate Entry object var fsName = entry.filesystemName || (entry.filesystem && entry.filesystem.name) || (entry.filesystem == window.PERSISTENT ? 'persistent' : 'temporary'); fileSystems.getFs(fsName, function(fs) { // This should happen only on platforms that haven't implemented requestAllFileSystems (windows) if (!fs) { fs = new FileSystem(fsName, {name:"", fullPath:"/"}); } var result = (entry.isDirectory) ? new DirectoryEntry(entry.name, entry.fullPath, fs, entry.nativeURL) : new FileEntry(entry.name, entry.fullPath, fs, entry.nativeURL); successCallback(result); }); } } else { // no Entry object returned fail(FileError.NOT_FOUND_ERR); } }; exec(success, fail, "File", "resolveLocalFileSystemURI", [uri]); }; module.exports.resolveLocalFileSystemURI = function() { console.log("resolveLocalFileSystemURI is deprecated. Please call resolveLocalFileSystemURL instead."); module.exports.resolveLocalFileSystemURL.apply(this, arguments); }; })();