file-fetch v2.0.0
file-fetch
file-fetch is a nodeify-fetch compatible fetch for read and write access to the local file system using file: URLs and URIs (including
implicit ones using relative paths).
Usage
Read
Reading a file from the file system is as easy as fetching it on the Web.
Call fetch with the URL, and the content is provided as Readable stream in res.body.
The example below uses an absolute URL, but relative paths are also supported.
See the Supported URLs and URIs section for more details.
import fetch from 'file-fetch'
const res = await fetch(new URL('example.js', import.meta.url))
res.body.pipe(process.stdout)It's also possible to handle the content without streams.
The async res.text() method returns the whole content as a string.
import fetch from 'file-fetch'
const res = await fetch(new URL('example.js', import.meta.url))
console.log(await res.text())A similar method res.json() is available to parse JSON content and return the parsed result.
import fetch from 'file-fetch'
const res = await fetch(new URL('example.js', import.meta.url))
console.log(await res.json())Write
Writing content to a file is done with the same function but with the PUT method.
The content must be provided as a string or a Readable stream object.
import fetch from 'file-fetch'
await fetch('file:///tmp/example.log', {
  method: 'PUT',
  body: 'test'
})import fetch from 'file-fetch'
import { Readable } from 'readable-stream'
await fetch('file:///tmp/example.log', {
  method: 'PUT',
  body: Readable.from(['test'])
})Options
file-fetch supports the following non-standard options:
- baseURL: A- stringor- URLused to resolve relative paths and URIs.
- contentType: A- stringor- functionto determine the media type based on the file extension or a fixed value. It can be useful if file extensions or media types not covered by mime-db are required.
Custom fetch with fixed baseURL or contentType lookup
Custom fetch instances can be useful if requests should be processed with relative paths to a directory that is not the current working directory.
The contentType argument can also be predefined for the instance.
The example below shows how to set the baseURL to a relative path of the current script and how to use a custom contentType function: 
import { factory as fetchFactory } from 'file-fetch'
const baseURL = new URL('examples', import.meta.url)
const contentType = ext => ext === 'json' ? 'application/ld+json' : 'application/octet-stream'
const fetch = fetchFactory({ baseURL, contentType })
const res = await fetch('example.js')
const text = await res.text()Supported URLs and URIs
Different styles of URLs and URIs are supported.
Absolute URLs
An absolute URL for a file schema must start with file:///.
No further resolve logic is used.
Example:
file:///home/user/tmp/content.txtURIs
URIs are supported for use cases where a file scheme is required to distinguish identifiers by scheme and if relative paths are required.
The relative paths logic is used to resolve the full URL.
Example:
file:tmp/content.txtRelative paths
Relative paths are resolved with the given baseURL or, if not given, with the working directory.
Example:
tmp/content.txt