Service | Cocoapods Pod Name | Framework | Dependency | Build Settings |
---|---|---|---|---|
Log & Crash | NHNCloudLogger | NHNCloudLogger.framework | [External & Optional] * CrashReporter.framework (NHNCloud) |
|
Mandatory | NHNCloudCore NHNCloudCommon |
NHNCloudCore.framework NHNCloudCommon.framework |
OTHER_LDFLAGS = ( "-ObjC", "-lc++" ); |
platform :ios, '11.0'
use_frameworks!
target '{YOUR PROJECT TARGET NAME}' do
pod 'NHNCloudLogger'
end
Build Settings의 Other Linker Flags에 -lc++와 -ObjC 항목을 추가합니다.
CrashReporter.framework를 직접 다운로드하거나 빌드한 경우에는 Build Setting의 Enable Bitcode의 값을 NO로 변경해야 합니다.
NHN Cloud의 Downloads 페이지에서 다운로드한 CrashReporter.framework는 bitCode를 지원합니다.
if [ "${CONFIGURATION}" = "Debug" ]; then
${PODS_ROOT}/NHNCloudSymbolUploader/nhncloud.ios.sdk-*/run --app-key LOG_N_CRASH_SEARCH_DEV_APPKEY
fi
USAGE: symbol-uploader -ak <ak> -pv <pv> [-sz <sz>] <path> [--verbose]
ARGUMENTS:
<path> dSYM file path is must be entered.
OPTIONS:
-ak, --app-key <ak> [Log&Crash Search]'s AppKey must be entered.
-pv, --project-version <pv>
Project version must be entered.
-sz, --service-zone <sz>
You can choose between real, alpha, and demo. (default: real)
--verbose Show more debugging information
-h, --help Show help information.
./SymbolUploader --app-key {APP_KEY} --project-version {CFBundleShortVersionString || MARKETING_VERSION} {symbol path(~/Project.dSYM)}
동일한 버전의 Symbol이 이미 업로드되어 있는 경우 SymbolUploader는 업로드되어 있는 Symbol을 제거하고 업로드를 수행합니다.
이때 두 Symbol 파일의파일명이 다를 경우 업로드되어 있던 Symbol은 제거되지 않습니다.
Log & Crash Search 콘솔에서 업로드되어 있는 Symbol을 제거해야 합니다. https://console.nhncloud.com/-> 조직 선택 -> 프로젝트 선택 -> Anaytics -> Log & Crash Search -> 설정 -> 심벌 파일
// 초기화
+ (void)initWithConfiguration:(NHNCloudLoggerConfiguration *)configuration;
NHNCloudLoggerConfiguration *configuration = [NHNCloudLoggerConfiguration configurationWithAppKey:@"YOUR_APP_KEY"];
[NHNCloudLogger initWithConfiguration:configuration];
// DEBUG Level log
+ (void)debug:(NSString *)message;
// INFO Level log
+ (void)info:(NSString *)message;
// WARN Level log
+ (void)warn:(NSString *)message;
// ERROR Level log
+ (void)error:(NSString *)message;
// FATAL Level log
+ (void)fatal:(NSString *)message;
[NHNCloudLogger info:@"NHN Cloud Log & Crash Search!"];
// 사용자 정의 필드 추가
+ (void)setUserFieldWithValue:(NSString *)value forKey:(NSString *)key;
// 사용자 정의 필드 추가
[NHNCloudLogger setUserFieldWithValue:@"USER_VALUE" forKey:@"USER_KEY"];
사용자 아이디가 설정되어 있으면 Log & Crash Search 콘솔의
크래시 사용자
항목에서 사용자별 크래시 경험을 확인할 수 있습니다. 사용자 아이디 설정은 시작하기에서 확인 가능합니다.
// CrashReporter 활성화
NHNCloudLoggerConfiguration *configuration = [NHNCloudLoggerConfiguration configurationWithAppKey:@"YOUR_APP_KEY" enableCrashReporter:YES];
[NHNCloudLogger initWithConfiguration:configuration];
// CrashReporter 비활성화
NHNCloudLoggerConfiguration *configuration = [NHNCloudLoggerConfiguration configurationWithAppKey:@"YOUR_APP_KEY" enableCrashReporter:NO];
[NHNCloudLogger initWithConfiguration:configuration];
+ (void)setShouldReportCrashHandler:(void (^)(void))handler;
[NHNCloudLogger setShouldReportCrashHandler:^{
// 사용자 정의 필드 를 통해 Crash가 발생한 상황에서 얻고자 하는 정보를 함께 전송
// 사용자 정의 필드 추가
[NHNCloudLogger setUserFieldWithValue:@"USER_VALUE" forKey:@"USER_KEY"];
}];
+ (void)setDelegate:(id<NHNCloudLoggerDelegate>) delegate;
@protocol NHNCloudLoggerDelegate <NSObject>
@optional
// 로그 전송 성공
- (void)nhnCloudLogDidSuccess:(NHNCloudLog *)log;
// 로그 전송 실패
- (void)nhnCloudLogDidFail:(NHNCloudLog *)log error:(NSError *)error;
// 네트워크 단절 등의 이유로 로그 전송에 실패한 경우 재전송을 위해 SDK 내부 저장
- (void)nhnCloudLogDidSave:(NHNCloudLog *)log;
// 로그 필터링
- (void)nhnCloudLogDidFilter:(NHNCloudLog *)log logFilter:(NHNCloudLogFilter *)logFilter;
@end
#import <NHNCloudLogger/NHNCloudLogger.h>
@interface AppDelegate () <UIApplicationDelegate, NHNCloudLoggerLoggerDelegate>
@end
@implementation AppDelegate
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// ...
// 초기화
NHNCloudLoggerConfiguration *configuration = [NHNCloudLoggerConfiguration configurationWithAppKey:@"YOUR_APP_KEY" enableCrashReporter:YES];
[NHNCloudLogger initWithConfiguration:configuration];
// Delegate 설정
[[NHNCloudLogger setDelegate:self];
return YES;
}
#pragma mark - NHNCloudLoggerDelegate
// 로그 전송 성공
- (void)nhnCloudLogDidSuccess:(NHNCloudLog *)log {
// ...
}
// 로그 전송 실패
- (void)nhnCloudLogDidFail:(NHNCloudLog *)log error:(NSError *)error {
// ...
}
// 네트워크 단절 등의 이유로 로그 전송에 실패한 경우 재전송을 위해 SDK 내부 저장
- (void)nhnCloudLogDidSave:(NHNCloudLog *)log {
// ...
}
// 로그 필터링
- (void)nhnCloudLogDidFilter:(NHNCloudLog *)log logFilter:(NHNCloudLogFilter *)logFilter {
// ...
}
@end
콘솔을 통해 Network Insights 기능을 활성화하면 NHN Cloud Logger를 초기화할 때, 콘솔에 등록한 URL로 1회 요청합니다.
typedef NS_ENUM(NSInteger, NHNCloudEnvironment) {
NHNCloudEnvironmentPublic = 0,
NHNCloudEnvironmentGovernment = 1,
};
@property (nonatomic) NHNCloudEnvironment cloudEnvironment;
NHNCloudEnvironmentPublic
입니다. NHNCloudLoggerConfiguration *configuration = [NHNCloudLoggerConfiguration configurationWithAppKey:@"YOUR_APP_KEY"];
[configuration setCloudEnvironment:NHNCloudEnvironmentGovernment];
[NHNCloudLogger initWithConfiguration:configuration];