Где хранятся данные о ролях Drupal Organic Group?Как мне получить к нему доступ? - PullRequest
1 голос
/ 01 сентября 2011

Я создал пользовательскую роль для своей группы. Я назначил пользователя, который был членом группы, для этой особой роли. Теперь я хочу получить доступ к роли пользователя в группе через PHP, но нигде не могу ее найти.
Я изучал Devels как пользователя, так и группы. Я могу получить доступ к тому факту, что пользователь является членом группы в массиве group_audience пользователя, но не определяет, какая у него роль в этой группе.

Любой совет?

Редактировать: Drupal 7

1 Ответ

3 голосов
/ 15 февраля 2012

Редактировать: Сначала есть некоторый фон, затем фактический ответ.

Фон

Глядя в базу данных mySQL на нашем сервере разработки, похоже, в нашей базе данных Drupal есть несколько таблиц, связанных с OG. Я уверен, что на devserver работает версия og-7.x-1.x-dev.

  • og
  • og_membership
  • og_membership_type
  • og_menu
  • og_role
  • og_role_permission
  • og_users_roles
  • field_data_og_membership_request
  • field_revision_og_membership_request

Их определения выглядят так:

mysql> describe og;
+-------------+------------------+------+-----+---------+----------------+
| Field       | Type             | Null | Key | Default | Extra          |
+-------------+------------------+------+-----+---------+----------------+
| gid         | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| etid        | int(10) unsigned | NO   | MUL | 0       |                |
| entity_type | varchar(32)      | NO   |     |         |                |
| label       | varchar(255)     | NO   |     |         |                |
| state       | int(11)          | NO   |     | 1       |                |
| created     | int(11)          | NO   |     | 0       |                |
+-------------+------------------+------+-----+---------+----------------+
6 rows in set (0.02 sec)

mysql> describe og_membership;
+-------------+------------------+------+-----+---------+----------------+
| Field       | Type             | Null | Key | Default | Extra          |
+-------------+------------------+------+-----+---------+----------------+
| id          | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| type        | varchar(255)     | NO   |     |         |                |
| etid        | int(10) unsigned | NO   | MUL | 0       |                |
| entity_type | varchar(32)      | NO   |     |         |                |
| gid         | int(11)          | NO   | MUL | NULL    |                |
| state       | varchar(255)     | YES  |     |         |                |
| created     | int(11)          | NO   |     | 0       |                |
+-------------+------------------+------+-----+---------+----------------+
7 rows in set (0.00 sec)

mysql> describe og_membership_type;
+-------------+--------------+------+-----+---------+----------------+
| Field       | Type         | Null | Key | Default | Extra          |
+-------------+--------------+------+-----+---------+----------------+
| id          | int(11)      | NO   | PRI | NULL    | auto_increment |
| name        | varchar(255) | NO   | UNI |         |                |
| description | varchar(255) | NO   |     |         |                |
| status      | tinyint(4)   | NO   |     | 1       |                |
| module      | varchar(255) | YES  |     | NULL    |                |
+-------------+--------------+------+-----+---------+----------------+
5 rows in set (0.00 sec)

mysql> describe og_menu;
+-----------+--------------+------+-----+---------+-------+
| Field     | Type         | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+-------+
| gid       | int(11)      | NO   | PRI | NULL    |       |
| menu_name | varchar(128) | NO   | PRI |         |       |
+-----------+--------------+------+-----+---------+-------+
2 rows in set (0.00 sec)

mysql> describe og_role;
+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| rid   | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| gid   | int(11)          | NO   |     | NULL    |                |
| name  | varchar(64)      | NO   |     |         |                |
+-------+------------------+------+-----+---------+----------------+
3 rows in set (0.00 sec)

mysql> describe og_role_permission;
+------------+------------------+------+-----+---------+-------+
| Field      | Type             | Null | Key | Default | Extra |
+------------+------------------+------+-----+---------+-------+
| rid        | int(10) unsigned | NO   | PRI | NULL    |       |
| permission | varchar(64)      | NO   | PRI |         |       |
| module     | varchar(255)     | NO   |     |         |       |
+------------+------------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> describe og_users_roles;
+-------+------------------+------+-----+---------+-------+
| Field | Type             | Null | Key | Default | Extra |
+-------+------------------+------+-----+---------+-------+
| uid   | int(10) unsigned | NO   | PRI | 0       |       |
| rid   | int(10) unsigned | NO   | PRI | 0       |       |
| gid   | int(11)          | NO   | PRI | NULL    |       |
+-------+------------------+------+-----+---------+-------+
3 rows in set (0.00 sec)

