Coder Social home page Coder Social logo

ioadres / vue-easysession Goto Github PK

View Code? Open in Web Editor NEW
7.0 0.0 0.0 27 KB

A manage easy session storage plugin for VueJS

License: Apache License 2.0

JavaScript 100.00%
session sessionstorage vue-session vuejs javascript plugin share sessions session-store expiration

vue-easysession's Introduction

Install

npm install vue-easysession --save

To install the plugin, do the following:

import VueEasySession from 'vue-easysession'
Vue.use(VueEasySession.install)

Now you can use it in your components with the $session property.

Options

VueSession can be started with some options that will change its behavior.

  • persist A Boolean value to determine whether the data stored in the session may persist between tabs and browser instances. Defaults to false. Optional

  • keySession A String value to determine the key of the current Vue session. Defaults is vue-session-key. Optional

  • expireSessionCallback is event handler that is execute when the expiration is success. Default is undefined. Optional

Pass the options in the use method:

var options = {
    persist: true,
    keySession: 'myKeySession',
    expireSessionCallback: function () {
        window.location.href = '/'
    }
}

Vue.use(VueEasySession.install, options)

Reference Vue instance this.$session .vue

  • this.$session.getAll(), returns all data stored in the Session.

  • this.$session.set(key,value), sets a single value to the Session.

  • this.$session.get(key), returns the value attributed to the given key.

  • this.$session.start(exp : milliseconds), initializes a session with a 'session-id'. If you attempt to save a value without having started a new session, the plugin will automatically start a new session. the parameter exp is optional and indicate the time of expiration the session(millisecond)

  • this.$session.exists(), checks whether a session has been initialized or not.

  • this.$session.has(key), checks whether the key exists in the Session

  • this.$session.remove(key), removes the given key from the Session

  • this.$session.clear(), clear all keys in the Session, except for 'session-id', keeping the Session alive

  • this.$session.destroy(), destroys the Session

  • this.$session.id(), returns the 'session-id'

  • this.$session.renew(session_id), allows a user to renew a previous session by manually inputting the session_id

Reference the instance VueEasySession

You can use the session in others scripts file

import VueEasySession from 'vue-easysession'
var session = VueEasySession.getInstance()
if(session.exists()) {
  console.log(true);
}

you can add the options parameters too in the VueEasySession.getInstance(options)

Example

Your login method could look like this:

export default {
    name: 'login',
    methods: {
        login: function () {
          this.$http.post('URL', {
            password: this.password,
            username: this.username
          }).then(function (response) {
            if (response.status === 200 && 'token' in response.body) {
              this.$session.start()
              this.$session.set('jwt', response.body.token)
              Vue.http.headers.common['Authorization'] = 'Bearer ' + response.body.token
              this.$router.push('/home')
            }
          }, function (err) {
            console.log('err', err)
          })
        }
    }
}

In your logged-in area, you can check whether or not a session is started and destroy it when the user wants to logout:

export default {
  name: 'panel',
  data () {
    return { }
  },
  beforeCreate: function () {
    if (!this.$session.exists()) {
      this.$router.push('/')
    }
  },
  methods: {
    logout: function () {
      this.$session.destroy()
      this.$router.push('/')
    }
  }
}

This library is based for the repository vue-session of victorsferreira https://github.com/victorsferreira/vue-session

vue-easysession's People

Contributors

ioadres avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar

vue-easysession's Issues

How to check if session exists globally

In the documentation, to check if a session exists on a component, we need to do:

 beforeCreate: function () {
    if (!this.$session.exists()) {
      this.$router.push('/')
    }

This will check if a session exists, else redirect back to homepage.

I have many components, and doing this on each of them feels like WET code, so I decided to do it on the router.js file

import VueEasySession from 'vue-easysession'
var session = VueEasySession.getInstance()
if(!session.exists()) {
   next('/')
     } else {
      next();
    }
}

It isn't working and I'm getting an error:
[vue-router] uncaught error during route navigation:
Invalid Object with a dropdown of many files

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.