2024-12-26 11:56:03 +13:00
/*
* Copyright ( c ) 2024 - 2025 , Shannon Booth < shannon @ serenityos . org >
*
* SPDX - License - Identifier : BSD - 2 - Clause
*/
# pragma once
# include <AK/Array.h>
# include <AK/Optional.h>
# include <AK/String.h>
# include <AK/Types.h>
# include <LibWeb/StorageAPI/StorageType.h>
namespace Web : : StorageAPI {
// https://storage.spec.whatwg.org/#storage-endpoint
//
// A storage endpoint is a local or session storage API that uses the infrastructure defined by this
// standard, most notably storage bottles, to keep track of its storage needs.
struct StorageEndpoint {
// https://storage.spec.whatwg.org/#storage-endpoint-identifier
// A storage endpoint has an identifier, which is a storage identifier.
String identifier ;
// https://storage.spec.whatwg.org/#storage-endpoint-types
// A storage endpoint also has types, which is a set of storage types.
2025-04-07 10:46:22 +00:00
// NOTE: We do not implement this as a set as it is not necessary in the current implementation.
2024-12-26 11:56:03 +13:00
StorageType type ;
// https://storage.spec.whatwg.org/#storage-endpoint-quota
// A storage endpoint also has a quota, which is null or a number representing a recommended quota (in bytes) for each storage bottle corresponding to this storage endpoint.
Optional < u64 > quota ;
static ReadonlySpan < StorageEndpoint > registered_endpoints ( ) ;
} ;
}