[Meteor + React] 개발환경 만들기 - 3
MeteorMeteor의 accounts-password를 패키지를 통한 로그인 환경 만들기를 해본다.
- accounts-password 패키지를 통한 미티어 사용자 가입/로그인 사용 방법 알기
- React Router 설정
- 미티어의 Tracker.autorun을 통해 reactivity computation과 resource 사용 방법 알기
- 소스코드
미티어 사용자 관리
accounts-password 패키지를 설치하고, 가입 및 로그인 화면을 만든다.
$ meteor add accounts-password
$ meteor npm install --save bcrypt
// Link 사용을 위해
$ meteor npm install --save react-router-dom
Signup.tsx와 Login.tsx 생성한다.
- email, password의 값을 읽기 위하여 typescript방식의 public refs를 정의한다.
- Accounts.createUser를 통해 사용자를 등록한다.
// Singup.tsx
import * as React from 'react';
import { Link } from 'react-router-dom';
import { Accounts } from 'meteor/accounts-base'
export interface SignupProps {}
export default class Signup extends React.Component<SignupProps, any> {
// @see https://goenning.net/2016/11/02/strongly-typed-react-refs-with-typescript/
public refs: {
email: HTMLInputElement,
password: HTMLInputElement
}
constructor(props) {
super(props);
this.state = {
error: ''
};
}
onCreateAccount = (e: any) => {
e.preventDefault();
let email = this.refs.email.value.trim();
let password = this.refs.password.value.trim();
Accounts.createUser({email, password}, (err) => {
if (err) {
this.setState({ error: err.reason });
} else {
this.setState({ error: '' });
}
});
}
public render() {
return (
<div>
<h1>Signup to short Link</h1>
{ this.state.error ? <p>{this.state.error} </p> : undefined}
<form onSubmit={this.onCreateAccount}>
<input type="email" ref="email" name="email" placeholder="Email"/>
<input type="password" ref="password" name="password" placeholder="Password"/>
<button>Create Acount</button>
</form>
<Link to="/login">Already have a account?</Link>
</div>
);
}
}
Login.tsx
- refs 정의
- Meteor.loginWithPassword를 통해 로그인한다.
import * as React from 'react';
import { Link } from 'react-router-dom';
import { Meteor } from 'meteor/meteor';
export interface LoginProps {
history: any;
}
export default class Login extends React.Component<LoginProps, any> {
public refs: {
email: HTMLInputElement,
password: HTMLInputElement
}
constructor(props) {
super(props);
this.state = {
error: ''
};
}
onLogin = (e: any) => {
e.preventDefault();
let email = this.refs.email.value.trim();
let password = this.refs.password.value.trim();
Meteor.loginWithPassword({ email }, password, (err) => {
if (err) {
this.setState({ error: err.reason });
} else {
this.setState({ error: '' });
}
});
}
public render() {
return (
<div>
<h1>Login to short Link</h1>
{this.state.error ? <p>{this.state.error} </p> : undefined}
<form onSubmit={this.onLogin}>
<input type="email" ref="email" name="email" placeholder="Email" />
<input type="password" ref="password" name="password" placeholder="Password" />
<button>Login</button>
</form>
<Link to="/signup">Have a account?</Link>
</div>
);
}
}
NotFound.tsx 파일도 생성한다.
import * as React from 'react';
export default () => <div>Not Found Page</div>
React Router 설정
라우팅 설정을 통해 가입, 로그인후 Link화면으로 이동하는 설정한다.
history 모듈을 설치한다.
$ meteor npm install --save history
client/main.tsx에 Route설정을 한다.
import * as React from 'react';
import { Meteor } from 'meteor/meteor';
import { render } from 'react-dom';
import { Provider } from 'react-redux';
import { Route, Router, Switch } from 'react-router-dom';
import { createBrowserHistory } from 'history';
import App from '../imports/ui/App'
import Login from '../imports/ui/pages/Login';
import Signup from '../imports/ui/pages/Signup';
import InfoContainer from '../imports/ui/Info';
import NotFound from '../imports/ui/pages/NotFound';
import store from '../imports/ui/store';
const browserHistory = createBrowserHistory();
const Root = (
<Provider store={store}>
<Router history={browserHistory}>
<Switch>
<Route exact path="/" component={Login} />
<Route path="/main" component={App} />
<Route path="/signup" component={Signup} />
<Route path="/links" component={InfoContainer} />
<Route path="*" component={NotFound} />
</Switch>
</Router>
</Provider>
);
Meteor.startup(() => {
render(Root, document.getElementById('react-target'));
});
links는 인증된 사용자만 볼 수 있으므로 Tracker.autorun이라는 Reactivity Computation 영역에서 Meteor.user()라는 Reactivity Source가 로그인 상태인지 검사한다.
- 로그인 상태가 아니면 무조건 login화면으로 이동
- 로그인 상태이면서 인증이 필요없는 화면인 경우 link화면으로 이동
// client/main.tsx
import { Tracker } from 'meteor/tracker';
Tracker.autorun(() => {
const isAuthenticated = !!Meteor.user();
if (isAuthenticated) {
const pathname = browserHistory.location.pathname;
const unauthenticatedPages: any = ['/', '/signup'];
const isUnauthenticatedPage = unauthenticatedPages.includes(pathname);
if (isUnauthenticatedPage) {
browserHistory.push('/links'); // main
} else {
browserHistory.push(pathname);
}
} else {
browserHistory.push('/'); // login
}
});
Meteor.startup(() => {
render(Root, document.getElementById('react-target'));
});
imports/ui/Info.tsx 에 logout 기능 추가
...
import { Accounts } from 'meteor/accounts-base';
interface InfoProps {
links: any;
loading: boolean
}
class Info extends React.Component<InfoProps, any> {
linkList() {
const { links, loading } = this.props;
if (loading) {
return <div>loading...</div>
} else {
return <LinkList links={links} />
}
}
onLogout = () => {
Accounts.logout();
}
render() {
return (
<div>
<button onClick={this.onLogout}>Log out</button>
<AddLink />
{this.linkList()}
</div>
);
}
}
가입 및 로그인 테스트 확인하기
가입을 하고, 로그인을 한다.
Chrome Extension 으로 MiniMongoExplorer를 설치하고 user Collection의 내용을 확인한다.
또는 Chrome DevTool의 Application에서 로그인 사용자의 userId와 console에서 확인해 볼 수 있다. 또한 Link페이지에서 로그아웃을 해보고 콘솔을 확인해 본다.
<참조>
- 크롬 확장툴 MiniMongoExplorer
- 세번째 글 소스
'Meteor' 카테고리의 다른 글
[Meteor + React] 개발환경 만들기 - 6 (0) | 2018.12.05 |
---|---|
[Meteor + React] 개발환경 만들기 - 5 (0) | 2018.12.05 |
[Meteor + React] 개발환경 만들기 - 4 (0) | 2018.12.05 |
[Meteor + React] 개발환경 만들기 - 2 (0) | 2018.12.05 |
[Meteor + React] 개발환경 만들기 - 1 (0) | 2018.12.05 |