Google 日历 API 插入未经授权的事件 Rails
Google Calendar API insert event without auth Rails
我需要在没有用户授权的情况下在我的日历中插入事件。
变量:
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
当我开始这个方法时,我必须做一些控制台技巧(我从 google 中获取一个令牌并将它们传递到控制台中)并在该事件发布之后。我可以自动化这个过程吗?还是取长寿命的token?
此过程必须在没有用户的情况下运行。
我找到了解决方案。需要使用服务器到服务器身份验证。
下一页有这个解决方案:
我需要在没有用户授权的情况下在我的日历中插入事件。
变量:
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
当我开始这个方法时,我必须做一些控制台技巧(我从 google 中获取一个令牌并将它们传递到控制台中)并在该事件发布之后。我可以自动化这个过程吗?还是取长寿命的token?
此过程必须在没有用户的情况下运行。
我找到了解决方案。需要使用服务器到服务器身份验证。
下一页有这个解决方案: