Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat: Support for Microsoft Oauth in Email Channel #6227

Merged
merged 51 commits into from
Jan 16, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
51 commits
Select commit Hold shift + click to select a range
f3c4fcf
fix:
tejaswinichile Dec 30, 2022
cab4aa3
fix:
tejaswinichile Dec 30, 2022
579bebc
refresh tokens and fetch the mails from ms graph
tejaswinichile Jan 3, 2023
bb5a248
fix: refresh tokens with IMAP; commented conde for the HTTParty
tejaswinichile Jan 4, 2023
3247067
refresh tokens and fetch the mails from ms graph
tejaswinichile Jan 3, 2023
d91d1dc
code cleaning, hash indifferent access fix, updated schedule class an…
tejaswinichile Jan 4, 2023
44a55ac
send email via SMTP
tejaswinichile Jan 5, 2023
c71c602
code sanity changes, addded comments and references
tejaswinichile Jan 5, 2023
7a58a70
rubocop and spec fixes
tejaswinichile Jan 6, 2023
330a36e
Feat: microsoft email channel oauth provider and fetching emails
tejaswinichile Jan 10, 2023
96368e8
minor fixes
tejaswinichile Jan 10, 2023
5f99ffa
feat: code clean up and refactoring
tejaswinichile Jan 11, 2023
48bf5b5
feat: code clean up and refactoring
tejaswinichile Jan 11, 2023
b10ccb6
Remove all the frontend code
pranavrajs Jan 12, 2023
90471d7
Merge branch 'develop' into feat/microsoft-oauth-apis
pranavrajs Jan 12, 2023
7f43ab5
feat: MS reauthorization
tejaswinichile Jan 12, 2023
cb701d6
Merge branch 'feat/microsoft-oauth-apis' of https://github.com/chatwo…
tejaswinichile Jan 12, 2023
3fe0d06
update microsoft oauth concern
tejaswinichile Jan 12, 2023
cd9e93d
PR comments changes
tejaswinichile Jan 12, 2023
d8acd5f
PR comments changes
tejaswinichile Jan 12, 2023
3c23975
Fix: Specs
tejaswinichile Jan 12, 2023
b10d0f3
Merge branch 'feat/microsoft-oauth-apis' of https://github.com/chatwo…
tejaswinichile Jan 12, 2023
8deac0f
fix: rubocop
tejaswinichile Jan 12, 2023
de416ad
fix: rubocop
tejaswinichile Jan 12, 2023
85abe97
Merge branch 'feat/microsoft-oauth-apis' of https://github.com/chatwo…
tejaswinichile Jan 12, 2023
7cc3113
Merge branch 'develop' into feat/microsoft-oauth-apis
tejaswinichile Jan 13, 2023
7521813
fix: remove comman key for redis account id setup
tejaswinichile Jan 13, 2023
d55ff39
fix: remove comman key for redis account id setup
tejaswinichile Jan 13, 2023
179fb37
fix: remove comman key for redis account id setup
tejaswinichile Jan 13, 2023
8c668f6
Merge branch 'feat/microsoft-oauth-apis' of https://github.com/chatwo…
tejaswinichile Jan 13, 2023
d5a8e05
fix: PR comments resolved
tejaswinichile Jan 13, 2023
f0bcdda
fix: moved refersh_ms_oauth_token job to service
tejaswinichile Jan 13, 2023
4b28672
chore: refactor the token service
sojan-official Jan 13, 2023
d53b077
chore: rubocop fixes
sojan-official Jan 13, 2023
2708fc2
spces for callbacks controlelr
tejaswinichile Jan 13, 2023
5d712dd
spces for callbacks controlelr
tejaswinichile Jan 13, 2023
526b83a
Merge branch 'feat/microsoft-oauth-apis' of https://github.com/chatwo…
tejaswinichile Jan 13, 2023
9d941de
Merge branch 'develop' into feat/microsoft-oauth-apis
tejaswinichile Jan 13, 2023
799f46b
fix: failing specs
tejaswinichile Jan 16, 2023
5eab1de
Merge branch 'develop' into feat/microsoft-oauth-apis
tejaswinichile Jan 16, 2023
f18d7a5
chore: remove unneccesary mocks
sojan-official Jan 16, 2023
8e55349
Merge branch 'develop' into feat/microsoft-oauth-apis
sojan-official Jan 16, 2023
908c409
chore: callback controller specs
sojan-official Jan 16, 2023
6a9f78c
chore: remove unwanted code
sojan-official Jan 16, 2023
6adebd1
chore: spec for model
sojan-official Jan 16, 2023
80d977b
chore: rubocop
sojan-official Jan 16, 2023
7da09f6
chore: more specs
sojan-official Jan 16, 2023
cae923b
chore: refactor
sojan-official Jan 16, 2023
ba09939
chore: refactor
sojan-official Jan 16, 2023
10cf72c
chore: fix specs
sojan-official Jan 16, 2023
759fecf
Merge branch 'develop' into feat/microsoft-oauth-apis
sojan-official Jan 16, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
fix: refresh tokens with IMAP; commented conde for the HTTParty
  • Loading branch information
