## Public and Private API ##
_API documentation automatically generated by [docmeteor](https://github.com/raix/docmeteor)._
***
__File: ["fsFile-common.js"](fsFile-common.js) Where: {client|server}__
***
### new *fs*.File([ref])  Anywhere ###
*This method __File__ is defined in `FS`*
__Arguments__
* __ref__ *{object|[FS.File](#FS.File)|[data to attach](#data to attach)}*  (Optional)
 Another FS.File instance, a filerecord, or some data to pass to attachData
> ```FS.File = function(ref, createdByTransform) { ...``` [fsFile-common.js:8](fsFile-common.js#L8)
-
### *fsFile*.attachData(data, [options], [callback])  Anywhere ###
*This method __attachData__ is defined in `prototype` of `FS.File`*
__Arguments__
* __data__ *{[File](#File)|[Blob](#Blob)|Buffer|ArrayBuffer|Uint8Array|String}*  
 The data that you want to attach to the file.
* __options__ *{Object}*  (Optional)
 Options
    * __type__ *{String}*  (Optional)
    The data content (MIME) type, if known.
    * __headers__ *{String}*  (Optional)
    When attaching a URL, headers to be used for the GET request (currently server only)
    * __auth__ *{String}*  (Optional)
    When attaching a URL, "username:password" to be used for the GET request (currently server only)
* __callback__ *{Function}*  (Optional)
 Callback function, callback(error). On the client, a callback is required if data is a URL.
__Returns__  *{FS.File}*
This FS.File instance.
> ```FS.File.prototype.attachData = function fsFileAttachData(data, options, callback) { ...``` [fsFile-common.js:36](fsFile-common.js#L36)
-
### *fsFile*.uploadProgress()  Anywhere ###
*This method __uploadProgress__ is defined in `prototype` of `FS.File`*
__Returns__  *{number}*
The server confirmed upload progress
> ```FS.File.prototype.uploadProgress = function() { ...``` [fsFile-common.js:154](fsFile-common.js#L154)
-
### *fsFile*.controlledByDeps()  Anywhere ###
*This method __controlledByDeps__ is defined in `prototype` of `FS.File`*
__Returns__  *{FS.Collection}*
Returns true if this FS.File is reactive
> Note: Returns true if this FS.File object was created by a FS.Collection
> and we are in a reactive computations. What does this mean? Well it should
> mean that our fileRecord is fully updated by Meteor and we are mounted on
> a collection
> ```FS.File.prototype.controlledByDeps = function() { ...``` [fsFile-common.js:179](fsFile-common.js#L179)
-
### *fsFile*.getCollection()  Anywhere ###
*This method __getCollection__ is defined in `prototype` of `FS.File`*
__Returns__  *{FS.Collection}*
Returns attached collection or undefined if not mounted
> ```FS.File.prototype.getCollection = function() { ...``` [fsFile-common.js:189](fsFile-common.js#L189)
-
### *fsFile*.isMounted()  Anywhere ###
*This method __isMounted__ is defined in `prototype` of `FS.File`*
__Returns__  *{FS.Collection}*
Returns attached collection or undefined if not mounted
> ```FS.File.prototype.isMounted = FS.File.prototype.getCollection;``` [fsFile-common.js:217](fsFile-common.js#L217)
-
### *fsFile*.getFileRecord()  Anywhere ###
*This method __getFileRecord__ is defined in `prototype` of `FS.File`*
__Returns__  *{object}*
The filerecord
> ```FS.File.prototype.getFileRecord = function() { ...``` [fsFile-common.js:224](fsFile-common.js#L224)
-
### *fsFile*.update(modifier, [options], [callback])  Anywhere ###
*This method __update__ is defined in `prototype` of `FS.File`*
__Arguments__
* __modifier__ *{[modifier](#modifier)}*  
* __options__ *{object}*  (Optional)
* __callback__ *{function}*  (Optional)
Updates the fileRecord.
> ```FS.File.prototype.update = function(modifier, options, callback) { ...``` [fsFile-common.js:255](fsFile-common.js#L255)
-
### *fsFile*._saveChanges([what])  Anywhere ###
*This method is private*
*This method ___saveChanges__ is defined in `prototype` of `FS.File`*
__Arguments__
* __what__ *{String}*  (Optional)
 "_original" to save original info, or a store name to save info for that store, or saves everything
Updates the fileRecord from values currently set on the FS.File instance.
> ```FS.File.prototype._saveChanges = function(what) { ...``` [fsFile-common.js:290](fsFile-common.js#L290)
-
### *fsFile*.remove([callback])  Anywhere ###
*This method __remove__ is defined in `prototype` of `FS.File`*
__Arguments__
* __callback__ *{Function}*  (Optional)
__Returns__  *{number}*
Count
Remove the current file from its FS.Collection
> ```FS.File.prototype.remove = function(callback) { ...``` [fsFile-common.js:323](fsFile-common.js#L323)
-
### *fsFile*.moveTo(targetCollection)  Anywhere ###
*This method is private*
*This method __moveTo__ is defined in `prototype` of `FS.File`*
__Arguments__
* __targetCollection__ *{[FS.Collection](#FS.Collection)}*  
__TODO__
```
* Needs to be implemented
```
Move the file from current collection to another collection
> Note: Not yet implemented
> ```FS.File.prototype.getExtension = function(options) { ...``` [fsFile-common.js:364](fsFile-common.js#L364)
-
### *fsFile*.getExtension([options])  Anywhere ###
> __Warning!__
> This method "FS.File.prototype.getExtension" has deprecated from the API
> Use the `extension` getter/setter method instead.
*This method __getExtension__ is defined in `prototype` of `FS.File`*
__Arguments__
* __options__ *{Object}*  (Optional)
    * __store__ *{String}*  (Optional)
     Store name. Default is the original extension.
__Returns__  *{string}*
The extension eg.: `jpg` or if not found then an empty string ''
> ```FS.File.prototype.getExtension = function(options) { ...``` [fsFile-common.js:364](fsFile-common.js#L364)
-
### *fsFile*.isImage([options])  Anywhere ###
*This method __isImage__ is defined in `prototype` of `FS.File`*
__Arguments__
* __options__ *{object}*  (Optional)
    * __store__ *{string}*  (Optional)
    The store we're interested in
Returns true if the copy of this file in the specified store has an image
content type. If the file object is unmounted or doesn't have a copy for
the specified store, or if you don't specify a store, this method checks
the content type of the original file.
> ```FS.File.prototype.isImage = function(options) { ...``` [fsFile-common.js:393](fsFile-common.js#L393)
-
### *fsFile*.isVideo([options])  Anywhere ###
*This method __isVideo__ is defined in `prototype` of `FS.File`*
__Arguments__
* __options__ *{object}*  (Optional)
    * __store__ *{string}*  (Optional)
    The store we're interested in
Returns true if the copy of this file in the specified store has a video
content type. If the file object is unmounted or doesn't have a copy for
the specified store, or if you don't specify a store, this method checks
the content type of the original file.
> ```FS.File.prototype.isVideo = function(options) { ...``` [fsFile-common.js:408](fsFile-common.js#L408)
-
### *fsFile*.isAudio([options])  Anywhere ###
*This method __isAudio__ is defined in `prototype` of `FS.File`*
__Arguments__
* __options__ *{object}*  (Optional)
    * __store__ *{string}*  (Optional)
    The store we're interested in
Returns true if the copy of this file in the specified store has an audio
content type. If the file object is unmounted or doesn't have a copy for
the specified store, or if you don't specify a store, this method checks
the content type of the original file.
> ```FS.File.prototype.isAudio = function(options) { ...``` [fsFile-common.js:423](fsFile-common.js#L423)
-
### *fsFile*.formattedSize({Object}, {String}, {String})  Anywhere ###
*This method __formattedSize__ is defined in `prototype` of `FS.File`*
__Arguments__
* __{Object}__ *{any}*  
 options
* __{String}__ *{any}*  
 [options.store=none,display original file size] Which file do you want to get the size of?
* __{String}__ *{any}*  
 [options.formatString='0.00 b'] The `numeral` format string to use.
__Returns__  *{String}*
The file size formatted as a human readable string and reactively updated.
You must add the `numeral` package to your app before you can use this method.
If info is not found or a size can't be determined, it will show 0.
> ```FS.File.prototype.formattedSize = function fsFileFormattedSize(options) { ...``` [fsFile-common.js:438](fsFile-common.js#L438)
-
### *fsFile*.isUploaded()  Anywhere ###
*This method __isUploaded__ is defined in `prototype` of `FS.File`*
__Returns__  *{boolean}*
True if the number of uploaded bytes is equal to the file size.
> ```FS.File.prototype.isUploaded = function() { ...``` [fsFile-common.js:456](fsFile-common.js#L456)
-
### *fsFile*.hasStored(storeName, [optimistic])  Anywhere ###
*This method __hasStored__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{string}*  
 Name of the store
* __optimistic__ *{boolean}*  (Optional, Default = false)
 In case that the file record is not found, read below
__Returns__  *{boolean}*
Is a version of this file stored in the given store?
> Note: If the file is not published to the client or simply not found:
this method cannot know for sure if it exists or not. The `optimistic`
param is the boolean value to return. Are we `optimistic` that the copy
could exist. This is the case in `FS.File.url` we are optimistic that the
copy supplied by the user exists.
> ```FS.File.prototype.hasStored = function(storeName, optimistic) { ...``` [fsFile-common.js:478](fsFile-common.js#L478)
-
### *fsFile*.getCopyInfo(storeName)  Anywhere ###
> __Warning!__
> This method "FS.File.prototype.getCopyInfo" has deprecated from the API
> Use individual methods with `store` option instead.
*This method __getCopyInfo__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{string}*  
 Name of the store for which to get copy info.
__Returns__  *{Object}*
The file details, e.g., name, size, key, etc., specific to the copy saved in this store.
> ```FS.File.prototype.getCopyInfo = function(storeName) { ...``` [fsFile-common.js:504](fsFile-common.js#L504)
-
### *fsFile*._getInfo([storeName], [options])  Anywhere ###
*This method is private*
*This method ___getInfo__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{String}*  (Optional)
 Name of the store for which to get file info. Omit for original file details.
* __options__ *{Object}*  (Optional)
    * __updateFileRecordFirst__ *{Boolean}*  (Optional, Default = false)
    Update this instance with data from the DB first?
__Returns__  *{Object}*
The file details, e.g., name, size, key, etc. If not found, returns an empty object.
> ```FS.File.prototype._getInfo = function(storeName, options) { ...``` [fsFile-common.js:519](fsFile-common.js#L519)
-
### *fsFile*._setInfo(storeName, property, value, save)  Anywhere ###
*This method is private*
*This method ___setInfo__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{String}*  
 Name of the store for which to set file info. Non-string will set original file details.
* __property__ *{String}*  
 Property to set
* __value__ *{String}*  
 New value for property
* __save__ *{Boolean}*  
 Should the new value be saved to the DB, too, or just set in the FS.File properties?
__Returns__  *{undefined}*
> ```FS.File.prototype._setInfo = function(storeName, property, value, save) { ...``` [fsFile-common.js:544](fsFile-common.js#L544)
-
### *fsFile*.name([value], [options])  Anywhere ###
*This method __name__ is defined in `prototype` of `FS.File`*
__Arguments__
* __value__ *{String|null}*  (Optional)
 If setting the name, specify the new name as the first argument. Otherwise the options argument should be first.
* __options__ *{Object}*  (Optional)
    * __store__ *{Object}*  (Optional, Default = none,original)
     Get or set the name of the version of the file that was saved in this store. Default is the original file name.
    * __updateFileRecordFirst__ *{Boolean}*  (Optional, Default = false)
    Update this instance with data from the DB first? Applies to getter usage only.
    * __save__ *{Boolean}*  (Optional, Default = true)
    Save change to database? Applies to setter usage only.
__Returns__  *{String|undefined}*
If setting, returns `undefined`. If getting, returns the file name.
> ```FS.File.prototype.name = function(value, options) { ...``` [fsFile-common.js:568](fsFile-common.js#L568)
-
### *fsFile*.extension([value], [options])  Anywhere ###
*This method __extension__ is defined in `prototype` of `FS.File`*
__Arguments__
* __value__ *{String|null}*  (Optional)
 If setting the extension, specify the new extension (without period) as the first argument. Otherwise the options argument should be first.
* __options__ *{Object}*  (Optional)
    * __store__ *{Object}*  (Optional, Default = none,original)
     Get or set the extension of the version of the file that was saved in this store. Default is the original file extension.
    * __updateFileRecordFirst__ *{Boolean}*  (Optional, Default = false)
    Update this instance with data from the DB first? Applies to getter usage only.
    * __save__ *{Boolean}*  (Optional, Default = true)
    Save change to database? Applies to setter usage only.
__Returns__  *{String|undefined}*
If setting, returns `undefined`. If getting, returns the file extension or an empty string if there isn't one.
> ```FS.File.prototype.extension = function(value, options) { ...``` [fsFile-common.js:593](fsFile-common.js#L593)
-
### *fsFile*.size([value], [options])  Anywhere ###
*This method __size__ is defined in `prototype` of `FS.File`*
__Arguments__
* __value__ *{Number}*  (Optional)
 If setting the size, specify the new size in bytes as the first argument. Otherwise the options argument should be first.
* __options__ *{Object}*  (Optional)
    * __store__ *{Object}*  (Optional, Default = none,original)
     Get or set the size of the version of the file that was saved in this store. Default is the original file size.
    * __updateFileRecordFirst__ *{Boolean}*  (Optional, Default = false)
    Update this instance with data from the DB first? Applies to getter usage only.
    * __save__ *{Boolean}*  (Optional, Default = true)
    Save change to database? Applies to setter usage only.
__Returns__  *{Number|undefined}*
If setting, returns `undefined`. If getting, returns the file size.
> ```FS.File.prototype.size = function(value, options) { ...``` [fsFile-common.js:618](fsFile-common.js#L618)
-
### *fsFile*.type([value], [options])  Anywhere ###
*This method __type__ is defined in `prototype` of `FS.File`*
__Arguments__
* __value__ *{String}*  (Optional)
 If setting the type, specify the new type as the first argument. Otherwise the options argument should be first.
* __options__ *{Object}*  (Optional)
    * __store__ *{Object}*  (Optional, Default = none,original)
     Get or set the type of the version of the file that was saved in this store. Default is the original file type.
    * __updateFileRecordFirst__ *{Boolean}*  (Optional, Default = false)
    Update this instance with data from the DB first? Applies to getter usage only.
    * __save__ *{Boolean}*  (Optional, Default = true)
    Save change to database? Applies to setter usage only.
__Returns__  *{String|undefined}*
If setting, returns `undefined`. If getting, returns the file type.
> ```FS.File.prototype.type = function(value, options) { ...``` [fsFile-common.js:643](fsFile-common.js#L643)
-
### *fsFile*.updatedAt([value], [options])  Anywhere ###
*This method __updatedAt__ is defined in `prototype` of `FS.File`*
__Arguments__
* __value__ *{String}*  (Optional)
 If setting updatedAt, specify the new date as the first argument. Otherwise the options argument should be first.
* __options__ *{Object}*  (Optional)
    * __store__ *{Object}*  (Optional, Default = none,original)
     Get or set the last updated date for the version of the file that was saved in this store. Default is the original last updated date.
    * __updateFileRecordFirst__ *{Boolean}*  (Optional, Default = false)
    Update this instance with data from the DB first? Applies to getter usage only.
    * __save__ *{Boolean}*  (Optional, Default = true)
    Save change to database? Applies to setter usage only.
__Returns__  *{String|undefined}*
If setting, returns `undefined`. If getting, returns the file's last updated date.
> ```FS.File.prototype.updatedAt = function(value, options) { ...``` [fsFile-common.js:668](fsFile-common.js#L668)
***
__File: ["fsFile-server.js"](fsFile-server.js) Where: {server}__
***
### *fsFile*.logCopyFailure(storeName, maxTries)  Server ###
```
Notes a details about a storage adapter failure within the file record
```
*This method __logCopyFailure__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{string}*  
* __maxTries__ *{number}*  
__Returns__  *{undefined}*
__TODO__
```
* deprecate this
```
> ```FS.File.prototype.logCopyFailure = function(storeName, maxTries) { ...``` [fsFile-server.js:8](fsFile-server.js#L8)
-
### *fsFile*.failedPermanently(storeName)  Server ###
```
Has this store permanently failed?
```
*This method __failedPermanently__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{String}*  
 The name of the store
__Returns__  *{boolean}*
Has this store failed permanently?
__TODO__
```
* deprecate this
```
> ```FS.File.prototype.failedPermanently = function(storeName) { ...``` [fsFile-server.js:41](fsFile-server.js#L41)
-
### *fsFile*.createReadStream([storeName])  Server ###
*This method __createReadStream__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{String}*  (Optional)
__Returns__  *{stream.Readable}*
Readable NodeJS stream
Returns a readable stream. Where the stream reads from depends on the FS.File instance and whether you pass a store name.
If you pass a `storeName`, a readable stream for the file data saved in that store is returned.
If you don't pass a `storeName` and data is attached to the FS.File instance (on `data` property, which must be a DataMan instance), then a readable stream for the attached data is returned.
If you don't pass a `storeName` and there is no data attached to the FS.File instance, a readable stream for the file data currently in the temporary store (`FS.TempStore`) is returned.
> ```FS.File.prototype.createReadStream = function(storeName) { ...``` [fsFile-server.js:62](fsFile-server.js#L62)
-
### *fsFile*.createWriteStream([storeName])  Server ###
*This method __createWriteStream__ is defined in `prototype` of `FS.File`*
__Arguments__
* __storeName__ *{String}*  (Optional)
__Returns__  *{stream.Writeable}*
Writeable NodeJS stream
Returns a writeable stream. Where the stream writes to depends on whether you pass in a store name.
If you pass a `storeName`, a writeable stream for (over)writing the file data in that store is returned.
If you don't pass a `storeName`, a writeable stream for writing to the temp store for this file is returned.
> ```FS.File.prototype.createWriteStream = function(storeName) { ...``` [fsFile-server.js:100](fsFile-server.js#L100)
-
### *fsFile*.copy()  Server ###
*This method __copy__ is defined in `prototype` of `FS.File`*
__Returns__  *{FS.File}*
The new FS.File instance
> ```FS.File.prototype.copy = function() { ...``` [fsFile-server.js:126](fsFile-server.js#L126)