본문 바로가기

전체 글

(64)
[TIL] 열거형 Equatable 프로토콜 준수로 대소 비교 구현(feat. Alert 문제 해결) 현재 Alert 창을 열거형으로 정의하여 구분지어 구현중에 있는데요. 그러던 중 기존 Alert 열거형 값과 다른 연관값(Associated Value)으로 열거형 case를 정의하여 다른 연관값이 없는 Alert 열거형의 case들과 비교해야하는 상황을 마주하여 이를 해결한 방법에 대해 서술해 볼까 합니다.문제사항아래 이미지에서 보시는 바와 같이 Alert 구성 시 Alert Type이 비교가 안되는 오류를 마주하였습니다. 문제 원인 파악원인을 파악해보니 AlertType 정의가 연관케이스가 정의되어 있기 때문에 서로 대소 비교가 불가했던 것이었습니다.  해결방법AlertType이 Equtable 프로토콜을 준수하여 대소 비교가 가능하도록 구현하여 문제를 해결하였습니다. 마치며여기까지 읽어주셔서 정말 ..
[TIL] Redux 패턴 간단 정리 Redux 패턴 도입 배경이전 프로젝트에서 단방향 흐름인 MVI 패턴으로 구현하여 오류 발생 시 디버깅에 큰 장점을 누릴 수 있었지만 View별로 정의된 State 정의로 인해 State 간 상태 공유 관리가 생각보다 까다롭게 느껴졌습니다. 이에 단방향의 흐름을 유지하면서 한 곳에서 상태를 관리해줄 수 있는 방법이 없을까 하는 생각에 구글링을 하던 중 React 진영에서 상태를 한 곳(Store)에서 관리해주는 아키텍처인 Redux가 Swift에서도 구현가능하다는 정보를 접하여 이번에 새로 시작하려는 프로젝트부터 Redux 패턴을 도입하게 되었습니다.상태(State)란?우선 Redux에 대해 알아보기 전에 State란 무엇인지부터 살펴보겠습니다.Redux 공식문서를 확인해보시면 State의 정의는 다음과..
[TIL] SwiftUI에서 네트워크 단절 대응 구현기 오늘 포스팅은 SwiftUI에서 네트워크 단절 대응 기능을 구현하였던 과정에 대해 서술해 볼까 합니다. 네트워크 연결 모니터링 클래스 NWPathMonitorSwift에서 네트워크 단절 대응이라는 키워드를 구글링하면 나오는 키워드는 NWPathMonitor  클래스입니다. 이 클래스의 특징은 이름에서도 유추할 수 있다시피 네트워크 연결에 대해 실시간으로 모니터링해주는 클래스입니다.이 기능은 iOS12이후 버전부터 사용 가능하다고 합니다. 네트워크 모니터링 구현자 이제 그럼 네트워크 연결을 담당하는 클래스를 만들어 보겠습니다.네트워크 모니터링 클래스 선언 우선 NWPathMonitor 클래스의 인스턴스를 선언해줍니다.그리고 나서 네트워크 모니터링을 담당할 DispatchQueue를 선언해줍니다.외부로 네트..
[TIL] @AppStorage Custom Property Wrapper로 전환기 적용 동기아래 사진에서 빨간 박스로 표시되어 있는 것처럼 앱 로그인 시 프로필 이미지를 @AppStorage 프로퍼티 래퍼를 통해 UserDefaults에 저장하고 있습니다. 하지만 프로필 이미지도 유저의 개인정보로 취급될 수 있다고 생각하여 Token과 마찬가지로 Keychain에 저장해보기로 하였습니다. Property Wrapper란?Custom Property Wrapper를 만들기 앞서 Property Wrapper에 대해 간단히 알아보겠습니다. Property Wrapper란 Swift 5.1부터 도입된 개념이며,  Swift Programming Language Guide에 따르는 정의는 다음과 같다고 합니다.A property wrapper adds a layer of separation ..
[TIL] 여러 Destination이 있을 때 화면 관리법 배경아래 사진들을 보시면 프로필 화면에서 각각 닉네임 화면과 연락처 화면으로 이동하는 것을 알 수 있습니다.이처럼 오늘은 한 화면에서 여러 화면으로 이동하려고 할 때 어떻게 관리해주면 될지 알아보도록 하겠습니다. 구현 방법구현 방법은 아주 간단합니다. 바로 NavigationLink의 tag와 selection을 이용하면 되는데요. 구현 코드는 아래와 같습니다.struct ContentView: View { @State private var selection: String? = nil var body: some View { NavigationView { List { NavigationLink("1", t..
[TIL] 애플 소셜 로그인 구현기 이전 포스팅에서 카카오 소셜 로그인에 대해 구현한 내용을 작성하였었는데, 오늘은 애플 소셜 로그인을 적용한 구현기에 대한 여정을 작성해볼까 합니다! 해당 글은 애플 공식문서를 기반으로 구현한 내용을 설명해보고자 합니다. Implementing User Authentication with Sign in with Apple | Apple Developer DocumentationProvide a way for users of your app to set up an account and start using your services.developer.apple.com 코드 구현 전 환경설정우선 Signing & Capabilities > + Capability > Sign in with Apple 경로로 Si..
[TIL] 카카오 소셜 로그인 구현 이번 포스팅에선 카카오 소셜 로그인 구현에 대한 여정을 작성해 볼까 합니다.개발 전 사전 준비카카오 소셜 로그인은 개발 전 카카오 개발자 웹사이트에서 준비할 사항들이 좀 많이 있었는데요.그 과정을 하나하나 살펴보겠습니다. 애플리케이션 등록카카오 소셜 로그인을 사용하려면 카카오 개발자 웹사이트에 애플리케이션을 등록해주어야 합니다.앱 아이콘, 앱 이름,  회사명을 입력해줍니다.  여기서 가장 중요한 게 앱 아이콘인데요. 이는 앱을 카카오 Biz앱(실질적인 앱 운영을 위한 비지니스 앱)으로 등록하는 과정 중 필수과정이며, 추후 앱을 테스트 앱으로 전환하기 위함입니다. 왜냐하면 이후 유저가 카카오 로그인 시 유저에게 제공받을 개인정보 동의항목 설정의 제한을 더 확장시켜 주기 위함이죠. 이 부분에 대한 더 자세한..
[TIL] Keychain 적용기 적용 배경이전부터 유저 정보 저장용으로 계속 UserDefaults만 사용했기 때문에 이번에 보안성 좀 더 강하다는 Keychain을 적용해보려고 합니다. Keychain에 대하여등장배경 Secure login with iCloud Keychain verification codes - WWDC21 - Videos - Apple DeveloperLearn how you can support on-device verification codes in your app or website for a more secure sign-in experience. We'll explore the...developer.apple.com WWDC21 영상에 의하면 많은 유저들이 여러 디바이스에 걸쳐 동일한 비밀번호를 보유 및..