tejaswinichile committed Jan 10, 2023
commit bb5a248e3390dee4453b5c774cc5225c17da22c6
5 changes: 2 additions & 3 deletions app/jobs/channels/refresh_ms_oauth_token_job.rb
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,9 @@ class Channels::RefreshMsOauthTokenJob < ApplicationJob
queue_as :low

def perform
Channel::Email.all.each do |inbox|
Channel::Email.all.each do |channel|
# refresh the token here, offline access should work

channel = inbox.channel
ms_oauth_token_hash = channel.ms_oauth_token_hash || {}

return unless ms_oauth_token_hash[:access_token].present?
Expand All @@ -31,7 +30,7 @@ def access_token(channel, ms_oauth_token_hash)
# <RefreshTokensSnippet>
def refresh_tokens(channel, token_hash)
oauth_strategy = OmniAuth::Strategies::MicrosoftGraphAuth.new(
nil, ENV['AZURE_APP_ID'], ENV['AZURE_APP_SECRET']
nil, ENV.fetch['AZURE_APP_ID'], ENV.fetch['AZURE_APP_SECRET']
)

token = OAuth2::AccessToken.new(
Expand Down
30 changes: 15 additions & 15 deletions app/jobs/inboxes/fetch_imap_emails_job.rb
Original file line number Diff line number Diff line change
Expand Up @@ -56,26 +56,26 @@ def fetch_mail_for_ms_oauth_channel(channel)

return unless access_token

auth = 'Bearer ' + access_token
all_mails = HTTParty.get("https://graph.microsoft.com/v1.0/me/mailfolders/inbox/messages", :headers => { "Authorization" => auth })['value']
# auth = 'Bearer ' + access_token
# all_mails = HTTParty.get("https://graph.microsoft.com/v1.0/me/mailfolders/inbox/messages", :headers => { "Authorization" => auth })['value']

all_mails.each do |mail|
inbound_mail = Mail.read_from_string mail
next if channel.inbox.messages.find_by(source_id: inbound_mail['id'].value).present?
# all_mails.each do |mail|
# inbound_mail = Mail.read_from_string mail
# next if channel.inbox.messages.find_by(source_id: inbound_mail['id'].value).present?

process_mail(inbound_mail, channel)
end
# process_mail(inbound_mail, channel)
# end

# imap = Net::IMAP.new(channel.imap_address, channel.imap_port, true)
# imap.authenticate('XOAUTH2', 'tejaswinichile@chatwoot.onmicrosoft.com', "Bearer eyJ0eXAiOiJKV1QiLCJub25jZSI6ImNhTG15M19HX2lvLUxjYmFWME1SLUZlYnJCQ3FYbWpkRkRlNlAtZmxaX1EiLCJhbGciOiJSUzI1NiIsIng1dCI6Ii1LSTNROW5OUjdiUm9meG1lWm9YcWJIWkdldyIsImtpZCI6Ii1LSTNROW5OUjdiUm9meG1lWm9YcWJIWkdldyJ9.eyJhdWQiOiJodHRwczovL2dyYXBoLm1pY3Jvc29mdC5jb20iLCJpc3MiOiJodHRwczovL3N0cy53aW5kb3dzLm5ldC9hMWUzYjU0Zi04NDc0LTQ1MjItYmUyNC04ODIxOTdlODgzMDYvIiwiaWF0IjoxNjcyNzUwOTEzLCJuYmYiOjE2NzI3NTA5MTMsImV4cCI6MTY3Mjc1NTYxNywiYWNjdCI6MCwiYWNyIjoiMSIsImFpbyI6IkFWUUFxLzhUQUFBQVR4S05wK0VQYTUwTC9YK2poM2IycVhqbGZtVndoeXpjb2hXVkd0dmVycFd1Yi9ydXJnb3NIb2dmdXBuQzV5QXhZZGQ0WnlvR0Qwa2RrbGJNSldodWVzcXY3MDNlQlZCeThYc3hSRjBLSXYwPSIsImFtciI6WyJwd2QiLCJtZmEiXSwiYXBwX2Rpc3BsYXluYW1lIjoic3Vic2NyaWJlZC1jaGF0d29vdCIsImFwcGlkIjoiZDk2OTUxNjUtNDA0Mi00NWI1LTk5YWYtYWFmOGQwOWM5OGFlIiwiYXBwaWRhY3IiOiIxIiwiZmFtaWx5X25hbWUiOiJjaGlsZSIsImdpdmVuX25hbWUiOiJ0ZWphc3dpbmkiLCJpZHR5cCI6InVzZXIiLCJpcGFkZHIiOiI0OS4yNDguODguNDMiLCJuYW1lIjoidGVqYXN3aW5pIGNoaWxlIiwib2lkIjoiZmExMzQ5ZDMtODAwMi00MmI4LWI2YWEtZDdhMWMxYzJmMDk3IiwicGxhdGYiOiI1IiwicHVpZCI6IjEwMDMyMDAyNUY0QjU2RjciLCJyaCI6IjAuQVZZQVQ3WGpvWFNFSWtXLUpJZ2hsLWlEQmdNQUFBQUFBQUFBd0FBQUFBQUFBQUNmQUtnLiIsInNjcCI6ImVtYWlsIElNQVAuQWNjZXNzQXNVc2VyLkFsbCBNYWlsLlJlYWQgb3BlbmlkIHByb2ZpbGUgU01UUC5TZW5kIFVzZXIuUmVhZCIsInNpZ25pbl9zdGF0ZSI6WyJrbXNpIl0sInN1YiI6IkNTTGNmN2xrWWJBZmdVS3k3WDZDX2FQUGw1SmoyZlhCMEdWRWN5alZSbDgiLCJ0ZW5hbnRfcmVnaW9uX3Njb3BlIjoiQVMiLCJ0aWQiOiJhMWUzYjU0Zi04NDc0LTQ1MjItYmUyNC04ODIxOTdlODgzMDYiLCJ1bmlxdWVfbmFtZSI6InRlamFzd2luaWNoaWxlQGNoYXR3b290Lm9ubWljcm9zb2Z0LmNvbSIsInVwbiI6InRlamFzd2luaWNoaWxlQGNoYXR3b290Lm9ubWljcm9zb2Z0LmNvbSIsInV0aSI6InlpdlZjYTRMVVVHZE02YWdZdm5pQVEiLCJ2ZXIiOiIxLjAiLCJ3aWRzIjpbIjYyZTkwMzk0LTY5ZjUtNDIzNy05MTkwLTAxMjE3NzE0NWUxMCIsImI3OWZiZjRkLTNlZjktNDY4OS04MTQzLTc2YjE5NGU4NTUwOSJdLCJ4bXNfc3QiOnsic3ViIjoiU0dyUWNxTTc3bVQ4TFdDLTJQT1p5eHY0LS0ycjRLR2FDYjNhc0h2ZDV1QSJ9LCJ4bXNfdGNkdCI6MTY3MjExNzA1OH0.Jy4qdXGqQYpw9Ejx29uc4Q_Q1mB1jMYEHRVDUqe2oteGznAgTvjrtINKB9ny1_YdHs5uMt2ZpTGRXBLEwJTkBDaUResKVQtTPqPLsB25_80NEHuJJvZJrqJaA6b7RfwTCGhd6gjtvqnH0FkmMO6iirDnqoaGlrvFhgz2y-yZbG2pl6emwdFBo6IlFhOuQyqecRI5LlW9nnq7jK5p6OFtQ8q0OIShwB_AXY5fSIJX-Wtm6yV-82dDm2-sX5Lb0PYQsY72ZKly29yK6c_K8ouDt7JBRZY1oxNBr_pa6FyTYTygAk3CxOoUZeXIeMU7pus0w0B7JjKVaQob5d_BsuC4rg")
# imap.select('INBOX')
# imap.search(['ALL']).each do |message_id|
# inbound_mail = Mail.read_from_string imap.fetch(message_id,'RFC822')[0].attr['RFC822']
imap = Net::IMAP.new(channel.imap_address, channel.imap_port, true)
imap.authenticate('XOAUTH2', channel.imap_login, access_token)
imap.select('INBOX')
imap.search(['ALL']).each do |message_id|
inbound_mail = Mail.read_from_string imap.fetch(message_id,'RFC822')[0].attr['RFC822']

# next if channel.inbox.messages.find_by(source_id: inbound_mail.message_id).present?
next if channel.inbox.messages.find_by(source_id: inbound_mail.message_id).present?

# process_mail(inbound_mail, channel)
# end
process_mail(inbound_mail, channel)
end
end

def process_mail(inbound_mail, channel)
Expand Down