最新消息:雨落星辰是一个专注网站SEO优化、网站SEO诊断、搜索引擎研究、网络营销推广、网站策划运营及站长类的自媒体原创博客

python - Gmail Oauth2 - restrict the scope to only emails from a certain domain - Stack Overflow

programmeradmin2浏览0评论

I have a Django site that uses Google Oauth2 to allow users to grant access to read and reply to their emails.

GOOGLE_OAUTH2_CREDENTIALS = {
    'client_id': '********************',
    'client_secret': '*******',
    'scope': [
        '.readonly',
        '.send'
    ],
    'redirect_uri': 'https://www.********/*****/',
}

However, for privacy and security purposes I want to set restrict the scope to only being able to read and reply to emails from a specific domain.

Is it possible to modify the scope to only allow the permissions within for emails to/from a certain domain?

I have a Django site that uses Google Oauth2 to allow users to grant access to read and reply to their emails.

GOOGLE_OAUTH2_CREDENTIALS = {
    'client_id': '********************',
    'client_secret': '*******',
    'scope': [
        'https://www.googleapis/auth/gmail.readonly',
        'https://www.googleapis/auth/gmail.send'
    ],
    'redirect_uri': 'https://www.********/*****/',
}

However, for privacy and security purposes I want to set restrict the scope to only being able to read and reply to emails from a specific domain.

Is it possible to modify the scope to only allow the permissions within for emails to/from a certain domain?

Share Improve this question asked Feb 4 at 17:15 Kovy JacobKovy Jacob 1,1218 silver badges24 bronze badges
Add a comment  | 

1 Answer 1

Reset to default 1

No.

Here's the list of scopes available for the Gmail API.

As of the time of writing this answer, none of them let you define this kind of access restriction. In fact, none of them support anything that can even resemble row- or object-level security. You either have the ability to perform the action described in the scope, or you don't - and if you have it, then you have it universally.

发布评论

评论列表(0)

  1. 暂无评论
ok 不同模板 switch ($forum['model']) { /*case '0': include _include(APP_PATH . 'view/htm/read.htm'); break;*/ default: include _include(theme_load('read', $fid)); break; } } break; case '10': // 主题外链 / thread external link http_location(htmlspecialchars_decode(trim($thread['description']))); break; case '11': // 单页 / single page $attachlist = array(); $imagelist = array(); $thread['filelist'] = array(); $threadlist = NULL; $thread['files'] > 0 and list($attachlist, $imagelist, $thread['filelist']) = well_attach_find_by_tid($tid); $data = data_read_cache($tid); empty($data) and message(-1, lang('data_malformation')); $tidlist = $forum['threads'] ? page_find_by_fid($fid, $page, $pagesize) : NULL; if ($tidlist) { $tidarr = arrlist_values($tidlist, 'tid'); $threadlist = well_thread_find($tidarr, $pagesize); // 按之前tidlist排序 $threadlist = array2_sort_key($threadlist, $tidlist, 'tid'); } $allowpost = forum_access_user($fid, $gid, 'allowpost'); $allowupdate = forum_access_mod($fid, $gid, 'allowupdate'); $allowdelete = forum_access_mod($fid, $gid, 'allowdelete'); $access = array('allowpost' => $allowpost, 'allowupdate' => $allowupdate, 'allowdelete' => $allowdelete); $header['title'] = $thread['subject']; $header['mobile_link'] = $thread['url']; $header['keywords'] = $thread['keyword'] ? $thread['keyword'] : $thread['subject']; $header['description'] = $thread['description'] ? $thread['description'] : $thread['brief']; $_SESSION['fid'] = $fid; if ($ajax) { empty($conf['api_on']) and message(0, lang('closed')); $apilist['header'] = $header; $apilist['extra'] = $extra; $apilist['access'] = $access; $apilist['thread'] = well_thread_safe_info($thread); $apilist['thread_data'] = $data; $apilist['forum'] = $forum; $apilist['imagelist'] = $imagelist; $apilist['filelist'] = $thread['filelist']; $apilist['threadlist'] = $threadlist; message(0, $apilist); } else { include _include(theme_load('single_page', $fid)); } break; default: message(-1, lang('data_malformation')); break; } ?>