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: Response Bot using GPT and Webpage Sources #7518

Merged
merged 41 commits into from
Jul 21, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
41 commits
Select commit Hold shift + click to select a range
3cbbc3a
poc: Search support articles via OpenAI embeddings
sojan-official May 22, 2023
fe86e78
Merge branch 'develop' into spike/CW-1690-embeddings-for-articles
sojan-official May 29, 2023
3e0a71d
Chore: basic prototype
sojan-official Mar 20, 2023
8fbfe44
chore: GPT bot with article recommendations
sojan-official May 29, 2023
44a24bb
Merge branch 'develop' into spike/CW-1690-embeddings-for-articles
sojan-official May 29, 2023
cdaa40b
chore: minor formatting
sojan-official May 29, 2023
a728bb2
Merge branch 'develop' into spike/CW-1690-embeddings-for-articles
sojan-official Jun 21, 2023
f26649a
Merge branch 'develop' into spike/CW-1690-embeddings-for-articles
sojan-official Jul 5, 2023
c921aec
chore: Response Sources
sojan-official Jul 10, 2023
ce872de
Merge branch 'spike/CW-1690-embeddings-for-articles' into chore/respo…
sojan-official Jul 10, 2023
870d2e6
chore: fi
sojan-official Jul 13, 2023
41a7a25
chore: clean up
sojan-official Jul 13, 2023
a732ec1
chore: clean up
sojan-official Jul 13, 2023
78814eb
Merge branch 'develop' into chore/response-sources-with-embeddings
sojan-official Jul 13, 2023
bf6d69a
chore: fix
sojan-official Jul 13, 2023
dc01127
chore: endpoint to create sources
sojan-official Jul 13, 2023
590cff4
chor: fixes
sojan-official Jul 13, 2023
11a16a8
chore: The bot
sojan-official Jul 13, 2023
6510886
chore: reoder gemfile
sojan-official Jul 13, 2023
cc61674
chore: fix
sojan-official Jul 13, 2023
b7c7b09
chore: APIs for add and remove documents
sojan-official Jul 14, 2023
ada6c9c
Chore: clean up
sojan-official Jul 14, 2023
3729a9f
Merge branch 'develop' into chore/response-sources-with-embeddings
sojan-official Jul 14, 2023
dfa9b27
chore: fixes
sojan-official Jul 17, 2023
fce44b7
Merge branch 'develop' into chore/response-sources-with-embeddings
sojan-official Jul 17, 2023
c459f42
chore: clean up
sojan-official Jul 17, 2023
98e3ae0
chore: clean up
sojan-official Jul 17, 2023
f63feff
chore: refactor
sojan-official Jul 17, 2023
fec1e8a
Merge branch 'develop' into chore/response-sources-with-embeddings
pranavrajs Jul 19, 2023
30a2009
Merge branch 'develop' into chore/response-sources-with-embeddings
pranavrajs Jul 19, 2023
3ca3f9d
chore: add feature lock
sojan-official Jul 20, 2023
4538d35
chore: clean up
sojan-official Jul 20, 2023
1db6b2a
chore: fix specs
sojan-official Jul 20, 2023
e99a8ee
Merge branch 'develop' into chore/response-sources-with-embeddings
sojan-official Jul 21, 2023
4b05257
chore: fix code climate
sojan-official Jul 21, 2023
45a2754
chore: fix specs
sojan-official Jul 21, 2023
455df91
chore: test latest postgres
sojan-official Jul 21, 2023
ede19fe
chore: tests
sojan-official Jul 21, 2023
441da57
chore: update
sojan-official Jul 21, 2023
fe86348
Empty-Commit
sojan-official Jul 21, 2023
acf5b66
chore: clean up
sojan-official Jul 21, 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
chore: fix
  • Loading branch information
sojan-official committed Jul 13, 2023
commit cc616745ff4503f9088cd62435dba7a1dffea363
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,11 @@ class Api::V1::Accounts::ResponseSourcesController < Api::V1::Accounts::BaseCont
before_action :current_account
before_action :check_authorization

def parse
links = PageCrawlerService.new(params[:link]).get_links
render json: { links: links }
end

def create
@response_source = Current.account.response_sources.new(response_source_params)
@response_source.save!
Expand Down
4 changes: 4 additions & 0 deletions app/policies/response_source_policy.rb
Original file line number Diff line number Diff line change
@@ -1,4 +1,8 @@
class ResponseSourcePolicy < ApplicationPolicy
def parse?
@account_user.administrator?
end

def create?
@account_user.administrator?
end
Expand Down
2 changes: 1 addition & 1 deletion app/services/message_templates/hook_execution_service.rb
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ def trigger_templates
def should_process_response_bot?
return false unless conversation.pending?
return false unless message.incoming?
return false unless inbox.response_sources.present?
return false if inbox.response_sources.blank?

true
end
Expand Down
8 changes: 4 additions & 4 deletions app/services/page_crawler_service.rb
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ def get_links

def page_title
title_element = @doc.at_xpath('//title')
title_element.text.strip if title_element
title_element&.text&.strip
end

def body_text_content
Expand All @@ -26,13 +26,13 @@ def sitemap?
end

def extract_links_from_sitemap
@doc.xpath('//loc').map(&:text).to_set
@doc.xpath('//loc').to_set(&:text)
end

def extract_links_from_html
@doc.xpath('//a/@href').map do |link|
@doc.xpath('//a/@href').to_set do |link|
absolute_url = URI.join(@external_link, link.value).to_s
absolute_url
end.to_set
end
end
end
6 changes: 5 additions & 1 deletion config/routes.rb
Original file line number Diff line number Diff line change
Expand Up @@ -151,7 +151,11 @@
end
end
resources :labels, only: [:index, :show, :create, :update, :destroy]
resources :response_sources, only: [:create]
resources :response_sources, only: [:create] do
collection do
post :parse
end
end

resources :notifications, only: [:index, :update] do
collection do
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,37 @@
let!(:account) { create(:account) }
let!(:inbox) { create(:inbox, account: account) }

describe 'POST /api/v1/accounts/{account.id}/response_sources/parse' do
let(:valid_params) do
{
link: 'http://test.test'
}
end

context 'when it is an unauthenticated user' do
it 'returns unauthorized' do
expect { post "/api/v1/accounts/#{account.id}/response_sources/parse", params: valid_params }.not_to change(Label, :count)

expect(response).to have_http_status(:unauthorized)
end
end

context 'when it is an authenticated user' do
let(:admin) { create(:user, account: account, role: :administrator) }

it 'returns links in the webpage' do
crawler = double
allow(PageCrawlerService).to receive(:new).and_return(crawler)
allow(crawler).to receive(:get_links).and_return(['http://test.test'])

post "/api/v1/accounts/#{account.id}/response_sources/parse", headers: admin.create_new_auth_token,
params: valid_params
expect(response).to have_http_status(:success)
expect(response.parsed_body['links']).to eq(['http://test.test'])
end
end
end

describe 'POST /api/v1/accounts/{account.id}/response_sources' do
let(:valid_params) do
{
Expand All @@ -30,7 +61,7 @@
context 'when it is an authenticated user' do
let(:admin) { create(:user, account: account, role: :administrator) }

it 'creates the contact' do
it 'creates the response sources and documents' do
expect do
post "/api/v1/accounts/#{account.id}/response_sources", headers: admin.create_new_auth_token,
params: valid_params
Expand Down