GithubHelp home page GithubHelp logo

Comments (5)

silverbux avatar silverbux commented on July 18, 2024

Hi @andresrivas1506 , its already implemented by default, on protected routes you simply add
data { auth: true } example: routes.config.js#L36

and to show / hide elements use vm.can() nav-sidebar.component.html#L28 which is referenced on its controller nav-sidebar.component.js#L6

from laravel-angular-admin.

arivasvera avatar arivasvera commented on July 18, 2024

Hello @silverbux thanks for your time. Yes, its already implemented, but only using data { auth: true } and showing/hiding things in template. If you go, for example, to url http://myapp/#/user-lists from url bar, you can see the html.

I want to protect the route using permissions:

.when('/content', {
      resolve : {
        'acl' : ['$q', 'AclService', function($q, AclService){
          if(AclService.can('view_content')){
            // Has proper permissions
            return true;
          } else {
            // Does not have permission
            return $q.reject('Unauthorized');
          }
        }]
      }
    });

Sorry for my bad english

from laravel-angular-admin.

arivasvera avatar arivasvera commented on July 18, 2024

I can solve with this:

$rootScope.$on('$stateChangeError', function (event, toState, toParams, fromState, fromParams, rejection) {
    if (rejection === 'Unauthorized') {
      $state.go('app.landing');
    }
  });
  • my protected route
.state('app.somerute', {
      url: '/some-route',
      resolve : {
        'acl' : ['$q', 'AclService', function($q, AclService){
          if(AclService.can('some_permission')){
            // Has proper permissions
            return true;
          } else {
            // Does not have permission
            return $q.reject('Unauthorized');
          }
        }]
      },
      data: {
        auth: true
      },
      views: {
        'main@app': {
          templateUrl: getView('someview')
        }
      }
    })

Thank you @silverbux

from laravel-angular-admin.

silverbux avatar silverbux commented on July 18, 2024

Coolness, or try this approach as well.

data: {
   auth: true,
   access: 'manage.user'
}

then you could add a function on your /angular/run/routes.run.js and call AclService from there.

from laravel-angular-admin.

arivasvera avatar arivasvera commented on July 18, 2024

very nice that approach, thanks

from laravel-angular-admin.

Related Issues (20)

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.