티스토리 뷰
728x90
반응형
로그인도 Auth의 signIn 함수면 간단히 끝 -!
FirebaseManager에 다음메소드를 추가하고
class func login(email: String, password: String, completion: @escaping (Result<AuthDataResult,Error>) -> Void) {
Auth.auth().signIn(withEmail: email, password: password) { (result, error) in
if let result = result {
completion(.success(result))
} else if let error = error {
completion(.failure(error))
}
}
}
LoginViewModel도 구현해준다
struct LoginViewModel {
struct State {
}
struct Action {
let login = PublishSubject<(String, String)>()
}
let state = State()
let action = Action()
private let bag = DisposeBag()
init() {
action.login.subscribe(onNext: { email, password in
FirebaseManager.login(email: email, password: password, completion: { result in
switch result {
case .success(let success):
let navController = UIStoryboard.init(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "MemosNavController")
Navigator.present(to: navController)
print(success.user.email)
case .failure(let failure):
Navigator.presentAlert(with: failure.localizedDescription)
}
})
}).disposed(by: bag)
}
}
Navigator에 present메소드도 추가해줬다
class func present(to viewController: UIViewController, animated: Bool = false, completion: (() -> Void)? = nil) {
UIApplication.topViewController()?.present(viewController, animated: animated, completion: completion)
}
그러면 로그인 실패하면 alert화면,
로그인 성공하면 메모 화면으로 가게 된다
로그인한 사용자에 따라 다르게 메모를 보여주기 위해 FirebaseManager 코드를 다음과 같이 바꿔준다
User 노드 밑에 메모들이 추가되는 구조이다
class FirebaseManager {
class var user: String {
return Auth.auth().currentUser?.email?.removeSpecialCharacters() ?? ""
}
class func add(memo: Memo) {
let rootRef = Database.database().reference()
let memosRef = rootRef.child(user).child("memos")
let memoRef = memosRef.childByAutoId()
memoRef.setValue(memo.toDictionary())
}
class func fetchAll() -> Observable<[Memo]> {
return Observable<[Memo]>.create { observer in
let rootRef = Database.database().reference()
rootRef.child(user).child("memos").observe(.value) { snapshot in
var memos: [Memo] = []
let memosDic = snapshot.value as? [String: Any] ?? [:]
for (key, _) in memosDic.sorted(by: {$0.key < $1.key}) {
if let memoDic = memosDic[key] as? [String: Any], let memo = Memo(dic: memoDic, ID: key) {
memos.append(memo)
}
}
observer.onNext(memos)
}
return Disposables.create()
}
}
class func delete(key: String) {
let rootRef = Database.database().reference()
let memoRef = rootRef.child(user).child("memos").child(key)
memoRef.removeValue()
}
class func change(key: String, to memo: Memo) {
let rootRef = Database.database().reference()
let memoRef = rootRef.child(user).child("memos").child(key)
memoRef.setValue(memo.toDictionary())
}
}
extension String {
func removeSpecialCharacters() -> String {
return self.components(separatedBy: CharacterSet.letters.inverted).joined()
}
}
이 string extension도 해줬는데, 노드의 키값으로 특수문자가 들어가는 것을 빼주기 위해 사용했다
이메일을 그대로 쓰면 이런 에러가 나기 때문...!!
'(child:) Must be a non-empty string and not contain '.' '#' '$' '[' or ']''
반응형
'💻 > Firebase' 카테고리의 다른 글
[FireBase-MLKit] FireBase MLKit 소개 (0) | 2019.07.05 |
---|---|
[Firebase-Auth] Firebase 예제 프로젝트 - 회원가입 (0) | 2019.06.10 |
[Firebase-Auth] Firebase 예제 프로젝트 - Auth를 사용하기 위해 준비하기 (0) | 2019.05.31 |
[Firebase-DB] Firebase 예제 프로젝트(modify) - Realtime DB에서 데이터 변경하기 (0) | 2019.05.31 |
[Firebase-DB] Firebase 예제 프로젝트(delete) - Realtime DB에서 데이터 삭제하기 (2) | 2019.05.28 |
댓글
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
TAG
- SerializerMethodField
- cocoapod
- Watch App for iOS App vs Watch App
- METAL
- Django Firebase Cloud Messaging
- 플러터 싱글톤
- flutter 앱 출시
- 구글 Geocoding API
- 플러터 얼럿
- Flutter Clipboard
- 장고 URL querystring
- Dart Factory
- 장고 Custom Management Command
- Django Heroku Scheduler
- Flutter Text Gradient
- flutter build mode
- drf custom error
- Flutter Spacer
- DRF APIException
- PencilKit
- ribs
- Django FCM
- flutter deep link
- github actions
- Python Type Hint
- flutter dynamic link
- Flutter 로딩
- ipad multitasking
- Flutter getter setter
- Sketch 누끼
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함