From 5be66d3cf19506aa155bbdb4b27b50033b841ac9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kr=C3=A6n=20Hansen?= Date: Fri, 23 Aug 2024 12:17:05 +0200 Subject: [PATCH] Updated bindgen spec and helpers --- bindgen/spec.yml | 626 +----------------------------------- bindgen/src/bound-model.ts | 60 +--- bindgen/src/realm_helpers.h | 81 ----- 3 files changed, 3 insertions(+), 764 deletions(-) diff --git a/bindgen/spec.yml b/bindgen/spec.yml index 91fac6394fa..6190d0e870b 100644 --- a/bindgen/spec.yml +++ b/bindgen/spec.yml @@ -1,8 +1,6 @@ # yaml-language-server: $schema=generated/spec.schema.json headers: - - "realm/sync/config.hpp" - - "realm/sync/subscriptions.hpp" - "realm/status.hpp" - "realm/object-store/shared_realm.hpp" - "realm/object-store/object_store.hpp" @@ -13,15 +11,6 @@ headers: - "realm/object-store/collection_notifications.hpp" - "realm/object-store/impl/object_notifier.hpp" - "realm/object-store/impl/realm_coordinator.hpp" - - "realm/object-store/sync/async_open_task.hpp" - - "realm/object-store/sync/app_credentials.hpp" - - "realm/object-store/sync/generic_network_transport.hpp" - - "realm/object-store/sync/app.hpp" - - "realm/object-store/sync/sync_manager.hpp" - - "realm/object-store/sync/sync_session.hpp" - - "realm/object-store/sync/sync_user.hpp" - - "realm/object-store/sync/app_user.hpp" - - "realm/object-store/sync/mongo_collection.hpp" - "realm/util/bson/bson.hpp" primitives: @@ -81,9 +70,6 @@ templates: # value tells you how many arguments it takes ('*' means any number) std::map: 2 util::UniqueFunction: 1 std::function: 1 - AsyncCallback: 1 # same as UniqueFunction, but guaranteed to be called exactly once. - # Recommended to convert to Future/Promise/Task in bound language. - AsyncResult: 1 # Synthetic type. Not used in spec, but created by utilities. Nullable: 1 # By default most types in the spec are assumed to be non-null. This marks those that are nullable. IgnoreArgument: 1 @@ -200,40 +186,6 @@ enums: TypedLink: 16 UUID: 17 - AuthProvider: - cppName: app::AuthProvider - values: - - ANONYMOUS - - ANONYMOUS_NO_REUSE - - FACEBOOK - - GOOGLE - - APPLE - - CUSTOM - - USERNAME_PASSWORD - - FUNCTION - - API_KEY - - AppCacheMode: - cppName: app::App::CacheMode - values: - - Enabled - - Disabled - - ClientResetMode: - cppName: ClientResyncMode - values: - - Manual - - DiscardLocal - - Recover - - RecoverOrDiscard - - MetadataMode: - cppName: app::AppConfig::MetadataMode - values: - - NoEncryption - - Encryption - - InMemory - LoggerLevel: cppName: util::Logger::Level values: @@ -247,91 +199,6 @@ enums: - fatal - off - HttpMethod: - cppName: app::HttpMethod - values: - - get - - post - - patch - - put - - del - - SyncSessionStopPolicy: - values: - - Immediately - - LiveIndefinitely - - AfterChangesUploaded - - SyncSessionState: - cppName: SyncSession::State - values: - - Active - - Dying - - Inactive - - WaitingForAccessToken - - SyncSessionConnectionState: - cppName: SyncSession::ConnectionState - values: - - Disconnected - - Connecting - - Connected - - SyncErrorAction: - cppName: sync::ProtocolErrorInfo::Action - values: - - NoAction - - ProtocolViolation - - ApplicationBug - - Warning - - Transient - - DeleteRealm - - ClientReset - - ClientResetNoRecovery - - SyncFileAction: - cppName: SyncFileAction - values: - - DeleteRealm - - BackUpThenDeleteRealm - - ProgressDirection: - cppName: SyncSession::ProgressDirection - values: - - upload - - download - - SyncUserState: - cppName: SyncUser::State - values: - - LoggedOut - - LoggedIn - - Removed - - SyncSubscriptionSetState: - cppName: sync::SubscriptionSet::State - values: - - Uncommitted - - Pending - - Bootstrapping - - Complete - - Error - - Superseded - - AwaitingMark - - WatchStreamState: - cppName: app::WatchStream::State - values: - - NEED_DATA - - HAVE_EVENT - - HAVE_ERROR - - ProxyType: - cppName: SyncConfig::ProxyConfig::Type - values: - - HTTP - - HTTPS - # These types are handled specially. They must be structs with a single fields named "value". keyTypes: ColKey: int64_t @@ -443,11 +310,6 @@ records: disable_format_upgrade: type: bool default: false - sync_config: Nullable> - # Used internally as a flag for opening a synced realm locally. - force_sync_history: - type: bool - default: false # Unclear if migration_function and initialization_function should be marked as off_thread. # Existing JS sdk treats them as not. migration_function: 'Nullable) -> void>>' @@ -457,74 +319,6 @@ records: type: bool default: false - UserIdentity: - cppName: app::UserIdentity - fields: - id: - type: std::string - provider_type: - type: std::string - - UserAPIKey: - cppName: app::App::UserAPIKey - fields: - id: - type: ObjectId - key: - type: std::optional - name: - type: std::string - disabled: - type: bool - - SyncProxyConfig: - cppName: SyncConfig::ProxyConfig - fields: - address: std::string - port: PortType - type: ProxyType - - SyncConfig: - fields: - user: SharedSyncUser - partition_value: - type: std::string - default: "" - stop_policy: - type: SyncSessionStopPolicy - default: AfterChangesUploaded - flx_sync_requested: - type: bool - default: false - error_handler: 'Nullable void>>' - custom_http_headers: - type: 'std::map' - default: {} - client_validate_ssl: - type: bool - default: true - ssl_trust_certificate_path: std::optional - ssl_verify_callback: Nullable - client_resync_mode: - type: ClientResetMode - default: ClientResyncMode::Manual; - notify_before_client_reset: 'Nullable void>>' - notify_after_client_reset: 'Nullable void>>' - cancel_waits_on_nonfatal_error: - type: bool - default: false - proxy_config: std::optional - - SyncSubscription: - cppName: sync::Subscription - fields: - id: ObjectId - created_at: Timestamp - updated_at: Timestamp - name: std::optional - object_class_name: std::string - query_string: std::string - ObjectChangeSet: fields: is_deleted: bool @@ -561,145 +355,6 @@ records: before_notify: 'Nullable>' schema_did_change: 'Nullable>' # new schema available as r.schema - ResumptionDelayInfo: - cppName: sync::ResumptionDelayInfo - fields: - max_resumption_delay_interval: - type: std::chrono::milliseconds - default: 3000000 - resumption_delay_interval: - type: std::chrono::milliseconds - default: 1000 - resumption_delay_backoff_multiplier: - type: int - default: 2 - delay_jitter_divisor: - type: int - default: 4 - - SyncClientTimeouts: - fields: - connect_timeout: - type: uint64_t - default: 120000 - connection_linger_time: - type: uint64_t - default: 30000 - ping_keepalive_period: - type: uint64_t - default: 60000 - pong_keepalive_timeout: - type: uint64_t - default: 120000 - fast_reconnect_limit: - type: uint64_t - default: 60000 - reconnect_backoff_info: - type: ResumptionDelayInfo - default: {} - - SyncClientConfig: - fields: - logger_factory: Nullable - log_level: - type: LoggerLevel - default: LoggerLevel::info - # reconnect_mode is probably internal-only - multiplex_sessions: - type: bool - default: false - user_agent_binding_info: - type: std::string - default: "" - user_agent_application_info: - type: std::string - default: "" - timeouts: - type: SyncClientTimeouts - default: {} - - SyncError: - fields: - status: Status - is_fatal: bool - simple_message: StringData - logURL: StringData - user_info: std::unordered_map - is_unrecognized_by_client: - type: bool - default: false - is_client_reset_requested: - type: bool - cppName: is_client_reset_requested() - server_requests_action: - type: SyncErrorAction - default: NoAction - # server_requests_action: - # type: sync::ProtocolErrorInfo::Action - # default: sync::ProtocolErrorInfo::Action::NoAction - compensating_writes_info: std::vector - - Request: - cppName: app::Request - fields: - method: HttpMethod - url: std::string - timeout_ms: uint64_t - headers: std::map - body: std::string - uses_refresh_token: bool - - Response: - cppName: app::Response - fields: - http_status_code: int - custom_status_code: int - headers: std::map - body: std::string - - DeviceInfo: - cppName: app::AppConfig::DeviceInfo - fields: - platform_version: std::string - sdk_version: std::string - sdk: std::string - device_name: std::string - device_version: std::string - framework_name: std::string - framework_version: std::string - bundle_id: std::string - - AppConfig: - cppName: app::AppConfig - fields: - app_id: std::string - transport: SharedGenericNetworkTransport - base_url: std::optional - default_request_timeout_ms: std::optional - device_info: DeviceInfo - base_file_path: std::string - sync_client_config: SyncClientConfig - metadata_mode: - type: MetadataMode - default: MetadataMode::Encryption - custom_encryption_key: std::optional - security_access_group: - type: std::string - default: "" - - CompensatingWriteErrorInfo: - cppName: sync::CompensatingWriteErrorInfo - fields: - object_name: std::string - reason: std::string - primary_key: Mixed - - SaltedFileIdent: - cppName: sync::SaltedFileIdent - fields: - ident: uint64_t - salt: int64_t - opaqueTypes: - Schema - Group @@ -723,24 +378,15 @@ classes: has_binding_context: '(r: Realm) -> bool' set_binding_context: '(r: SharedRealm, methods: BindingContext)' get_or_create_object_with_primary_key: '(t: TableRef, pk: Mixed) -> std::pair' - make_network_transport: '(runRequest: (request: const Request&, callback: util::UniqueFunction<(response: Response&&)>&&) off_thread) -> SharedGenericNetworkTransport' delete_data_for_object: '(realm: SharedRealm, object_type: StringData)' base64_decode: '(input: StringData) -> BinaryData' make_logger_factory: '(log: (category: const std::string&, level: LoggerLevel, message: const std::string&) off_thread) -> LoggerFactory' make_logger: '(log: (category: const std::string&, level: LoggerLevel, message: const std::string&) off_thread) -> SharedLogger' - simulate_sync_error: '(session: SyncSession&, code: const int&, message: const std::string&, type: const std::string&, is_fatal: bool)' consume_thread_safe_reference_to_shared_realm: '(tsr: ThreadSafeReference) -> SharedRealm' file_exists: '(path: StringData) -> bool' - erase_subscription: '(subs: MutableSyncSubscriptionSet&, sub_to_remove: const SyncSubscription&) -> bool' # This is added due to DescriptorOrdering not being exposed get_results_description: '(results: const Results&) -> StringData' - feed_buffer: '(ws: WatchStream&, buffer: BinaryData)' - # Converts char* and length to a combined string_view argument to callback. - # TODO: Consider making preverify_ok a bool. - make_ssl_verify_callback: '(callback: (server_address: const std::string&, server_port: int, pem_data: std::string_view, preverify_ok: int, depth: int) off_thread -> bool) -> SSLVerifyCallback' needs_file_format_upgrade: '(config: const RealmConfig&) -> bool' - sync_user_as_app_user: '(sync_user: Nullable>) -> Nullable>' - app_user_as_sync_user: '(sync_user: Nullable>) -> Nullable>' LogCategoryRef: cppName: util::LogCategoryRef @@ -931,12 +577,6 @@ classes: staticMethods: get_shared_realm: - '(config: RealmConfig) -> SharedRealm' - # These are important, but we need to handle move-only types, and that is tricky - # - suffix: from_reference - # sig: '(thread: ThreadSafeReference) -> SharedRealm' - # - suffix: from_reference_with_sched - # sig: '(thread: ThreadSafeReference, scheduler: SharedScheduler) -> SharedRealm' - get_synchronized_realm: '(config: RealmConfig) -> SharedAsyncOpenTask' #make_shared_realm: '(config: Realm::Config, version: std::optional, coordinator: std::shared_ptr<_impl::RealmCoordinator>) -> SharedRealm' get_schema_version: '(config: const RealmConfig&) const -> SchemaVersion' @@ -962,10 +602,6 @@ classes: audit_context: Nullable - sync_session: Nullable - get_latest_subscription_set: SyncSubscriptionSet - get_active_subscription_set: SyncSubscriptionSet - methods: begin_transaction: () commit_transaction: () @@ -1171,173 +807,6 @@ classes: remove_all: '()' try_erase: '(key: StringData) -> bool' - # These are a bit of a hack. - # TODO rename one of the AppCredentials::google() functions. - GoogleAuthCode: - cppName: app::AuthCode - constructors: - make: '(code: std::string)' - GoogleIdToken: - cppName: app::IdToken - constructors: - make: '(token: std::string)' - - AppCredentials: - cppName: app::AppCredentials - staticMethods: - facebook: '(access_token: const AppCredentialsToken) -> AppCredentials' - anonymous: '(reuse_anonymous_credentials: bool) -> AppCredentials' - apple: '(id_token: const AppCredentialsToken) -> AppCredentials' - google: - - sig: '(id_token: GoogleAuthCode&&) -> AppCredentials' - suffix: auth - - sig: '(id_token: GoogleIdToken&&) -> AppCredentials' - suffix: id - custom: '(token: const AppCredentialsToken) -> AppCredentials' - username_password: '(username: std::string, password: std::string) -> AppCredentials' - function: - - '(serialized_payload: const EJsonObj&) -> AppCredentials' - - sig: '(payload: const bson::BsonDocument&) -> AppCredentials' - suffix: 'bson' - api_key: '(api_key: std::string) -> AppCredentials' - properties: - provider: AuthProvider - provider_as_string: std::string - - UserSubscriptionToken: - cppName: app::User::Token - - SyncUser: - cppName: SyncUser - sharedPtrWrapped: SharedSyncUser - properties: - is_logged_in: bool - - User: - cppName: app::User - sharedPtrWrapped: SharedUser - properties: - user_id: std::string - app_id: std::string - legacy_identities: std::vector - access_token: std::string - refresh_token: std::string - state: SyncUserState - is_anonymous: bool - device_id: std::string - has_device_id: bool - user_profile: UserProfile - identities: std::vector - custom_data: std::optional - subscribers_count: count_t - app: SharedApp - methods: - log_out: () - subscribe: '(observer: (user: IgnoreArgument)) -> UserSubscriptionToken' - unsubscribe: '(token: UserSubscriptionToken)' - path_for_realm: '(config: SyncConfig&, custom_file_name: std::optional&) -> std::string' - access_token_refresh_required: '() -> bool' -# # request_log_out: '(cb: AsyncCallback<(err: std::optional)>&&)' - request_refresh_location: '(cb: AsyncCallback<(err: std::optional)>&&)' - request_access_token: '(cb: AsyncCallback<(err: std::optional)>&&)' - track_realm: '(path: std::string_view)' - create_file_action: '(action: SyncFileAction, original_path: std::string_view, requested_recovery_dir: std::optional, partition_value: std::string_view) -> std::string' - - UserProfile: - cppName: app::UserProfile - methods: - name: '() -> std::optional' - email: '() -> std::optional' - picture_url: '() -> std::optional' - first_name: '() -> std::optional' - last_name: '() -> std::optional' - gender: '() -> std::optional' - birthday: '() -> std::optional' - min_age: '() -> std::optional' - max_age: '() -> std::optional' - data: '() -> bson::BsonDocument' - - AppSubscriptionToken: - cppName: app::App::Token - - App: - cppName: app::App - sharedPtrWrapped: SharedApp - properties: - config: const AppConfig& - current_user: Nullable - all_users: std::vector - sync_manager: SharedSyncManager - subscribers_count: count_t - staticMethods: - get_app: '(mode: AppCacheMode, config: const AppConfig&) -> SharedApp' - get_cached_app: '(app_id: const std::string&) -> SharedApp' - clear_cached_apps: () - close_all_sync_sessions: () - - methods: - log_in_with_credentials: '(credentials: AppCredentials, cb: AsyncCallback<(user: const Nullable&, err: std::optional)>&&)' - log_out: - - '(cb: AsyncCallback<(err: std::optional)>&&)' - - sig: '(user: SharedUser, cb: AsyncCallback<(err: std::optional)>&&)' - suffix: user - refresh_custom_data: '(user: SharedUser, cb: AsyncCallback<(err: std::optional)>&&)' - link_user: '(user: SharedUser, credentials: const AppCredentials&, cb: AsyncCallback<(user: const Nullable&, err: std::optional)>&&)' - switch_user: '(user: SharedUser)' - remove_user: '(user: SharedUser, cb: AsyncCallback<(err: std::optional)>&&)' - delete_user: '(user: SharedUser, cb: AsyncCallback<(err: std::optional)>&&)' - usernamePasswordProviderClient: - - sig: () -> UsernamePasswordProviderClient - cppName: provider_client - userAPIKeyProviderClient: - - sig: () -> UserAPIKeyProviderClient - cppName: provider_client - push_notification_client: '(service_name: const std::string&) -> PushClient' - subscribe: '(observer: (app: IgnoreArgument)) -> AppSubscriptionToken' - unsubscribe: '(token: AppSubscriptionToken)' - call_function: '(user: const SharedUser&, name: std::string, args: EJsonArray, service_name: std::optional, cb: AsyncCallback<(result: Nullable, err: std::optional)>)' - make_streaming_request: '(user: SharedUser, name: std::string, args: bson::BsonArray, service_name: std::optional) -> Request' - update_base_url: '(base_url: std::string_view, cb: AsyncCallback<(err: std::optional)>&&)' - get_base_url: '() const -> std::string' - immediately_run_file_actions: '(realm_path: std::string) -> bool' - - WatchStream: - cppName: app::WatchStream - constructors: - make: () - properties: - state: WatchStreamState - error: AppError - methods: - next_event: '() -> bson::BsonDocument' - - PushClient: - cppName: app::PushClient - methods: - register_device: '(registration_token: const std::string&, sync_user: const SharedUser&, completion: AsyncCallback<(err: std::optional)>&&)' - deregister_device: '(sync_user: const SharedUser&, completion: AsyncCallback<(err: std::optional)>&&)' - - UsernamePasswordProviderClient: - cppName: app::App::UsernamePasswordProviderClient - methods: - register_email: '(email: const std::string&, password: const std::string&, completion: AsyncCallback<(err: std::optional)>&&)' - retry_custom_confirmation: '(email: const std::string&, completion: AsyncCallback<(err: std::optional)>&&)' - confirm_user: '(token: const std::string&, token_id: const std::string&, completion: AsyncCallback<(err: std::optional)>&&)' - resend_confirmation_email: '(email: const std::string&, completion: AsyncCallback<(err: std::optional)>&&)' - reset_password: '(password: const std::string&, token: const std::string&, token_id: const std::string&, completion: AsyncCallback<(err: std::optional)>&&)' - send_reset_password_email: '(email: const std::string&, completion: AsyncCallback<(err: std::optional)>&&)' - call_reset_password_function: '(email: const std::string&, password: const std::string&, args: const bson::BsonArray&, completion: AsyncCallback<(err: std::optional)>&&)' - - UserAPIKeyProviderClient: - cppName: app::App::UserAPIKeyProviderClient - methods: - create_api_key: '(name: const std::string&, user: SharedUser, completion: AsyncCallback<(apiKey: UserAPIKey&&, err: std::optional)>&&)' - fetch_api_key: '(id: ObjectId&, user: const SharedUser, completion: AsyncCallback<(apiKey: UserAPIKey&&, err: std::optional)>&&)' - fetch_api_keys: '(user: const SharedUser, completion: AsyncCallback<(apiKeys: std::vector&&, err: std::optional)>&&)' - delete_api_key: '(id: ObjectId&, user: const SharedUser, completion: AsyncCallback<(err: std::optional)>&&)' - enable_api_key: '(id: ObjectId&, user: const SharedUser, completion: AsyncCallback<(err: std::optional)>&&)' - disable_api_key: '(id: ObjectId&, user: const SharedUser, completion: AsyncCallback<(err: std::optional)>&&)' - # See Helpers::make_loger_factory to construct one. # Using an opaque class here rather than exposing the factory to avoid having to # involve the SDK in the construction of the logger. For JS at least, that would @@ -1347,96 +816,8 @@ classes: LoggerFactory: cppName: std::function(util::Logger::Level)> - SyncManager: - sharedPtrWrapped: SharedSyncManager - properties: - log_level: LoggerLevel - has_existing_sessions: bool - methods: - set_session_multiplexing: '(allowed: bool)' - set_log_level: '(level: LoggerLevel)' - set_logger_factory: '(factory: LoggerFactory)' - set_user_agent: '(user_agent: std::string)' - set_timeouts: '(timeouts: SyncClientTimeouts)' - reconnect: () - wait_for_sessions_to_terminate: () - get_existing_active_session: '(path: const std::string&) -> Nullable' - get_all_sessions_for: '(user: const User&) -> std::vector' - ThreadSafeReference: {} - AsyncOpenTask: - sharedPtrWrapped: SharedAsyncOpenTask - methods: - start: '(callback: AsyncCallback<(realm: Nullable, error: Nullable) off_thread>)' - cancel: () - register_download_progress_notifier: '(callback: (transferred_bytes: uint64_t, transferrable_bytes: uint64_t, progress_estimate: double) off_thread) -> uint64_t' - unregister_download_progress_notifier: '(token: uint64_t)' - - SyncSession: - sharedPtrWrapped: SharedSyncSession - properties: - state: SyncSessionState - connection_state: SyncSessionConnectionState - path: std::string - user: SharedSyncUser - config: SyncConfig - full_realm_url: std::string - methods: - wait_for_upload_completion: '(callback: AsyncCallback<(err: Status) off_thread>)' - wait_for_download_completion: '(callback: AsyncCallback<(err: Status) off_thread>)' - register_progress_notifier: '(callback: (transferred_bytes: uint64_t, transferrable_bytes: uint64_t, progress_estimate: double) off_thread, direction: ProgressDirection, is_streaming: bool) -> uint64_t' - unregister_progress_notifier: '(token: uint64_t)' - register_connection_change_callback: '(callback: (old_state: SyncSessionConnectionState, new_state: SyncSessionConnectionState) off_thread) -> uint64_t' - unregister_connection_change_callback: '(token: uint64_t)' - revive_if_needed: () - handle_reconnect: () - close: () - force_close: () - shutdown_and_wait: () - update_configuration: '(config: SyncConfig)' - get_file_ident: '() -> SaltedFileIdent' - - SSLVerifyCallback: - cppName: std::function - - SyncSubscriptionSet: - cppName: sync::SubscriptionSet - iterable: const SyncSubscription& - properties: - version: int64_t - # not exposing snapshot_version - state: SyncSubscriptionSetState - error_str: StringData - size: count_t - methods: - make_mutable_copy: () const -> MutableSyncSubscriptionSet - get_state_change_notification: '(notify_when: SyncSubscriptionSetState, callback: AsyncCallback<(new_state: std::optional, err: std::optional) off_thread>) const' - at: '(index: count_t) const -> const SyncSubscription&' - find: - - sig: '(name: StringData) const -> Nullable' - suffix: by_name - - sig: '(query: const Query&) const -> Nullable' - suffix: by_query - refresh: () - # not exposing to_ext_json() - - MutableSyncSubscriptionSet: - cppName: sync::MutableSubscriptionSet - base: SyncSubscriptionSet - methods: - clear: () - insert_or_assign: # NOTE: these really return iterators, but the API is close enough to pointers to work here. - - sig: '(name: std::string_view, query: const Query&) -> std::pair' - suffix: by_name - - sig: '(query: const Query&) -> std::pair' - suffix: by_query - erase: - - sig: '(name: StringData) -> bool' - suffix: by_name - - sig: '(query: const Query&) -> bool' - suffix: by_query - commit: () -> SyncSubscriptionSet - # not exposing import() or update_state() + Scheduler: cppName: util::Scheduler sharedPtrWrapped: SharedScheduler @@ -1449,8 +830,3 @@ classes: make_frozen: '(version: VersionID) -> SharedScheduler' make_default: '() -> SharedScheduler' set_default_factory: '(factory: () -> SharedScheduler)' - GenericNetworkTransport: - cppName: app::GenericNetworkTransport - sharedPtrWrapped: SharedGenericNetworkTransport - methods: - send_request_to_server: '(request: Request&&, completionBlock: util::UniqueFunction<(response: const Response&)>&&)' diff --git a/bindgen/src/bound-model.ts b/bindgen/src/bound-model.ts index f5eae8c874f..bd21ff0c12f 100644 --- a/bindgen/src/bound-model.ts +++ b/bindgen/src/bound-model.ts @@ -168,57 +168,6 @@ export class Func extends TypeBase { argsSkippingIgnored() { return this.args.filter((arg) => !arg.type.isTemplate("IgnoreArgument")); } - - // For functions that take a final AsyncCallback argument, transforms into a - // function signature that omits that argument and returns an AsyncResult. - // Other functions return undefined. - asyncTransform(): Func | undefined { - if (!this.ret.isVoid()) return undefined; - const voidType = this.ret; - if (this.args.length === 0) return undefined; - const lastArgType = this.args[this.args.length - 1].type.removeConstRef(); - if (!lastArgType.isTemplate("AsyncCallback")) return undefined; - - // Now we know we are an async function. Validate requirements and do the transform. - const cb = lastArgType.args[0]; - assert.equal(cb.kind, "Func" as const); - assert.equal(cb.ret, voidType); - - // Callback arguments are either (error?) or (result?, error?). - // In the latter case, result is the "real" return value from the async op. - assert([1, 2].includes(cb.args.length)); - const lastCbArgType = cb.args[cb.args.length - 1].type; - assert( - lastCbArgType.isOptional("AppError") || - lastCbArgType.isOptional("Status") || - lastCbArgType.isPrimitive("Status") || - lastCbArgType.isNullable("std::error_code") || - lastCbArgType.isNullable("std::exception_ptr"), - "Last arg to AsyncCallback must be one of " + - "util::Optional, util::Optional, Status, Nullable, r Nullable, " + - `but got ${lastCbArgType}`, - ); - let res: Type = voidType; - if (cb.args.length === 2) { - res = cb.args[0].type.removeConstRef(); - if (res.isOptional() || res.isNullable()) { - res = res.args[0]; - } - } - return new Func( - new Template("AsyncResult", [res]), - this.args.slice(0, -1), - this.isConst, - this.noexcept, - this.isOffThread, - ); - } - - // Like asyncTransform(), but returns self for non-async functions. This is useful if you only care - // about the exposed signature, and not whether it is an async function. - asyncTransformOrSelf(): Func { - return this.asyncTransform() ?? this; - } } export class Template extends TypeBase { @@ -235,15 +184,10 @@ export class Template extends TypeBase { } toCpp(): string { - assert.notEqual(this.name, "AsyncResult", "Should never see AsyncResult here"); - // These are just markers, not actually a part of the C++ interface. if (["Nullable", "IgnoreArgument"].includes(this.name)) return this.args[0].toCpp(); - const templateMap: Record = { - AsyncCallback: "util::UniqueFunction", - }; - const cppTemplate = templateMap[this.name] ?? this.name; + const cppTemplate = this.name; let args; if (["util::UniqueFunction", "std::function"].includes(cppTemplate)) { // Functions can't normally be toCpp'd because lambda types are unutterable. @@ -564,7 +508,7 @@ export class BoundSpec { for (const [structName, structRaw] of Object.entries(this.optInSpec?.records ?? {})) { const boundStruct = this.types[structName]; - assert(boundStruct instanceof Struct); + assert(boundStruct instanceof Struct, `Expected '${structName}' to be in types`); for (const fieldName of structRaw.fields) { boundStruct.getField(fieldName).isOptedInTo = true; } diff --git a/bindgen/src/realm_helpers.h b/bindgen/src/realm_helpers.h index e302e0091a8..e6975238c6a 100644 --- a/bindgen/src/realm_helpers.h +++ b/bindgen/src/realm_helpers.h @@ -2,13 +2,8 @@ #include "realm/binary_data.hpp" #include "realm/object-store/object_store.hpp" -#include "realm/object-store/sync/mongo_collection.hpp" -#include "realm/object-store/sync/sync_session.hpp" #include "realm/object_id.hpp" #include "realm/query.hpp" -#include "realm/sync/client_base.hpp" -#include "realm/sync/protocol.hpp" -#include "realm/sync/subscriptions.hpp" #include "realm/util/base64.hpp" #include "realm/util/file.hpp" #include "realm/util/logger.hpp" @@ -28,10 +23,7 @@ #include #include #include -#include #include -#include -#include #include #include #include @@ -149,28 +141,6 @@ struct Helpers { realm->m_binding_context = std::make_unique(realm, std::move(methods)); } - // This requires the ability to implement interfaces. - // This is planned, but for now, providing a helper unlocks sync. - template - static std::shared_ptr make_network_transport(F&& runRequest) - { - - class Impl final : public app::GenericNetworkTransport { - public: - Impl(F&& runRequest) - : runRequest(FWD(runRequest)) - { - } - void send_request_to_server(const app::Request& request, - util::UniqueFunction&& completionBlock) override - { - runRequest(std::move(request), std::move(completionBlock)); - } - std::decay_t runRequest; - }; - return std::make_shared(FWD(runRequest)); - } - static void delete_data_for_object(const SharedRealm& realm, StringData object_type) { auto& group = realm->read_group(); @@ -221,18 +191,6 @@ struct Helpers { return std::make_shared(logger); } - static void simulate_sync_error(SyncSession& session, const int& code, const std::string& message, - const std::string& type, bool is_fatal) - { - sync::SessionErrorInfo error(Status{type == "realm::sync::ProtocolError" ? ErrorCodes::SyncClientResetRequired - : ErrorCodes::UnknownError, - message}, - sync::IsFatal(is_fatal)); - error.server_requests_action = - code == 211 ? sync::ProtocolErrorInfo::Action::ClientReset : sync::ProtocolErrorInfo::Action::Warning; - SyncSession::OnlyForTesting::handle_error(session, std::move(error)); - } - // This is entirely because ThreadSafeReference is a move-only type, and those are hard to expose to JS. // Instead, we are exposing a function that takes a mutable lvalue reference and moves from it. static SharedRealm consume_thread_safe_reference_to_shared_realm(ThreadSafeReference& tsr) @@ -245,20 +203,6 @@ struct Helpers { return realm::util::File::exists(path); } - static bool erase_subscription(sync::MutableSubscriptionSet& subs, const sync::Subscription& sub_to_remove) - { - auto it = std::find_if(subs.begin(), subs.end(), [&](const auto& sub) { - return sub.id == sub_to_remove.id; - }); - - if (it == subs.end()) { - return false; - } - subs.erase(it); - - return true; - } - static std::string get_results_description(const Results& results) { const auto& query = results.get_query(); @@ -266,35 +210,10 @@ struct Helpers { return query.get_description() + ' ' + results.get_descriptor_ordering().get_description(query.get_table()); } - static void feed_buffer(app::WatchStream& ws, BinaryData buffer) - { - ws.feed_buffer({buffer.data(), buffer.size()}); - } - - static auto make_ssl_verify_callback(std::function - callback) - { - return [callback = std::move(callback)](const std::string& server_address, uint16_t server_port, - const char* pem_data, size_t pem_size, int preverify_ok, int depth) { - return callback(server_address, server_port, std::string_view(pem_data, pem_size), preverify_ok, depth); - }; - } - static bool needs_file_format_upgrade(const RealmConfig& config) { return config.needs_file_format_upgrade(); } - - static std::shared_ptr sync_user_as_app_user(std::shared_ptr sync_user) - { - return std::dynamic_pointer_cast(sync_user); - } - - static std::shared_ptr app_user_as_sync_user(std::shared_ptr app_user) - { - return std::dynamic_pointer_cast(app_user); - } }; struct ObjectChangeSet {