mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-04-27 06:48:49 +00:00
Stub out basic Credential Management APIs and import IDL tests. Spec: https://w3c.github.io/webappsec-credential-management/
52 lines
1.4 KiB
C++
52 lines
1.4 KiB
C++
/*
|
|
* Copyright (c) 2025, Altomani Gianluca <altomanigianluca@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <LibJS/Forward.h>
|
|
#include <LibWeb/Bindings/FederatedCredentialPrototype.h>
|
|
#include <LibWeb/Bindings/PlatformObject.h>
|
|
#include <LibWeb/CredentialManagement/Credential.h>
|
|
|
|
namespace Web::CredentialManagement {
|
|
|
|
class FederatedCredential final : public Credential {
|
|
WEB_PLATFORM_OBJECT(FederatedCredential, Credential);
|
|
GC_DECLARE_ALLOCATOR(FederatedCredential);
|
|
|
|
public:
|
|
[[nodiscard]] static GC::Ref<FederatedCredential> create(JS::Realm&);
|
|
static WebIDL::ExceptionOr<GC::Ref<FederatedCredential>> construct_impl(JS::Realm&, FederatedCredentialInit const&);
|
|
|
|
virtual ~FederatedCredential() override;
|
|
|
|
String const& provider() { return m_provider; }
|
|
Optional<String> const& protocol() { return m_protocol; }
|
|
|
|
String type() override { return "federated"_string; }
|
|
|
|
private:
|
|
explicit FederatedCredential(JS::Realm&);
|
|
virtual void initialize(JS::Realm&) override;
|
|
|
|
String m_provider;
|
|
Optional<String> m_protocol;
|
|
};
|
|
|
|
struct FederatedCredentialRequestOptions {
|
|
Optional<Vector<String>> providers;
|
|
Optional<Vector<String>> protocols;
|
|
};
|
|
|
|
struct FederatedCredentialInit : CredentialData {
|
|
Optional<String> name;
|
|
Optional<String> icon_url;
|
|
String origin;
|
|
String provider;
|
|
Optional<String> protocol;
|
|
};
|
|
|
|
}
|