--- webform.module_orig	2009-01-18 19:40:14.000000000 -0500
+++ webform.module	2009-01-18 19:40:15.000000000 -0500
@@ -64,7 +64,7 @@ function webform_help($section = 'admin/
  */
 function webform_menu() {
   $items = array();
-
+  
   // Submissions listing.
   $items['admin/content/webform'] = array(
     'title' => 'Webforms',
@@ -144,7 +144,7 @@ function webform_menu() {
     'page callback' => 'webform_results_submissions',
     'page arguments' => array(1, FALSE, '50'),
     'access callback' => 'webform_results_access',
-    'access arguments' => array(1, 'access webform results'),
+    'access arguments' => array(1),
     'file' => 'webform_report.inc',
     'weight' => 2,
     'type' => MENU_LOCAL_TASK,
@@ -154,7 +154,7 @@ function webform_menu() {
     'page callback' => 'webform_results_submissions',
     'page arguments' => array(1, FALSE, '50'),
     'access callback' => 'webform_results_access',
-    'access arguments' => array(1, 'access webform results'),
+    'access arguments' => array(1),
     'file' => 'webform_report.inc',
     'weight' => 4,
     'type' => MENU_DEFAULT_LOCAL_TASK,
@@ -164,7 +164,7 @@ function webform_menu() {
     'page callback' => 'webform_results_analysis',
     'page arguments' => array(1),
     'access callback' => 'webform_results_access',
-    'access arguments' => array(1, 'access webform results'),
+    'access arguments' => array(1),
     'file' => 'webform_report.inc',
     'weight' => 5,
     'type' => MENU_LOCAL_TASK,
@@ -174,7 +174,7 @@ function webform_menu() {
     'page callback' => 'webform_results_table',
     'page arguments' => array(1, '50'),
     'access callback' => 'webform_results_access',
-    'access arguments' => array(1, 'access webform results'),
+    'access arguments' => array(1),
     'file' => 'webform_report.inc',
     'weight' => 6,
     'type' => MENU_LOCAL_TASK,
@@ -184,7 +184,7 @@ function webform_menu() {
     'page callback' => 'drupal_get_form',
     'page arguments' => array('webform_results_download_form', 1),
     'access callback' => 'webform_results_access',
-    'access arguments' => array(1, 'access webform results'),
+    'access arguments' => array(1),
     'file' => 'webform_report.inc',
     'weight' => 7,
     'type' => MENU_LOCAL_TASK,
@@ -193,7 +193,7 @@ function webform_menu() {
     'title' => 'Clear',
     'page callback' => 'drupal_get_form',
     'page arguments' => array('webform_results_clear_form', 1),
-    'access callback' => 'webform_results_access',
+    'access callback' => 'webform_results_clear_access',
     'access arguments' => array(1, 'clear webform results'),
     'file' => 'webform_report.inc',
     'weight' => 8,
@@ -299,20 +299,25 @@ function webform_submission_access($node
 
   switch ($op) {
     case 'view':
-      return user_access('access webform results') || (user_access('access own webform submissions') && ($account->uid == $submission->uid));
+      return user_access('access webform results') || (user_access('access own webform submissions') && ($account->uid == $submission->uid)) || (user_access('access own webform results') && $user->uid == $node->uid);
     case 'edit':
       return user_access('edit webform submissions') || (user_access('edit own webform submissions') && ($account->uid == $submission->uid));
     case 'delete':
       return user_access('edit webform submissions') || (user_access('edit own webform submissions') && ($account->uid == $submission->uid)) || user_access('clear webform results');
     case 'list':
-      return user_access('access webform results') || user_access('access webform submissions') || (user_access('access own webform submissions')  && $user->uid);
+      return user_access('access webform results') || user_access('access webform submissions') || (user_access('access own webform submissions')  && $user->uid) || (user_access('access own webform results') && $user->uid == $node->uid);
   }
 }
 
 /**
  * Menu access callback. Ensure a user both access and node 'view' permission.
  */
-function webform_results_access($node, $perm) {
+function webform_results_access($node) {
+  global $user;
+  return (node_access('view', $node) && (user_access('access webform results') || (user_access('access own webform results') && $user->uid == $node->uid)));
+}
+
+function webform_results_clear_access($node, $perm) {
   return node_access('view', $node) && user_access($perm);
 }
 
@@ -320,7 +325,7 @@ function webform_results_access($node, $
  * Implementation of hook_perm().
  */
 function webform_perm() {
-  return array('create webforms', 'edit own webforms', 'edit webforms', 'access webform results', 'clear webform results', 'access own webform submissions', 'edit own webform submissions', 'edit webform submissions', 'use PHP for additional processing');
+  return array('create webforms', 'edit own webforms', 'edit webforms', 'access webform results', 'access own webform results', 'clear webform results', 'access own webform submissions', 'edit own webform submissions', 'edit webform submissions', 'use PHP for additional processing');
 }
 
 /**
@@ -453,8 +458,9 @@ function webform_forms($form_id) {
  * Only allow users with view webform submissions to download files.
  */
 function webform_file_download($file) {
+  global $user;
   $file = file_check_location(file_directory_path() .'/'. $file, file_directory_path() .'/webform/');
-  if ($file && user_access('access webform results')) {
+  if ($file && (user_access('access webform results') || (user_access('access own webform results') && $user->uid == $node->uid))) {
     $info = image_get_info(file_create_path($file));
     if (isset($info['mime_type'])) {
       $headers = array('Content-type: '. $info['mime_type']);
@@ -1099,7 +1105,7 @@ function webform_view(&$node, $teaser = 
   }
 
   // Get a count of previous submissions by this user.
-  if ($user->uid && (user_access('access own webform submissions') || user_access('access webform results') || user_access('access webform submissions'))) {
+  if ($user->uid && (user_access('access own webform submissions') || user_access('access webform results') || user_access('access webform submissions') || (user_access('access own webform results') && $user->uid == $node->uid))) {
     $submission_count = db_result(db_query('SELECT count(*) FROM {webform_submissions} WHERE nid = %d AND uid = %d', $node->nid, $user->uid));
   }
 
@@ -1375,6 +1381,7 @@ function webform_client_form_load($node,
  *   editing.
  */
 function webform_client_form($form_state, &$node, $submission, $enabled = FALSE, $preview = FALSE) {
+  global $user;
   module_load_include('inc', 'webform', 'webform_components');
   webform_load_components();
 
@@ -1383,7 +1390,7 @@ function webform_client_form($form_state
   }
 
   // Set a header for navigating results.
-  if ($submission && user_access('access webform results')) {
+  if ($submission && (user_access('access webform results') || (user_access('access own webform results') && $user->uid == $node->uid))) {
     // Add CSS to display submission info. Don't preprocess because this CSS file is used rarely.
     drupal_add_css(drupal_get_path('module', 'webform') .'/webform.css', 'module', 'all', FALSE);
 