mysql> describe field_data_og_membership_request;
+------------------------------+------------------+------+-----+---------+
| Field                        | Type             | Null | Key | Default |
+------------------------------+------------------+------+-----+---------+
| entity_type                  | varchar(128)     | NO   | PRI |         |
| bundle                       | varchar(128)     | NO   | MUL |         |
| deleted                      | tinyint(4)       | NO   | PRI | 0       |
| entity_id                    | int(10) unsigned | NO   | PRI | NULL    |
| revision_id                  | int(10) unsigned | YES  | MUL | NULL    |
| language                     | varchar(32)      | NO   | PRI |         |
| delta                        | int(10) unsigned | NO   | PRI | NULL    |
| og_membership_request_value  | longtext         | YES  |     | NULL    |
| og_membership_request_format | varchar(255)     | YES  | MUL | NULL    |
+------------------------------+------------------+------+-----+---------+
9 rows in set (0.00 sec)

mysql> describe field_revision_og_membership_request;
+------------------------------+------------------+------+-----+---------+
| Field                        | Type             | Null | Key | Default |
+------------------------------+------------------+------+-----+---------+
| entity_type                  | varchar(128)     | NO   | PRI |         |
| bundle                       | varchar(128)     | NO   | MUL |         |
| deleted                      | tinyint(4)       | NO   | PRI | 0       |
| entity_id                    | int(10) unsigned | NO   | PRI | NULL    |
| revision_id                  | int(10) unsigned | NO   | PRI | NULL    |
| language                     | varchar(32)      | NO   | PRI |         |
| delta                        | int(10) unsigned | NO   | PRI | NULL    |
| og_membership_request_value  | longtext         | YES  |     | NULL    |
| og_membership_request_format | varchar(255)     | YES  | MUL | NULL    |
+------------------------------+------------------+------+-----+---------+
9 rows in set (0.00 sec)

(я удалил пустой столбец «Дополнительно» из двух таблиц field_*, чтобы избежать горизонтальной прокрутки.) Надеюсь, это поможет?

Мои работы

Мне просто пришлось поиграть с этим на моем собственном сайте в Drupal, и оказалось, что og_membership имеет строку для каждого пользователя в каждой группе (я сократил type, который читается как og_membership_type_default):

mysql> select * from og_membership where gid = 324 and etid = 182905;
+--------+-----------------+--------+-------------+-----+-------+------------+
| id     | type            | etid   | entity_type | gid | state | created    |
+--------+-----------------+--------+-------------+-----+-------+------------+
| 223562 | og_m..._default | 182905 | user        | 324 | 1     | 1329388409 |
+--------+-----------------+--------+-------------+-----+-------+------------+
1 row in set (0.01 sec)

В этой строке id является идентификатором автоинкрементации для таблицы og_membership, etid соответствует users.uid для рассматриваемого пользователя, а gid соответствует og.gid для рассматриваемая группа.

Так что, если я выполню запрос

update og_membership set gid = 38 where gid = 324;

затем все члены группы # 324 перемещаются в группу # 38 (что мне просто нужно было сделать из-за ошибки в скрипте импорта).

Я думаю ответ на ваш вопрос в том, что og_membership.type соответствует og_membership_type.name. Глядя на эту таблицу:

mysql> select * from og_membership_type;
+----+----------------------------+-------------+--------+--------+
| id | name                       | description | status | module |
+----+----------------------------+-------------+--------+--------+
|  1 | og_membership_type_default | Default     |      2 | og     |
+----+----------------------------+-------------+--------+--------+
1 row in set (0.00 sec)

, я думаю og_membership_type.status соответствует og_role.rid:

mysql> select * from og_role;
+-----+-----+----------------------+
| rid | gid | name                 |
+-----+-----+----------------------+
|   1 |   0 | non-member           |
|   2 |   0 | member               |
|   3 |   0 | administrator member |
+-----+-----+----------------------+
3 rows in set (0.00 sec)

Фактический ответ

Так что я думаю, что вы хотите запрос:

select og_role.name
from og_role
    inner join og_membership_type on og_role.rid = og_membership_type.status
    inner join og_membership on og_membership_type.name = og_membership.type
where og_membership.gid = $group_id;

, где $group_id - это og.gid рассматриваемой группы. (Идентификатор, который отображается в URL-адресе, - og.etid, поэтому вы можете добавить еще один join к этому запросу.

...