update login
This commit is contained in:
		
							parent
							
								
									c57d32c450
								
							
						
					
					
						commit
						4821e08b80
					
				| @ -4,6 +4,7 @@ export class cookieHandler { | ||||
|     this.reload(); | ||||
|   } | ||||
|   getCookie(key){ | ||||
|     if (!this.cookies) return undefined; | ||||
|     let cookie = this.cookies.find(cookie => cookie.split('=')[0] === key); | ||||
|     return cookie ? cookie.split('=')[1] : false; | ||||
|   } | ||||
| @ -21,7 +22,7 @@ export class cookieHandler { | ||||
|     return cookies; | ||||
|   } | ||||
|   reload(){ | ||||
|     this.cookies = this.parseCookie(document.cookie) | ||||
|     if (document.cookie) this.cookies = this.parseCookie(document.cookie); | ||||
|   } | ||||
|   store(){ | ||||
|     document.cookie = this.toString(); | ||||
|  | ||||
| @ -1,16 +1,15 @@ | ||||
| import matrix from 'matrix-js-sdk'; | ||||
| import {cookieHandler} from '@/lib/cookieHandler.js'; | ||||
| 
 | ||||
| export let client = undefined; | ||||
| 
 | ||||
| export class MatrixHandler { | ||||
|   constructor(clientDisplayName = 'matrix-chat') { | ||||
|     this.clientDisplayName = clientDisplayName; | ||||
|     this.accessToken; | ||||
|     let cookie = new cookieHandler().getCookie(); | ||||
|     this.client = undefined; | ||||
|     if (cookie.baseUrl && cookie.accessToken && cookie.userId) | ||||
|       this.tokenLogin(cookie.baseUrl, cookie.accessToken, cookie.userId); | ||||
|     this.rooms = undefined; | ||||
|   } | ||||
|   login(user, password, baseUrl, onError){ | ||||
|   login(user, password, baseUrl, onError, callback = ()=>{}){ | ||||
|     if (this.client){ console.log('there is already an active session'); return; } | ||||
|     this.client = new matrix.createClient({ | ||||
|       baseUrl: baseUrl | ||||
| @ -20,19 +19,34 @@ export class MatrixHandler { | ||||
|       password: password, | ||||
|       initial_device_display_name: this.clientDisplayName, | ||||
|     }).then((response) => { | ||||
|       console.log(`access token => ${response.access_token}`); | ||||
|       if (response.error) { | ||||
|         this.logout(); | ||||
|         console.log(`login error => ${response.error}`); | ||||
|         onError(response.error); | ||||
|       } | ||||
|       if (response.access_token){ | ||||
|         console.log(`access token => ${response.access_token}`); | ||||
|         console.log(this.client.getRooms()); | ||||
|         callback(response.access_token); | ||||
|       } | ||||
|     }).catch(error => { | ||||
|       this.logout(); | ||||
|       console.log(error); | ||||
|       onError(error.toString()); | ||||
|     }) | ||||
|   } | ||||
|   tokenLogin(baseUrl, accessToken, userId){ | ||||
|     if (this.client){ console.log('there is already an active session'); return; } | ||||
|     this.client = new matrix.createClient({baseUrl, accessToken, userId}); | ||||
|     this.client = new matrix.createClient({baseUrl, accessToken, userId}).then(response => { | ||||
|       console.log(response); | ||||
|     }); | ||||
|     this.client.startClient(); | ||||
|     this.client.once('sync', (state) => { | ||||
|       console.log(state); | ||||
|     }); | ||||
|   } | ||||
|   logout(){ | ||||
|     this.client.stopClient(); | ||||
|     this.client = undefined; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										23
									
								
								src/main.js
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								src/main.js
									
									
									
									
									
								
							| @ -2,16 +2,18 @@ import Vue from 'vue' | ||||
| import VueRouter from 'vue-router' | ||||
| import App from './App.vue' | ||||
| import {router} from './router.js' | ||||
| import {MatrixHandler} from './lib/matrixHandler.js' | ||||
| import {cookieHandler} from './lib/cookieHandler.js'; | ||||
| 
 | ||||
| Vue.config.productionTip = false | ||||
| Vue.use(VueRouter) | ||||
| Vue.config.productionTip = false; | ||||
| Vue.use(VueRouter); | ||||
| 
 | ||||
| export let matrix = new MatrixHandler(); | ||||
| 
 | ||||
| 
 | ||||
| export default { | ||||
|   methods: { | ||||
|     router(route){router.push(route)} | ||||
|   } | ||||
| let cookie = new cookieHandler().getCookie(); | ||||
| console.log(`cookie => ${cookie}`) | ||||
| if (cookie && cookie.baseUrl && cookie.accessToken && cookie.userId) { | ||||
|   matrix.tokenLogin(cookie.baseUrl, cookie.accessToken, cookie.userId); | ||||
| } | ||||
| 
 | ||||
| new Vue({ | ||||
| @ -19,8 +21,7 @@ new Vue({ | ||||
|   router, | ||||
|   template: '<App/>', | ||||
|   components: {App}, | ||||
|   data(){ | ||||
|     return { | ||||
|     } | ||||
|   data() { | ||||
|     return {} | ||||
|   } | ||||
| }).$mount('#app') | ||||
| }).$mount('#app'); | ||||
|  | ||||
| @ -1,8 +1,8 @@ | ||||
| import matrix from 'matrix-js-sdk'; | ||||
| /*import matrix from 'matrix-js-sdk'; | ||||
| import main from '@/main.js'; | ||||
| // import Vue from 'vue';
 | ||||
| 
 | ||||
| let client = matrix.createClient({}); | ||||
| let client = undefined; | ||||
| let session = { | ||||
|   user: '', | ||||
|   baseUrl: '', | ||||
| @ -44,23 +44,12 @@ export default { | ||||
|   data() { | ||||
|     return { | ||||
|       session, | ||||
|       client | ||||
|     }; | ||||
|   }, | ||||
|   methods: { | ||||
|     login() { | ||||
|       if (session.accessToken !== '') { | ||||
|         main.methods.error('you are already logged in'); | ||||
|         return; | ||||
|       } if (session.login.user === '') { | ||||
|         main.methods.error('username is empty'); | ||||
|         return; | ||||
|       } if (session.login.password === '') { | ||||
|         main.methods.error('password is empty'); | ||||
|         return; | ||||
|       } if (!(session.login.user.includes('@') && session.login.user.includes(':'))) { | ||||
|         main.methods.error('username is in wrong style'); | ||||
|         return; | ||||
|       } | ||||
| 
 | ||||
|       client = matrix.createClient({ | ||||
|         baseUrl: session.login.baseUrl | ||||
|       }); | ||||
| @ -72,6 +61,7 @@ export default { | ||||
|         document.cookie = `accessToken=${response.access_token}`; | ||||
|         document.cookie = `userId=${session.login.user}`; | ||||
|         document.cookie = `baseUrl=${session.login.baseUrl}`; | ||||
|         document.cookie = `SameSite=Strict`; | ||||
|         document.cookie = `expires=${new Date(Date.now() + 86400 * 10 * 1000)}`; | ||||
|         session = { | ||||
|           user: session.login.user, | ||||
| @ -86,12 +76,12 @@ export default { | ||||
|           console.log(`login error => ${response.error}`); | ||||
|         } | ||||
|         window.location.href = '/#/rooms/'; | ||||
|         window.location.reload(); | ||||
|         window.location.reload();*/ | ||||
|         /*client.startClient(); | ||||
|         client.once('sync', (state) => { | ||||
|           console.log(state); | ||||
|         });*/ | ||||
|       }); | ||||
| /*      }); | ||||
|     }, | ||||
|     logout(){ | ||||
|       document.cookie = `accessToken=`; | ||||
| @ -124,7 +114,7 @@ function getCookie(key) { | ||||
|   return cookie ? cookie.split('=')[1] : false; | ||||
| } | ||||
| 
 | ||||
| client.on('event', (event) => { | ||||
| /*client.on('event', (event) => { | ||||
|   //console.log(event.getType());
 | ||||
|   //console.log(event);
 | ||||
|   if (event.getType() === 'm.room.name') { | ||||
| @ -175,4 +165,4 @@ client.on('Room.timeline', (event, room) => { | ||||
|       } else document.getElementById('scrollDown').style.display = 'block'; | ||||
|     } | ||||
|   } | ||||
| }); | ||||
| });*/ | ||||
|  | ||||
| @ -1,15 +1,16 @@ | ||||
| <template> | ||||
|   <div id="login"> | ||||
|     <h1 class="title">[chat]</h1> | ||||
|     <form v-if="session.login" @submit.prevent="login()"> | ||||
|       <input v-model="session.login.user" class="input" name="user" type="text" maxlength="30" placeholder="@user:adb.sh"><br> | ||||
|       <input v-model="session.login.password" class="input" name="password" type="password" maxlength="30" placeholder="password"><br> | ||||
|       <input v-model="session.login.baseUrl" class="input" name="homeserver" maxlength="50" placeholder="https://matrix.org"><br> | ||||
|     <form v-if="showLogin" @submit.prevent="login()"> | ||||
|       <input v-model="user" class="input" name="user" type="text" maxlength="30" placeholder="@user:adb.sh"><br> | ||||
|       <input v-model="password" class="input" name="password" type="password" maxlength="30" placeholder="password"><br> | ||||
|       <input v-model="homeServer" class="input" name="homeserver" maxlength="50" placeholder="https://matrix.org"><br> | ||||
|       <div v-if="loginError" class="info">{{loginError}}</div> | ||||
|       <textbtn type="submit" text="login" /> | ||||
|     </form> | ||||
|     <div v-else> | ||||
|       <p>you are already logged in</p> | ||||
|       <textbtn @click.native="$router.push('room')" text="chat" /> | ||||
|       <textbtn @click.native="$router.push('rooms')" text="chat" /> | ||||
|       <textbtn @click.native="logout()" text="logout" /> | ||||
|     </div> | ||||
|   </div> | ||||
| @ -17,7 +18,7 @@ | ||||
| 
 | ||||
| <script> | ||||
| import textbtn from '@/components/textbtn'; | ||||
| import matrix from '@/matrix.js'; | ||||
| import {matrix} from '@/main.js'; | ||||
| 
 | ||||
| export default { | ||||
|   name: "login.vue", | ||||
| @ -26,15 +27,34 @@ export default { | ||||
|   }, | ||||
|   methods: { | ||||
|     login(){ | ||||
|       matrix.methods.login(); | ||||
|       if (matrix.client !== undefined) { | ||||
|         this.loginError = 'you are already logged in'; | ||||
|         return; | ||||
|       } if (this.user === '') { | ||||
|         this.loginError = 'username is empty'; | ||||
|         return; | ||||
|       } if (this.password === '') { | ||||
|         this.loginError = 'password is empty'; | ||||
|         return; | ||||
|       } if (!(this.user.match(/^@[a-zA-Z0-9]+:[a-z0-9]+\.[a-z]/))) { | ||||
|         this.loginError = 'username is in wrong style'; | ||||
|         return; | ||||
|       } | ||||
|       matrix.login(this.user, this.password, this.homeServer, (error) => { | ||||
|         this.loginError = `login failed: ${error}`; | ||||
|       }, ()=> this.$router.push('/rooms/')); | ||||
|     }, | ||||
|     logout(){ | ||||
|       matrix.methods.logout(); | ||||
|       matrix.logout(); | ||||
|     } | ||||
|   }, | ||||
|   data(){ | ||||
|     return { | ||||
|       session: matrix.data().session | ||||
|       user: "", | ||||
|       password: "", | ||||
|       homeServer: "https://adb.sh", | ||||
|       loginError: "", | ||||
|       showLogin: (matrix.client === undefined) | ||||
|     } | ||||
|   } | ||||
| } | ||||
| @ -59,7 +79,7 @@ input{ | ||||
|   border: 1px solid #fff; | ||||
|   text-align: center; | ||||
|   font-size: 1.1rem; | ||||
|   margin-top: 1rem; | ||||
|   margin: 0.5rem; | ||||
|   appearance: none; | ||||
|   outline: none; | ||||
| } | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user