Diferencia entre revisiones de «Usuario:ManuelRomero/Laravel/Roles»
Línea 6: | Línea 6: | ||
3.- Se identifican roles y a cada rol se le asignan determinadas acciones (dar de alta usuarios, subir noticias, modificar clientes ...)<br /> | 3.- Se identifican roles y a cada rol se le asignan determinadas acciones (dar de alta usuarios, subir noticias, modificar clientes ...)<br /> | ||
4.- A los diferentes usuarios se les asisigna un rol concreto, con lo que puede realizar las acciones que a ese rol se le han atribuído<br /> | 4.- A los diferentes usuarios se les asisigna un rol concreto, con lo que puede realizar las acciones que a ese rol se le han atribuído<br /> | ||
+ | 5.- Lo mismo puedo asignar directamente permisos concretos, pero es mucho más útil asigar un rol concreto a un determinado usuario en lugar de dar permiso a permiso<br /> | ||
+ | |||
[[Archivo:DiagramaGeneralRoles.png|center|400px]] | [[Archivo:DiagramaGeneralRoles.png|center|400px]] | ||
===Paquetes para gestionar roles en Laravel=== | ===Paquetes para gestionar roles en Laravel=== | ||
Línea 12: | Línea 14: | ||
*Github del proyecto :'''''https://github.com/spatie/laravel-permission''''' | *Github del proyecto :'''''https://github.com/spatie/laravel-permission''''' | ||
*Blog en la web :'''''https://blog.pleets.org/article/sistema-basado-en-roles-con-laravel-permission''''' | *Blog en la web :'''''https://blog.pleets.org/article/sistema-basado-en-roles-con-laravel-permission''''' | ||
+ | |||
}} | }} | ||
*Lo primero que necesitamos es tener una aplicación desarrollada. | *Lo primero que necesitamos es tener una aplicación desarrollada. | ||
Línea 21: | Línea 24: | ||
[[Archivo:Diagrama_MR_Ej_Roles.png|center|400px]] | [[Archivo:Diagrama_MR_Ej_Roles.png|center|400px]] | ||
− | 1.- Crear modelos, crontroladores, migraciones, seeder y factory y resources para cada elemento | + | 1.- Crear modelos, crontroladores, migraciones, seeder y factory y resources para cada elemento<br /> |
− | 2.- Creemos el crud de, por ejemplos las '''''facturas''''' | + | 2.- Creemos el crud de, por ejemplos las '''''facturas'''''<br /> |
− | 3.- Activamos el sistema de autenticación de laravel con | + | 3.- Activamos el sistema de autenticación de laravel con <br /> |
Ahora agregamos o instalamos el paquete en nuestro proyecto | Ahora agregamos o instalamos el paquete en nuestro proyecto | ||
Línea 29: | Línea 32: | ||
composer require spatie/laravel-permission | composer require spatie/laravel-permission | ||
</source> | </source> | ||
+ | *Para que autocomplete en phpstorm los métodos | ||
+ | <source src=bash> | ||
+ | https://spatie.be/docs/laravel-permission/v3/advanced-usage/phpstorm | ||
+ | </source> | ||
+ | *Una vez que tenemos creada la aplicación vamos a realizar los roles y permisos | ||
+ | |||
==Seguimos el post arriba indicado== | ==Seguimos el post arriba indicado== | ||
+ | |||
+ | |||
*Instalamos el paquete por composer | *Instalamos el paquete por composer | ||
Revisión de 23:04 26 may 2021
Qué es un sistema de roles
- Es una utilidad que suelen tener muchas aplicaciónes donde hay diferentes secciones en nuestro sistema
- Es algo muy típico y muy bien implementado en los csm, que básicamente consiste es que:
1.- Te identificas en el sistema
2.- En fucnión de tus credenciales puedes realizar determinadas acciones en el sistema
3.- Se identifican roles y a cada rol se le asignan determinadas acciones (dar de alta usuarios, subir noticias, modificar clientes ...)
4.- A los diferentes usuarios se les asisigna un rol concreto, con lo que puede realizar las acciones que a ese rol se le han atribuído
5.- Lo mismo puedo asignar directamente permisos concretos, pero es mucho más útil asigar un rol concreto a un determinado usuario en lugar de dar permiso a permiso
Paquetes para gestionar roles en Laravel
- Vamos a utilizar el paquete laravel-permision para gestionar estas acciones en nuestro poryecto
|
- Lo primero que necesitamos es tener una aplicación desarrollada.
- Vamos a realizar una donde tengamos el siguiente esquema.
- Por supuesto en nuestra aplicación el usuario se tiene que autentificar para acceder
- Debemos hacer:
1.- Crear modelos, crontroladores, migraciones, seeder y factory y resources para cada elemento
2.- Creemos el crud de, por ejemplos las facturas
3.- Activamos el sistema de autenticación de laravel con
Ahora agregamos o instalamos el paquete en nuestro proyecto
Idioma no válido.
Necesita especificar un idioma como esto: <source lang="html4strict">...</source>
lenguajes soportados para sintaxis remarcada:
4cs, 6502acme, 6502kickass, 6502tasm, 68000devpac, abap, actionscript, actionscript3, ada, algol68, apache, applescript, apt_sources, arm, asm, asp, asymptote, autoconf, autohotkey, autoit, avisynth, awk, bascomavr, bash, basic4gl, bf, bibtex, blitzbasic, bnf, boo, c, c_loadrunner, c_mac, caddcl, cadlisp, cfdg, cfm, chaiscript, cil, clojure, cmake, cobol, coffeescript, cpp, cpp-qt, csharp, css, cuesheet, d, dcl, dcpu16, dcs, delphi, diff, div, dos, dot, e, ecmascript, eiffel, email, epc, erlang, euphoria, f1, falcon, fo, fortran, freebasic, freeswitch, fsharp, gambas, gdb, genero, genie, gettext, glsl, gml, gnuplot, go, groovy, gwbasic, haskell, haxe, hicest, hq9plus, html4strict, html5, icon, idl, ini, inno, intercal, io, j, java, java5, javascript, jquery, kixtart, klonec, klonecpp, latex, lb, ldif, lisp, llvm, locobasic, logtalk, lolcode, lotusformulas, lotusscript, lscript, lsl2, lua, m68k, magiksf, make, mapbasic, matlab, mirc, mmix, modula2, modula3, mpasm, mxml, mysql, nagios, netrexx, newlisp, nsis, oberon2, objc, objeck, ocaml, ocaml-brief, octave, oobas, oorexx, oracle11, oracle8, oxygene, oz, parasail, parigp, pascal, pcre, per, perl, perl6, pf, php, php-brief, pic16, pike, pixelbender, pli, plsql, postgresql, povray, powerbuilder, powershell, proftpd, progress, prolog, properties, providex, purebasic, pycon, pys60, python, q, qbasic, rails, rebol, reg, rexx, robots, rpmspec, rsplus, ruby, sas, scala, scheme, scilab, sdlbasic, smalltalk, smarty, spark, sparql, sql, stonescript, systemverilog, tcl, teraterm, text, thinbasic, tsql, typoscript, unicon, upc, urbi, uscript, vala, vb, vbnet, vedit, verilog, vhdl, vim, visualfoxpro, visualprolog, whitespace, whois, winbatch, xbasic, xml, xorg_conf, xpp, yaml, z80, zxbasic
composer require spatie/laravel-permission
- Para que autocomplete en phpstorm los métodos
Idioma no válido.
Necesita especificar un idioma como esto: <source lang="html4strict">...</source>
lenguajes soportados para sintaxis remarcada:
4cs, 6502acme, 6502kickass, 6502tasm, 68000devpac, abap, actionscript, actionscript3, ada, algol68, apache, applescript, apt_sources, arm, asm, asp, asymptote, autoconf, autohotkey, autoit, avisynth, awk, bascomavr, bash, basic4gl, bf, bibtex, blitzbasic, bnf, boo, c, c_loadrunner, c_mac, caddcl, cadlisp, cfdg, cfm, chaiscript, cil, clojure, cmake, cobol, coffeescript, cpp, cpp-qt, csharp, css, cuesheet, d, dcl, dcpu16, dcs, delphi, diff, div, dos, dot, e, ecmascript, eiffel, email, epc, erlang, euphoria, f1, falcon, fo, fortran, freebasic, freeswitch, fsharp, gambas, gdb, genero, genie, gettext, glsl, gml, gnuplot, go, groovy, gwbasic, haskell, haxe, hicest, hq9plus, html4strict, html5, icon, idl, ini, inno, intercal, io, j, java, java5, javascript, jquery, kixtart, klonec, klonecpp, latex, lb, ldif, lisp, llvm, locobasic, logtalk, lolcode, lotusformulas, lotusscript, lscript, lsl2, lua, m68k, magiksf, make, mapbasic, matlab, mirc, mmix, modula2, modula3, mpasm, mxml, mysql, nagios, netrexx, newlisp, nsis, oberon2, objc, objeck, ocaml, ocaml-brief, octave, oobas, oorexx, oracle11, oracle8, oxygene, oz, parasail, parigp, pascal, pcre, per, perl, perl6, pf, php, php-brief, pic16, pike, pixelbender, pli, plsql, postgresql, povray, powerbuilder, powershell, proftpd, progress, prolog, properties, providex, purebasic, pycon, pys60, python, q, qbasic, rails, rebol, reg, rexx, robots, rpmspec, rsplus, ruby, sas, scala, scheme, scilab, sdlbasic, smalltalk, smarty, spark, sparql, sql, stonescript, systemverilog, tcl, teraterm, text, thinbasic, tsql, typoscript, unicon, upc, urbi, uscript, vala, vb, vbnet, vedit, verilog, vhdl, vim, visualfoxpro, visualprolog, whitespace, whois, winbatch, xbasic, xml, xorg_conf, xpp, yaml, z80, zxbasic
https://spatie.be/docs/laravel-permission/v3/advanced-usage/phpstorm
- Una vez que tenemos creada la aplicación vamos a realizar los roles y permisos
Seguimos el post arriba indicado
- Instalamos el paquete por composer
- Incluimos todos los recursos asociados al paquete que acabamos de instalr
- Creamos las tablas con las migraciones creadas
- role_has_permissions
- model_has_roles
- model_has_permissions
- roles
- permissions
- Este paquete implementa un trait HasRoles (https://diego.com.es/traits-en-php) el cual hay que incorporar a la tabla User, ya que se pretende dar a cada usuario permisos específicos o grupo de permisos (roles)
... use Spatie\Permission\Traits\HasRoles; class User extends Authenticatable { use Notifiable, HasRoles; ... }