Files and filesystems
Virtual filesystems and how to use them
CheerpX implements UNIX-style virtual filesystems with multiple mount points, providing a flexible and secure way to manage files and data in your web-based Linux environment:
Filesystem Type | Description | Write | Read |
---|---|---|---|
WebDevice | HTTP-based filesystem for loading files from web server | No | Yes |
IDBDevice | Persistent read-write filesystem using IndexedDB | Yes | Yes |
DataDevice | In-memory filesystem for temporary data storage | Yes | Yes |
HttpBytesDevice | A block device with a Linux filesystem inside (ext2) | No | Yes |
OverlayDevice | A writable persistent overlay on another block device | Yes | Yes |
Virtual EnvironmentCheerpX provides access to a virtualized filesystem environment, which does not correspond to the local user’s computer. Direct access to local files is restricted due to browser security constraints.
WebDevice
WebDevice is a read-only, HTTP-based filesystem in CheerpX. It’s primarily used for accessing files from your web server.
Usage
To create a WebDevice, use the CheerpX.WebDevice.create()
method:
This will mount the specified directory at /web
in the CheerpX filesystem. To enable listing the directory contents, CheerpX looks for an index.list
file in the directory and any subdirectories. This file should contain a newline-separated list of all files and subdirectories within the directory.
Why use an index.list
file?
The index.list
file enables CheerpX to provide directory listing functionality in its WebDevice. Since HTTP does not have native support for file listing, index.list
is essential for managing and accessing files effectively.
Creating an index.list
file
To generate an index.list
in every directory without including it in the directory listing, use the following command:
Explanation:
-
find . -type d
: finds all directories starting from the current directory (.
). -
-exec sh -c
: executes the following shell commands for each directory found. -
ls "{}" > "{}"/.index.list
: lists the directory contents and saves it to.index.list
. -
&& mv "{}"/.index.list "{}"/index.list
: renames.index.list
toindex.list
in the same directory.
WarningBe careful when using this command. It will overwrite any existing index.list files in every directory it processes. Ensure you run it only in the intended directory and back up any important data before execution. Misuse in the wrong directory could cause unintentional data loss.
Accessing files
Files in the WebDevice are accessed relative to the current page’s URL. For example, if your current page is https://host/dir1/dir2/page.html
, then:
/web/example.txt
would correspond tohttps://host/dir1/dir2/path/to/local/directory/example.txt
/web/images/logo.png
would correspond tohttps://host/dir1/dir2/path/to/local/directory/images/logo.png
NoteIt’s important to note that this behavior depends on the current page’s URL, as it uses a relative path. For more predictable results, it’s recommended to use absolute paths when possible.
IDBDevice
IDBDevice provides a persistent, read-write filesystem using the browser’s IndexedDB. It’s ideal for storing data that should persist between sessions.
Usage
Create an IDBDevice using the CheerpX.IDBDevice.create()
method:
This setup creates a virtual filesystem at /files
that is backed by IndexedDB.
Reading files from JavaScript
You can read files from an IDBDevice
in JavaScript using the readFileAsBlob
method:
idbDevice.readFileAsBlob
CheerpX.IDBDevice
provides a method to read back files as JavaScript accessible data.
Parameters:
- filename: A string representing the path to the file within the device, starting with a
/
(e.g., “/filename”). Do not include the mount point.
Returns:
The method returns a Promise that resolves to a standard JavaScript Blob object.
Example:
NoteThe readFileAsBlob API returns a standard JavaScript Blob object. You can convert it to a string if needed, but you can also convert it to an ArrayBuffer or to a URL via URL.createObjectURL.
DataDevice
DataDevice
is an in-memory filesystem useful for temporary data storage or passing data from JavaScript to the CheerpX environment.
Usage
Create a DataDevice using the CheerpX.DataDevice.create()
method:
Adding files
You can add files to a DataDevice from JavaScript using the writeFile
method:
dataDevice.writeFile
CheerpX.DataDevice
provides a method to write data to new files within the mounted device. This utility is limited to creating files at the root level of the device.
Parameters:
- filename: A string representing the path to the file within the device, starting with a
/
(e.g., “/filename”). Do not include the mount point. - contents: The data to write to the file. Can be either a string or a Uint8Array.
Returns:
The method returns a Promise that resolves when the file has been created and written to. It doesn’t return any value.
Example:
Note
- This is the only way to create files in this device.
- Modifying existing files or creating files in subdirectories is not possible.
Block devices with ext2
CheerpX supports ext2 filesystems, which can be configured as an overlay device. This allows for a flexible setup that can combine different storage types.
Usage
Create an ext2 filesystem by combining a HttpBytesDevice
to acess disk blocks, an IDBDevice
to cache and persist data and a OverlayDevice
to combine the two.
This setup creates an ext2 filesystem that loads its initial data from an HTTP source and uses IndexedDB for persistent storage of changes.
Device configuration options
CheerpX supports various types of devices that can be used in the OverlayDevice configuration:
- HttpBytesDevice: The default choice for loading filesystem images via HTTP. Suitable for most web-hosted files.
- GitHubDevice: Ideal for projects forked from the WebVM repository. The Integrated GitHub Action will take care of preparing disk chunks for efficient access.
- OverlayDevice:
OverlayDevice
supports chaining, making it possible to efficiently “fork” disk images while only storing the changes from previous versions.
Best practices
- Use WebDevice for read-only access to server-side files.
- Utilize IDBDevice for persistent storage of user data or application state.
- Employ DataDevice for temporary storage or passing data between JavaScript and CheerpX.
- Consider ext2 filesystems for more complex file operations or when you need a traditional Linux filesystem structure.
By leveraging these different filesystem types, you can create a flexible and efficient file management system within your CheerpX-powered web application.