better_formats.admin_defaults.inc 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240
  1. <?php
  2. /**
  3. * @file
  4. * Contains FAPI and theme functions for the format defaults form.
  5. */
  6. /**
  7. * Builds the form for the filters admin.
  8. *
  9. * @return
  10. * FAPI array
  11. *
  12. * @see better_formats_defaults_admin_form_validate()
  13. * @see better_formats_defaults_admin_form_submit()
  14. */
  15. function better_formats_defaults_admin_form($form, &$form_state) {
  16. // Ensure all roles have a BF default entries in the database.
  17. better_formats_check_roles();
  18. // Build defaults form.
  19. $form = array(
  20. '#tree' => TRUE,
  21. );
  22. $nform = better_formats_get_role_default_fields('node');
  23. $cform = better_formats_get_role_default_fields('comment');
  24. $bform = better_formats_get_role_default_fields('block');
  25. $form = array_merge($form, $nform, $cform, $bform);
  26. $form['submit'] = array(
  27. '#type' => 'submit',
  28. '#value' => t('Save defaults'),
  29. );
  30. return $form;
  31. }
  32. /**
  33. * Validates better_formats_admin_filter_form.
  34. *
  35. * @see better_formats_defaults_admin_form()
  36. * @see better_formats_defaults_admin_form_submit()
  37. */
  38. function better_formats_defaults_admin_form_validate($form, &$form_state) {
  39. $formats = filter_formats();
  40. foreach ($formats as $fid => $format) {
  41. $roles[$fid] = explode(',', $format->roles);
  42. }
  43. // Get roles that have administer filters permission.
  44. $admin_roles = better_formats_get_roles_by_perm('administer filters');
  45. foreach ($form_state['values'] as $key => $values) {
  46. if (strpos($key, 'node-') === 0 || strpos($key, 'comment-') === 0 || strpos($key, 'block-') === 0) {
  47. list($type, $rid) = explode('-', $key);
  48. if (in_array($rid, $admin_roles)) {
  49. // Role has the 'administer filters' permission so it can use all formats.
  50. continue;
  51. }
  52. $fid = $values['format'];
  53. $site_default = filter_resolve_format(FILTER_FORMAT_DEFAULT);
  54. if ($fid != 0 && !in_array($rid, $roles[$fid]) && $fid !== $site_default) {
  55. form_set_error($key, t('Role does not have access to selected format.'));
  56. }
  57. }
  58. }
  59. }
  60. /**
  61. * Updates database from better_formats_admin_filter_form.
  62. *
  63. * @see better_formats_defaults_admin_form()
  64. * @see better_formats_defaults_admin_form_validate()
  65. */
  66. function better_formats_defaults_admin_form_submit($form, &$form_state) {
  67. // Update DB.
  68. $sql = "UPDATE {better_formats_defaults}
  69. SET format=%d, weight=%d
  70. WHERE rid=%d AND type='%s'";
  71. foreach ($form_state['values'] as $key => $values) {
  72. if (strpos($key, 'node-') === 0 || strpos($key, 'comment-') === 0 || strpos($key, 'block-') === 0) {
  73. list($type, $rid) = explode('-', $key);
  74. db_query($sql, $values['format'], $values['weight'], $rid, $type);
  75. }
  76. }
  77. drupal_set_message(t('Defaults have been saved.'));
  78. }
  79. /**
  80. * Builds FAPI form elements for the default format selection.
  81. *
  82. * @param $mode
  83. * 'node', 'comment', or 'block'. Top most level type for requested default.
  84. * @param $node_type
  85. * Type of node this request is for.
  86. * @return
  87. * FAPI array for the default select field.
  88. */
  89. function better_formats_get_role_default_fields($mode, $node_type = '') {
  90. $form = array();
  91. $format_options = better_formats_get_formats_per_role();
  92. $type = $types = $mode;
  93. $per_node_type = variable_get('better_formats_per_node_type', FALSE);
  94. if ($per_node_type && $node_type) {
  95. $type = $mode . '/' . $node_type;
  96. $types = $type . "','" . $mode;
  97. }
  98. // get data from db
  99. $sql = "SELECT bf.*, role.name
  100. FROM {better_formats_defaults} AS bf
  101. INNER JOIN {role} AS role
  102. ON bf.rid = role.rid
  103. WHERE bf.type IN ('$types')
  104. ORDER BY bf.type_weight DESC, bf.weight, role.rid";
  105. $result = db_query($sql);
  106. $roles_set = array();
  107. while ($role = db_fetch_object($result)) {
  108. if (in_array($role->rid, $roles_set)) {
  109. continue;
  110. }
  111. $roles_set[] = $role->rid;
  112. $key = $mode . '-' . $role->rid;
  113. $form[$key]['role'] = array(
  114. '#value' => $role->name,
  115. );
  116. $form[$key]['format'] = array(
  117. '#type' => 'select',
  118. '#options' => $format_options[$role->rid],
  119. '#default_value' => $role->format,
  120. '#attributes' => array('class' => 'bf-default-formats'),
  121. );
  122. $form[$key]['weight'] = array(
  123. '#type' => 'weight',
  124. '#delta' => 25,
  125. '#default_value' => $role->weight,
  126. );
  127. }
  128. return $form;
  129. }
  130. /**
  131. * Retrieve the formats available to users by role.
  132. *
  133. * Gets all formats then creates an array keyed by role IDs
  134. * that lists the formats available to that role. This is determined
  135. * by Drupal core's format permissions set at
  136. * admin/settings/filters/[filter_id].
  137. *
  138. * @return
  139. * Multi-dim array with role IDs for keys and list of allowed formats.
  140. *
  141. * @see better_formats_get_role_default_fields()
  142. */
  143. function better_formats_get_formats_per_role() {
  144. $formats = filter_formats();
  145. $roles = user_roles();
  146. // Get roles that have administer filters permission.
  147. $admin_roles = better_formats_get_roles_by_perm('administer filters');
  148. $site_default_format = filter_resolve_format(FILTER_FORMAT_DEFAULT);
  149. foreach ($formats as $format) {
  150. $roles_allowed = $format->roles ? explode(',', trim($format->roles, ',')) : array();
  151. foreach ($roles as $rid => $role) {
  152. $format_options[$rid][0] = t('Site default');
  153. if ($format->format == $site_default_format || in_array($rid, $admin_roles) || in_array($rid, $roles_allowed)) {
  154. $format_options[$rid][$format->format] = $format->name;
  155. }
  156. }
  157. }
  158. return $format_options;
  159. }
  160. /**
  161. * Get a list of roles that have a permission.
  162. *
  163. * @param $perm
  164. * Permission string to get roles for.
  165. * @param $reset
  166. * Boolean to clear static cache.
  167. * @return
  168. * An array of role IDs that have the requested permission.
  169. */
  170. function better_formats_get_roles_by_perm($perm, $reset = FALSE) {
  171. static $roles;
  172. if ($reset || !isset($roles[$perm])) {
  173. $sql = "SELECT rid
  174. FROM {permission}
  175. WHERE perm LIKE '%$perm%'
  176. ORDER BY rid";
  177. $result = db_query($sql);
  178. $roles[$perm] = array();
  179. while ($row = db_fetch_object($result)) {
  180. $roles[$perm][] = $row->rid;
  181. }
  182. }
  183. return $roles[$perm];
  184. }
  185. /**
  186. * Process variables for better-defaults-admin-form.tpl.php.
  187. *
  188. * @param $vars
  189. * The $variables array contains the following arguments:
  190. * - $form
  191. */
  192. function template_preprocess_better_formats_defaults_admin_form(&$vars) {
  193. foreach (element_children($vars['form']) as $key) {
  194. $form_row = &$vars['form'][$key];
  195. //$type = strpos($key, 'node-') === 0 ? 'node' : 'comment';
  196. $type = substr($key, 0, strpos($key, '-'));
  197. if (isset($form_row['role'])) {
  198. // Set special classes needed for table drag and drop.
  199. $form_row['weight']['#attributes']['class'] = 'better-formats-role-' . $type . '-weight';
  200. $row = new stdClass();
  201. $row->role = drupal_render($form_row['role']);
  202. $row->format_select = drupal_render($form_row['format']);
  203. $row->weight_select = drupal_render($form_row['weight']);
  204. $vars[$type . '_default_rows'][$key] = $row;
  205. }
  206. }
  207. $vars['form_submit'] = drupal_render($vars['form']);
  208. }