cloud-filter 0.0.5

A safe and idiomatic wrapper around the Windows Cloud Filter API
Documentation
<div align="center">
  <h1><code>cloud-filter</code></h1>
  <p><strong>Windows Cloud Sync</strong></p>
  <p>
    <a href="https://docs.rs/cloud-filter/"><img src="https://img.shields.io/docsrs/cloud-filter" alt="docs" /></a>
    <a href="https://crates.io/crates/cloud-filter"><img src="https://img.shields.io/crates/v/cloud-filter" alt="crates" /></a>
  </p>
</div>

> This is a fork of [wincs](https://github.com/ok-nick/wincs), thanks for [ok-nick](https://github.com/ok-nick)'s great work.

`cloud-filter` is a safe and idiomatic wrapper around the native [Windows Cloud Filter API](https://docs.microsoft.com/en-us/windows/win32/cfapi/build-a-cloud-file-sync-engine). The Cloud Filter API enables developers to implement their own remote file system from within user space. It is much like [FUSE](#why-not-fuse), although it contains many first-class Windows features that are only available through its API.
For example:

* [Placeholder files](#what-are-placeholders)
    * Partial files
    * Full files
    * Pinned files
* Built into the native File Explorer
    * Shown in the navigation pane at the uppermost level
    * Group sync engines as siblings
    * Register/unregister and connect/disconnect sync engines
        * Register to the File Explorer
        * Connect your file operation handlers
    * Custom name tag and icon
    * Automatic/custom hydration state icons
    * Progress indication
        * File dialog
        * Inline next to file in the File Explorer
        * A file toast if the user did not explicitly hydrate the placeholder
    * Thumbnails and metadata
    * Top-level context menu actions (even on Windows 11)
* Block specific apps from hydrating placeholders from Windows settings
* Automatically free space via Windows Storage Sense
* Monitor and filter file operations
* Declare a wide variety of supported file properties
* Files are cached to the disk (if set), allowing for offline access
* TODO: There is also a new API for custom UI, IStorageProviderStatusUISource

As of right now, the Cloud Filter API is used in production by OneDrive, Google Drive, Dropbox, and many other clients.

## Examples

Below is a simple snippet of implementing a sync engine. For more, in-depth examples, please check out the [examples directory](https://github.com/ho-229/cloud-filter/tree/main/examples).

## FAQ

### Why not FUSE?
Unfortunately, FUSE is only implemented for Unix-like operating systems. Luckily, there are numerous alternatives for implementing file systems on Windows, such as `dokany` or `winfsp`.

#### Why not `dokany`?

`dokany` has a Rust API and is accessible using safe code. However, it is fairly low-level and does not have the first-class capabilities supported by `cloud-filter`.

#### Why not `winfsp`?

Unlike `dokany`, `winfsp` currently does not have a Rust API. Perhaps at some point it may, but even so, it is impossible to have the first-class features supported by `cloud-filter`.

### What are placeholders?

Placeholders are internally [NTFS sparse files](https://docs.microsoft.com/en-us/windows/win32/fileio/sparse-files) and some [reparse point magic](https://docs.microsoft.com/en-us/windows/win32/cfapi/build-a-cloud-file-sync-engine#compatibility-with-applications-that-use-reparse-points). To put it simple, they are empty files that are meant to represent real files, although are not backed by any allocation unless requested. The way they work is heavily dependent on the sync engines' configuration. Know that if a process were to read the content of the placeholder, it would be "hydrated" (its file contents would be allocated). For more information, read [here](https://docs.microsoft.com/en-us/windows/win32/cfapi/build-a-cloud-file-sync-engine). 
 
### I know `cloud-filter` is maintained, but does Microsoft maintain the Cloud Filter API?

Of course, it is used by Microsoft's very own OneDrive Client. I have reported numerous issues and received quick feedback via the [Microsoft Q&A](https://docs.microsoft.com/en-us/answers/search.html?c=7&includeChildren=false&type=question&redirect=search%2Fsearch&sort=newest&q=cfapi). There are a lot of undocumented and unimplemented portions of the API, although they are not necessary for the features described.

### Why is `cloud-filter` only for remote files?

You are more than welcome to use it for local files, although the extra features may not suit your needs. It is recommended to instead use [ProjFS](https://docs.microsoft.com/en-us/windows/win32/projfs/projected-file-system), of which is also backed by Microsoft, but dedicated to "high-speed backing data stores."

## Additional Resources

If you are looking to contribute or want a deeper understanding of `cloud-filter`, be sure to check out these resources:
* [Build a Cloud Sync Engine that Supports Placeholder Files](https://docs.microsoft.com/en-us/windows/win32/cfapi/build-a-cloud-file-sync-engine)
* [Integrate a Cloud Storage Provider](https://docs.microsoft.com/en-us/windows/win32/shell/integrate-cloud-storage)
* [Microsoft Q&A Containing "cfapi"](https://docs.microsoft.com/en-us/answers/search.html?c=7&includeChildren=false&type=question&redirect=search%2Fsearch&sort=newest&q=cfapi)
* [Win32 API](https://docs.microsoft.com/en-us/windows/win32/cfapi/cloud-filter-reference)
* [UWP API](https://docs.microsoft.com/en-us/uwp/api/windows.storage.provider?view=winrt-22621)
    * Not all classes in the `Windows.Storage.Provider` namespace are used by cloud providers.