163 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
			
		
		
	
	
			163 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Objective-C
		
	
	
	
	
	
#if __has_include(<Sentry/Sentry.h>)
 | 
						|
#    import <Sentry/SentryDefines.h>
 | 
						|
#    import <Sentry/SentrySerializable.h>
 | 
						|
#    import <Sentry/SentrySpanProtocol.h>
 | 
						|
#else
 | 
						|
#    import <SentryWithoutUIKit/SentryDefines.h>
 | 
						|
#    import <SentryWithoutUIKit/SentrySerializable.h>
 | 
						|
#    import <SentryWithoutUIKit/SentrySpanProtocol.h>
 | 
						|
#endif
 | 
						|
 | 
						|
@class SentryUser, SentryOptions, SentryBreadcrumb, SentryAttachment;
 | 
						|
 | 
						|
NS_ASSUME_NONNULL_BEGIN
 | 
						|
 | 
						|
/**
 | 
						|
 * The scope holds useful information that should be sent along with the event. For instance tags or
 | 
						|
 * breadcrumbs are stored on the scope.
 | 
						|
 * @see
 | 
						|
 * https://docs.sentry.io/platforms/apple/enriching-events/scopes/#whats-a-scope-whats-a-hub
 | 
						|
 */
 | 
						|
NS_SWIFT_NAME(Scope)
 | 
						|
@interface SentryScope : NSObject <SentrySerializable>
 | 
						|
 | 
						|
/**
 | 
						|
 * Returns current Span or Transaction.
 | 
						|
 * @return current Span or Transaction or null if transaction has not been set.
 | 
						|
 */
 | 
						|
@property (nullable, nonatomic, strong) id<SentrySpan> span;
 | 
						|
 | 
						|
/**
 | 
						|
 * The id of current session replay.
 | 
						|
 */
 | 
						|
@property (nullable, nonatomic, strong) NSString *replayId;
 | 
						|
 | 
						|
/**
 | 
						|
 * Gets the dictionary of currently set tags.
 | 
						|
 */
 | 
						|
@property (nonatomic, readonly, copy) NSDictionary<NSString *, NSString *> *tags;
 | 
						|
 | 
						|
- (instancetype)initWithMaxBreadcrumbs:(NSInteger)maxBreadcrumbs NS_DESIGNATED_INITIALIZER;
 | 
						|
- (instancetype)init;
 | 
						|
- (instancetype)initWithScope:(SentryScope *)scope;
 | 
						|
 | 
						|
/**
 | 
						|
 * Set global user -> thus will be sent with every event
 | 
						|
 */
 | 
						|
- (void)setUser:(SentryUser *_Nullable)user;
 | 
						|
 | 
						|
/**
 | 
						|
 * Set a global tag. Tags are searchable key/value string pairs attached to
 | 
						|
 * every event.
 | 
						|
 */
 | 
						|
