我需要在没有用户身份验证的情况下在我的日历中插入事件。
变量:
OOB_URI = 'urn:ietf:wg:oauth:2.0:oob'
APPLICATION_NAME = 'Google Calendar API Ruby Quickstart'
CLIENT_SECRETS_PATH = './lib/client_secret.json'
CREDENTIALS_PATH = File.join(Dir.home, '.credentials',
"calendar-ruby-quickstart.yaml")
SCOPE = Google::Apis::CalendarV3::AUTH_CALENDAR
def initialize(meeting_data)
@meeting_data = meeting_data
end
授权流程:
def authorize
FileUtils.mkdir_p(File.dirname(CREDENTIALS_PATH))
client_id = Google::Auth::ClientId.from_file(CLIENT_SECRETS_PATH)
token_store = Google::Auth::Stores::FileTokenStore.new(file: CREDENTIALS_PATH)
authorizer = Google::Auth::UserAuthorizer.new(
client_id, SCOPE, token_store)
user_id = '2'
credentials = authorizer.get_credentials(user_id)
if credentials.nil?
url = authorizer.get_authorization_url(
base_url: OOB_URI)
puts "Open the following URL in the browser and enter the " +
"resulting code after authorization"
puts url
code = gets
credentials = authorizer.get_and_store_credentials_from_code(
user_id: user_id, code: code, base_url: OOB_URI)
end
credentials
end
创建方法:
def create_meeting
# Initialize the API
service = Google::Apis::CalendarV3::CalendarService.new
service.client_options.application_name = APPLICATION_NAME
service.authorization = authorize
...
# Create event end post
...
end
当我开始使用这种方法时,我必须制作一些控制台技巧(我从谷歌获取一个令牌并将它们移到控制台中)并在事件发布之后。我可以自动化这个过程吗?或者使用寿命很长的令牌?
此过程必须在没有用户的情况下运行。
答案 0 :(得分:1)
我找到了解决方案。需要使用服务器到服务器身份验证。