-
Notifications
You must be signed in to change notification settings - Fork 517
HomeKit iOS xcode13.3 beta1
Alex Soto edited this page Mar 7, 2022
·
2 revisions
#HomeKit.framework https://github.com/xamarin/xamarin-macios/pull/14325
diff -ruN /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupManager.h /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupManager.h
--- /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupManager.h 2021-11-19 10:27:34.000000000 -0500
+++ /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupManager.h 2022-01-25 13:04:53.000000000 -0500
@@ -10,20 +10,45 @@
NS_ASSUME_NONNULL_BEGIN
+@class HMAccessorySetupRequest;
+@class HMAccessorySetupResult;
@class HMMatterTopology;
+/*!
+ * @abstract This class can be used to launch system UI that will allow the user to go through the process
+ * of adding one or more accessories to a particular home and follow up with additional setup.
+ * These APIs do not require that the current app has home data authorization
+ */
HM_EXTERN API_AVAILABLE(ios(15.0)) API_UNAVAILABLE(watchos, tvos) API_UNAVAILABLE(macos, macCatalyst)
@interface HMAccessorySetupManager : NSObject
/*!
- * @abstract Add and set up CHIP accessories with a CHIP Partner Ecosystem App. This flow is unique among the
- * "Add Accessory" flows in that it primarily targets the originating (i.e. non-HomeKit) ecosystem
- * to add accessories to. "Add to Apple Home?" is presented as a final, optional step after the user
- * has completed pairing and configuration with the Partner Ecosystem App
+ * @abstract Launch system UI to perform the process of setting up accessories with the given request.
+ * During this process, each of the accessories is added to a home, assigned to a room and
+ * further configured based on its services
+ *
+ * @param request A request object describing information about how to set up the accessory
+ * @param completion A block that is invoked once the setup process finishes. On failure, the result will be
+ * nil and the error will provide additional information
+ */
+- (void)performAccessorySetupUsingRequest:(HMAccessorySetupRequest *)request completionHandler:(void(^)(HMAccessorySetupResult * _Nullable result, NSError * _Nullable error))completion API_AVAILABLE(ios(15.4)) API_UNAVAILABLE(watchos, tvos);
+
+/*!
+ * @abstract Launch system UI to perform the process of setting up Matter accessories with a Matter Partner
+ * Ecosystem App. This flow is different from other accessory setup flows in that it primarily
+ * targets the ecosystem of the originating (i.e. non-HomeKit) app as the ecosystem to add
+ * accessories to. The option to add to Apple Home is presented as a final, optional step after
+ * the user has completed setup with the Matter Partner Ecosystem App
*
- * @param topology A configuration object representing the topology of the initiating ecosystem
+ * @param request A request object describing information about how to set up the accessory
+ * @param topology A configuration object representing the topology of the initiating ecosystem
+ * @param completion A block that is invoked once the setup process finishes. The provided error will be nil
+ * on success or will provide additional information on failure
*/
-- (void)addAndSetUpAccessoriesForTopology:(HMMatterTopology *)topology completionHandler:(HMErrorBlock)completion;
+- (void)performMatterEcosystemAccessorySetupUsingRequest:(HMAccessorySetupRequest *)request
+ topology:(HMMatterTopology *)topology
+ completionHandler:(HMErrorBlock)completion API_AVAILABLE(ios(15.4)) API_UNAVAILABLE(watchos, tvos);
+- (void)addAndSetUpAccessoriesForTopology:(HMMatterTopology *)topology completionHandler:(HMErrorBlock)completion API_DEPRECATED("Use -[HMAccessorySetupManager performAccessorySetupUsingRequest:topology:completionHandler:] instead", ios(15.0, 15.4));
@end
diff -ruN /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupRequest.h /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupRequest.h
--- /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupRequest.h 1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupRequest.h 2022-01-25 13:04:53.000000000 -0500
@@ -0,0 +1,49 @@
+//
+// HMAccessorySetupRequest.h
+// HomeKit
+//
+// Copyright © 2021 Apple Inc. All rights reserved.
+//
+
+#import <Foundation/Foundation.h>
+#import <HomeKit/HMDefines.h>
+
+NS_ASSUME_NONNULL_BEGIN
+
+@class HMAccessorySetupPayload;
+
+HM_EXTERN API_AVAILABLE(ios(15.4)) API_UNAVAILABLE(watchos, tvos) API_UNAVAILABLE(macos, macCatalyst)
+@interface HMAccessorySetupRequest : NSObject <NSCopying>
+
+/*!
+ * @abstract The payload to use for accessory setup
+ * @note When this is non-nil, the following entitlement is required:
+ * com.apple.developer.homekit.allow-setup-payload
+ */
+@property (nullable, copy) HMAccessorySetupPayload *payload;
+
+/*!
+ * @abstract The -[HMHome uniqueIdentifier] that corresponds to the HMHome that the accessory should be
+ * added to when being set up. If nil, then the user will be prompted to choose a home
+ */
+@property (nullable, copy) NSUUID *homeUniqueIdentifier;
+
+/*!
+ * @abstract The -[HMRoom uniqueIdentifier] that corresponds to the existing HMRoom that should be
+ * suggested when the user is prompted to choose a room to add the accessory to. If nil, then any
+ * room may be suggested
+ * @note This value will be ignored if homeUniqueIdentifier is nil
+ */
+@property (nullable, copy) NSUUID *suggestedRoomUniqueIdentifier;
+
+/*!
+ * @abstract The name that will be suggested when the user is prompted to name the accessory being set up.
+ * If nil, then the suggested name will be taken from the accessory itself
+ * @note If an accessory bridge is being set up, then this value only applies to the accessory bridge
+ * and not any accessories behind the bridge
+ */
+@property (nullable, copy) NSString *suggestedAccessoryName;
+
+@end
+
+NS_ASSUME_NONNULL_END
diff -ruN /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupResult.h /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupResult.h
--- /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupResult.h 1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMAccessorySetupResult.h 2022-01-25 13:04:55.000000000 -0500
@@ -0,0 +1,33 @@
+//
+// HMAccessorySetupResult.h
+// HomeKit
+//
+// Created by Nick Fraioli on 7/12/21.
+// Copyright © 2021 Apple Inc. All rights reserved.
+//
+
+#import <Foundation/Foundation.h>
+
+NS_ASSUME_NONNULL_BEGIN
+
+HM_EXTERN API_AVAILABLE(ios(15.4)) API_UNAVAILABLE(watchos, tvos) API_UNAVAILABLE(macos, macCatalyst)
+@interface HMAccessorySetupResult : NSObject <NSCopying>
+
+/*!
+ * @abstract The -[HMHome uniqueIdentifier] that the accessories were added to
+ */
+@property (readonly, copy) NSUUID *homeUniqueIdentifier;
+
+/*!
+ * @abstract The -[HMAccessory uniqueIdentifier] values corresponding to the accessories that were set up.
+ * Usually only one accessory is set up at a time, but adding an accessory bridge can result in
+ * multiple accessories being set up at once
+ */
+@property (readonly, copy) NSArray<NSUUID *> *accessoryUniqueIdentifiers;
+
+- (instancetype)init NS_UNAVAILABLE;
++ (instancetype)new NS_UNAVAILABLE;
+
+@end
+
+NS_ASSUME_NONNULL_END
diff -ruN /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMHome.h /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMHome.h
--- /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMHome.h 2021-11-19 10:24:27.000000000 -0500
+++ /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HMHome.h 2022-01-25 13:17:53.000000000 -0500
@@ -168,7 +168,7 @@
* The NSError provides more information on the status of the request, error
* will be nil on success.
*/
-- (void)addAndSetupAccessoriesWithCompletionHandler:(void (^)(NSError * __nullable error))completion API_AVAILABLE(ios(10.0)) API_UNAVAILABLE(macos, macCatalyst) API_UNAVAILABLE(watchos, tvos) NS_SWIFT_ASYNC_NAME(addAndSetUpAccessories());
+- (void)addAndSetupAccessoriesWithCompletionHandler:(void (^)(NSError * __nullable error))completion NS_SWIFT_ASYNC_NAME(addAndSetUpAccessories()) API_DEPRECATED("Use -[HMAccessorySetupManager performAccessorySetupUsingRequest:completionHandler:] instead", ios(10.0, 15.4)) API_UNAVAILABLE(macos, macCatalyst) API_UNAVAILABLE(watchos, tvos);
/*!
* @brief Add accessory with the given setup payload to the home.
@@ -179,7 +179,7 @@
* The NSError provides more information on the status of the request, error
* will be nil on success.
*/
-- (void)addAndSetupAccessoriesWithPayload:(HMAccessorySetupPayload *)payload completionHandler:(void (^)(NSArray<HMAccessory *>* __nullable accessories, NSError * __nullable error))completion API_AVAILABLE(ios(11.3)) API_UNAVAILABLE(macos, macCatalyst) API_UNAVAILABLE(watchos, tvos) NS_SWIFT_ASYNC_NAME(addAndSetUpAccessories(payload:));
+- (void)addAndSetupAccessoriesWithPayload:(HMAccessorySetupPayload *)payload completionHandler:(void (^)(NSArray<HMAccessory *>* __nullable accessories, NSError * __nullable error))completion NS_SWIFT_ASYNC_NAME(addAndSetUpAccessories(payload:)) API_DEPRECATED("Use -[HMAccessorySetupManager performAccessorySetupUsingRequest:completionHandler:] instead", ios(11.3, 15.0)) API_UNAVAILABLE(macos, macCatalyst) API_UNAVAILABLE(watchos, tvos);
/*!
* @brief True if this home supports all of the requirements for adding a network router.
diff -ruN /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HomeKit.h /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HomeKit.h
--- /Applications/Xcode_13.2.0.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HomeKit.h 2021-11-12 22:35:50.000000000 -0500
+++ /Applications/Xcode_13.3.0-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/HomeKit.framework/Headers/HomeKit.h 2022-01-20 03:11:00.000000000 -0500
@@ -42,7 +42,6 @@
#import <HomeKit/HMEventTriggerActivationState.h>
#import <HomeKit/HMSignificantEvents.h>
#import <HomeKit/HMPresenceEventDefines.h>
-#import <HomeKit/HMAccessorySetupPayload.h>
#import <HomeKit/HMAddAccessoryRequest.h>
#import <HomeKit/HMNetworkConfigurationProfile.h>
@@ -62,7 +61,11 @@
#import <HomeKit/HMCameraAudioControl.h>
#import <HomeKit/HMAccessorySetupManager.h>
+#import <HomeKit/HMAccessorySetupPayload.h>
+#import <HomeKit/HMAccessorySetupRequest.h>
+#import <HomeKit/HMAccessorySetupResult.h>
+
#import <HomeKit/HMMatterHome.h>
+#import <HomeKit/HMMatterRequestHandler.h>
#import <HomeKit/HMMatterRoom.h>
#import <HomeKit/HMMatterTopology.h>
-#import <HomeKit/HMMatterRequestHandler.h>
- README
- xcode13.0 Binding Status
- xcode13.1 Binding Status
- xcode13.2 Binding Status
- xcode13.3 Binding Status
- xcode13.4 Binding Status
- xcode14.0 Binding Status
- xcode14.1 Binding Status
- xcode14.2 Binding Status
- xcode14.3 Binding Status
- xcode15.0 Binding Status
- xcode15.1 Binding Status
- xcode15.3 Binding Status
- xcode15.4 Binding Status
- xcode16.0 Binding Status
- xcode16.1 Binding Status
- xcode16.2 Binding Status