- (void)setTagValue:(NSString *)value forKey:(NSString *)key NS_SWIFT_NAME(setTag(value:key:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Remove the tag for the specified key.
 | 
						|
 */
 | 
						|
- (void)removeTagForKey:(NSString *)key NS_SWIFT_NAME(removeTag(key:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Set global tags. Tags are searchable key/value string pairs attached to every
 | 
						|
 * event.
 | 
						|
 */
 | 
						|
- (void)setTags:(NSDictionary<NSString *, NSString *> *_Nullable)tags;
 | 
						|
 | 
						|
/**
 | 
						|
 * Set global extra -> these will be sent with every event
 | 
						|
 */
 | 
						|
- (void)setExtras:(NSDictionary<NSString *, id> *_Nullable)extras;
 | 
						|
 | 
						|
/**
 | 
						|
 * Set global extra -> these will be sent with every event
 | 
						|
 */
 | 
						|
- (void)setExtraValue:(id _Nullable)value
 | 
						|
               forKey:(NSString *)key NS_SWIFT_NAME(setExtra(value:key:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Remove the extra for the specified key.
 | 
						|
 */
 | 
						|
- (void)removeExtraForKey:(NSString *)key NS_SWIFT_NAME(removeExtra(key:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Set @c dist in the scope
 | 
						|
 */
 | 
						|
- (void)setDist:(NSString *_Nullable)dist;
 | 
						|
 | 
						|
/**
 | 
						|
 * Set @c environment in the scope
 | 
						|
 */
 | 
						|
- (void)setEnvironment:(NSString *_Nullable)environment;
 | 
						|
 | 
						|
/**
 | 
						|
 * Sets the @c fingerprint in the scope
 | 
						|
 */
 | 
						|
- (void)setFingerprint:(NSArray<NSString *> *_Nullable)fingerprint;
 | 
						|
 | 
						|
/**
 | 
						|
 * Sets the @c level in the scope
 | 
						|
 */
 | 
						|
- (void)setLevel:(enum SentryLevel)level;
 | 
						|
 | 
						|
/**
 | 
						|
 * Add a breadcrumb to the scope
 | 
						|
 */
 | 
						|
- (void)addBreadcrumb:(SentryBreadcrumb *)crumb NS_SWIFT_NAME(addBreadcrumb(_:));
 | 
						|
 | 
						|
- (void)add:(SentryBreadcrumb *)crumb DEPRECATED_MSG_ATTRIBUTE("use `addBreadcrumb` instead")
 | 
						|
                NS_SWIFT_NAME(add(_:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Clears all breadcrumbs in the scope
 | 
						|
 */
 | 
						|
- (void)clearBreadcrumbs;
 | 
						|
 | 
						|
/**
 | 
						|
 * Serializes the Scope to JSON
 | 
						|
 */
 | 
						|
- (NSDictionary<NSString *, id> *)serialize;
 | 
						|
 | 
						|
/**
 | 
						|
 * Sets context values which will overwrite SentryEvent.context when event is
 | 
						|
 * "enriched" with scope before sending event.
 | 
						|
 */
 | 
						|
- (void)setContextValue:(NSDictionary<NSString *, id> *)value
 | 
						|
                 forKey:(NSString *)key NS_SWIFT_NAME(setContext(value:key:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Remove the context for the specified key.
 | 
						|
 */
 | 
						|
- (void)removeContextForKey:(NSString *)key NS_SWIFT_NAME(removeContext(key:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Adds an attachment to the Scope's list of attachments. The SDK adds the attachment to every event
 | 
						|
 * sent to Sentry.
 | 
						|
 * @param attachment The attachment to add to the Scope's list of attachments.
 | 
						|
 */
 | 
						|
- (void)addAttachment:(SentryAttachment *)attachment NS_SWIFT_NAME(addAttachment(_:));
 | 
						|
 | 
						|
// We want to keep the old Swift `add(_ attachment:)` function as deprecated, but we cant have
 | 
						|
// another objc `add` method
 | 
						|
- (void)includeAttachment:(SentryAttachment *)attachment
 | 
						|
    DEPRECATED_MSG_ATTRIBUTE("use `addAttachment` instead")NS_SWIFT_NAME(add(_:));
 | 
						|
 | 
						|
/**
 | 
						|
 * Clears all attachments in the scope.
 | 
						|
 */
 | 
						|
- (void)clearAttachments;
 | 
						|
 | 
						|
/**
 | 
						|
 * Clears the current Scope
 | 
						|
 */
 | 
						|
- (void)clear;
 | 
						|
 | 
						|
/**
 | 
						|
 * Mutates the current transaction atomically.
 | 
						|
 * @param callback the SentrySpanCallback.
 | 
						|
 */
 | 
						|
- (void)useSpan:(SentrySpanCallback)callback;
 | 
						|
 | 
						|
@end
 | 
						|
 | 
						|
NS_ASSUME_NONNULL_END
 |