Refit: The automatic type-safe REST library for .NET Core, Xamarin and .NET


관련 자료

https://reactiveui.github.io/refit/

 

Refit: The automatic type-safe REST library for .NET Core, Xamarin and .NET

The automatic type-safe REST library for Xamarin and .NET

reactiveui.github.io

http://square.github.io/retrofit/

 

Retrofit

A type-safe HTTP client for Android and Java

square.github.io

 

 

 

 



 

 

 Refit은 Square의 Retrofit 라이브러리에서 크게 영향을받은 라이브러리이며 REST API를 라이브 인터페이스로 변환합니다. 간단하게 요약하면 인터페이스 정의 만으로도 REST API를 호출하여 데이터를 가져올 수 있게 해준다라는 것이다.

 

 예를 아래 코드를 통해 살펴 보자. 일단 인터페이스를 정의를 한다.

 

public interface IGitHubApi
{
    [Get("/users/{user}")]
    Task<User> GetUser(string user);
}

RestService 클래스는 HttpClient를 사용하여 호출을 수행하는 IGitHubApi 구현을 생성합니다.

var gitHubApi = RestService.For<IGitHubApi>("https://api.github.com");
var octocat = await gitHubApi.GetUser("octocat");

위와 같은 짧은 코드만으로 외부 자원을 사용하도록 할 수 있다.

 

 

 

ReactiveUI and the MVVM Pattern in WPF


관련 자료

 

https://reactiveui.net/

 

An advanced, composable, reactive model-view-viewmodel framework

Declarative Describe what you want, not how to do it & rejoice in the increased readability of your code. Code is communication between people, that also happens to run on a computer. If you optimise for reading by humans, then over a long time your projec

reactiveui.net

https://github.com/reactiveui

 

ReactiveUI

Use the Reactive Extensions for .NET to create elegant, testable user interfaces that run on any mobile or desktop platform. - ReactiveUI

github.com

https://www.toptal.com/wpf/reactiveui-and-mvvm-in-wpf

 

ReactiveUI and the MVVM Pattern in WPF Applications

I will implement a WPF app using ReactiveUI with the MVVM pattern, and uses it to access a REST API. This app will be able to track cars and their locations, take information pulled from a simulated source, and display this information to the user in a Bin

www.toptal.com

 

 



 

[그림1] ReactiveUI

 

 Reactive Extensions for .NET을 사용하여 모바일 또는 데스크톱 플랫폼에서 실행되는 우아하고 테스트 가능한 사용자 인터페이스를 만들 수 있다. 

 

[그림2] ReactiveUI code example

 "그림2"에서와 같은 코드로 이벤트를 잡아내고, 처리 로직을 세울 수 있다.

 

 

[그림3] example

 

 

[그림4] MVVM flow

 

 "그림4"는 MVVM의 흐름을 나타낸것이다. MV-VM으로서 처리 로직과, UI의 분리를 통해 디자이너와의 협업성을 향상 시킬 수 있다. MV* 아키텍처의 아류로서 MS에서 발표 하였지만, 대부분은 WPF에서 사용중이다. 하지만 javascript 진영이나, 기타 프레임워크에서 MV*와 바인딩 엔진 개념을 도입해서 사용하는 프로젝트가 늘어나고 있는 추세이긴 하다.

 

 

아래는 각 언어와 플랫폼별로 라이브러리를 추가하는 정보를 나열하였다. 참고하여 프로젝트에 추가하면 되겠다.

Platform ReactiveUI Package Package
.NET Standard ReactiveUI None
  ReactiveUI.Fody None
Unit Testing ReactiveUI.Testing None
Universal Windows ReactiveUI ReactiveUI.Events
WPF ReactiveUI.WPF ReactiveUI.Events.WPF
Windows Forms ReactiveUI.WinForms ReactiveUI.Events.WinForms
Xamarin.Forms ReactiveUI.XamForms ReactiveUI.Events.XamForms
Xamarin.Essentials ReactiveUI ReactiveUI.Events.XamEssentials
Xamarin.Android ReactiveUI.AndroidSupport ReactiveUI.Events
Xamarin.iOS ReactiveUI ReactiveUI.Events
Xamarin.Mac ReactiveUI ReactiveUI.Events
Tizen ReactiveUI ReactiveUI.Events
Avalonia Avalonia.ReactiveUI None

[표1] 참조 라이브러리

Create an Angular 7 + Google Authenticator + Node JS Web App with Two-Factor Authentication


관련 자료

https://hackernoon.com/create-an-angular-7-google-authenticator-node-js-web-app-with-two-factor-authentication-95e87af9356b

 

Create an Angular 7 + Google Authenticator + Node JS Web App with Two-Factor Authentication

“Turn on all security features like two-factor authentication. People who do that generally don’t get hacked. Don’t care? You will when…

hackernoon.com

https://github.com/Narendra-Kamath/angular-node-mfauth

 

Narendra-Kamath/angular-node-mfauth

Contribute to Narendra-Kamath/angular-node-mfauth development by creating an account on GitHub.

github.com

https://youtu.be/iZlpQg6F3LY

 



 

Angular 7 애플리케이션에서 Two-Factor 인증의 통합을 입증하는 간단한 웹 애플리케이션을 소개합니다.

 

SPA에서 구글 계정 연동하여 사용자 정보를 가져올 수 있습니다.

 

 

+ Recent posts