Nie jesteś zalogowany.
Jeśli nie posiadasz konta, zarejestruj je już teraz! Pozwoli Ci ono w pełni korzystać z naszego serwisu. Spamerom dziękujemy!
Prosimy o pomoc dla małej Julki — przekaż 1% podatku na Fundacji Dzieciom zdazyć z Pomocą.
Więcej informacji na dug.net.pl/pomagamy/.
Witam
poszukuję sposobu na rozwiązanie ACL w tworzonym CMS ,chciałbym by użytkownikowi mógł przyznawać prawa podobnie jak to jest w forum phpbb3 ,czy zablokować edycje tworzonych postów , nadać dostęp tylko do określonych działów serwisu itp , zapoznałem się z phpgacl ,ale sam skrypt średnio mi się spodobał, ponieważ generuje bardzo dużą ilość zapytań do SQL ,(czasami po 400 )
Offline
http://artykuly.zyxist.com/czytaj.php/system_uprawnien_w_php , pasuje?
3 wynik w google po wpisaniu "php acl". Nie rozumiem jak może być szybciej machnąć posta na forum niż wpisać 2 słowa w googlach.
Offline
Skoro sam tworzysz CMS, to nie lepiej napisać coś autorskiego, specjalnie na Twoje potrzeby ?
Pozdrawiam
Offline
mozesz zastosowac ACL'a z Zend Frameworka
Offline
hmmm.. czy tak trudno dodać kolumnę do bazy z userami o nazwie alevel i do tego klasę regulującą poziomy?
Dlaczego korzystać z gotowców skoro można to zrobić samemu. Jak zrobisz to sam to doskonalisz swój tok rozumowania/programowania. Zresztą jeśli sam to zrobisz kto wie czy nie zrobisz tego lepiej.
Ostatnio edytowany przez blinki (2011-06-19 12:55:48)
Offline
@blinki, frameworki powstaly po to, aby nie robic 1000x tego samo i zeby szybciej tworzyc oprogramowanie, wlasnie dla tego a jezeli Ty masz czas to prosze bardzo mozesz doktoryzowac
Offline
Nie ma się co rozwodzić i kłócić, sam autor postu wydaje się nie być zainteresowany.
Offline
No tak, ale robiąc CMS chcesz wprowadzić coś nowego coś SWOJEGO, używanie gotowców w tym przypadku mija się z celem. Ja bym się lepiej czół jak by zrobił ten system sam (niema co ukrywać ciężki i praco chłonny)
moja wizja by była taka,
SQL
create table grupy (`id` int not null auto_increment, `nazwa` varchar(30) not null, `read` text not null, `write` text not null, `lock` text not null, primary key(id))
create table członkowie_grup (`id` int not null auto_increment, `user_id` int not null, `grupa_id` int not null, `owner` int not null, primary key (id))
przy tworzeniu i edycji grupy były by check boxy z prawami do elementów frontend'u i backend'u. A potem tylko klasa kontrolująca dostęp do poszczególnych elementów.
Offline
[quote=kamikaze]Nie ma się co rozwodzić i kłócić, sam autor postu wydaje się nie być zainteresowany.[/quote]
sam autor postu w pocie czoła napisał:)
CREATE TABLE `acl_action` ( `id_action` mediumint(8) unsigned NOT NULL auto_increment, `id_module` smallint(4) unsigned NOT NULL, `action` varchar(32) NOT NULL, `inherited` tinyint(1) NOT NULL, PRIMARY KEY (`id_action`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ; -- -- Struktura tabeli dla `acl_resources` -- CREATE TABLE `acl_resources` ( `id_action` mediumint(8) unsigned NOT NULL auto_increment, -- edit `id_module` smallint(4) unsigned NOT NULL, -- post `id_resource` int(10) NOT NULL, -- id = 10 `allow` tinyint(1) NOT NULL, PRIMARY KEY (`id_action`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ; -- -- Struktura tabeli dla `acl_module` -- CREATE TABLE `acl_module` ( `id_module` smallint(4) unsigned NOT NULL auto_increment, `module` varchar(32) NOT NULL, PRIMARY KEY (`id_module`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ; -- -- Struktura tabeli dla `acl_roles` -- CREATE TABLE `acl_roles` ( `id_group` int(10) unsigned NOT NULL, `id_module` smallint(4) unsigned NOT NULL, `id_action` mediumint(8) unsigned NOT NULL, `allow` tinyint(1) NOT NULL, PRIMARY KEY (`id_group`,`id_module`,`id_action`) ) ENGINE=InnoDB DEFAULT CHARSET=utf8; SELECT allow, m.module , a.action FROM acl_roles r LEFT JOIN acl_module m ON ( r.id_module = m.id_module ) LEFT JOIN acl_action a ON ( r.id_action = a.id_action ) LEFT JOIN users u ON ( r.id_group = u.group_id ) WHERE u.id = 2 AND m.module = 'admin' AND a.action = 'page'
coś takiego znalezionego w necie , na chwile obecną zdaje egzamin ,a dodatkwo wspomagane memcached nie zamula serwera
Offline
No i super. Blinki trochę cienka ta twoja wizja i jakby ma niewiele wspólnego z ACL. No i pola text dla checkboxów, ble.
Offline
[edit]
Ostatnio edytowany przez szewczyk (2012-01-15 18:02:20)
Offline
Time (s) | Query |
---|---|
0.00009 | SET CHARSET latin2 |
0.00004 | SET NAMES latin2 |
0.00111 | SELECT u.*, g.*, o.logged FROM punbb_users AS u INNER JOIN punbb_groups AS g ON u.group_id=g.g_id LEFT JOIN punbb_online AS o ON o.ident='13.58.18.135' WHERE u.id=1 |
0.00087 | REPLACE INTO punbb_online (user_id, ident, logged) VALUES(1, '13.58.18.135', 1732492902) |
0.00056 | SELECT * FROM punbb_online WHERE logged<1732492602 |
0.00055 | SELECT topic_id FROM punbb_posts WHERE id=175344 |
0.00213 | SELECT id FROM punbb_posts WHERE topic_id=19165 ORDER BY posted |
0.00072 | SELECT t.subject, t.closed, t.num_replies, t.sticky, f.id AS forum_id, f.forum_name, f.moderators, fp.post_replies, 0 FROM punbb_topics AS t INNER JOIN punbb_forums AS f ON f.id=t.forum_id LEFT JOIN punbb_forum_perms AS fp ON (fp.forum_id=f.id AND fp.group_id=3) WHERE (fp.read_forum IS NULL OR fp.read_forum=1) AND t.id=19165 AND t.moved_to IS NULL |
0.00005 | SELECT search_for, replace_with FROM punbb_censoring |
0.00085 | SELECT u.email, u.title, u.url, u.location, u.use_avatar, u.signature, u.email_setting, u.num_posts, u.registered, u.admin_note, p.id, p.poster AS username, p.poster_id, p.poster_ip, p.poster_email, p.message, p.hide_smilies, p.posted, p.edited, p.edited_by, g.g_id, g.g_user_title, o.user_id AS is_online FROM punbb_posts AS p INNER JOIN punbb_users AS u ON u.id=p.poster_id INNER JOIN punbb_groups AS g ON g.g_id=u.group_id LEFT JOIN punbb_online AS o ON (o.user_id=u.id AND o.user_id!=1 AND o.idle=0) WHERE p.topic_id=19165 ORDER BY p.id LIMIT 0,25 |
0.00095 | UPDATE punbb_topics SET num_views=num_views+1 WHERE id=19165 |
Total query time: 0.00792 s |