Skip to content

Commit

Permalink
Merge pull request #27114 from frappe-pr-bot/backport/develop/24664
Browse files Browse the repository at this point in the history
refactor: social media post fixes
  • Loading branch information
nabinhait authored Aug 24, 2021
2 parents 255b99e + d0cc1be commit 14332ad
Show file tree
Hide file tree
Showing 10 changed files with 349 additions and 202 deletions.
11 changes: 6 additions & 5 deletions erpnext/crm/doctype/linkedin_settings/linkedin_settings.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,8 @@
// For license information, please see license.txt

frappe.ui.form.on('LinkedIn Settings', {
onload: function(frm){
if (frm.doc.session_status == 'Expired' && frm.doc.consumer_key && frm.doc.consumer_secret){
onload: function(frm) {
if (frm.doc.session_status == 'Expired' && frm.doc.consumer_key && frm.doc.consumer_secret) {
frappe.confirm(
__('Session not valid, Do you want to login?'),
function(){
Expand All @@ -14,8 +14,9 @@ frappe.ui.form.on('LinkedIn Settings', {
}
);
}
frm.dashboard.set_headline(__("For more information, {0}.", [`<a target='_blank' href='https://docs.erpnext.com/docs/user/manual/en/CRM/linkedin-settings'>${__('Click here')}</a>`]));
},
refresh: function(frm){
refresh: function(frm) {
if (frm.doc.session_status=="Expired"){
let msg = __("Session Not Active. Save doc to login.");
frm.dashboard.set_headline_alert(
Expand Down Expand Up @@ -53,7 +54,7 @@ frappe.ui.form.on('LinkedIn Settings', {
);
}
},
login: function(frm){
login: function(frm) {
if (frm.doc.consumer_key && frm.doc.consumer_secret){
frappe.dom.freeze();
frappe.call({
Expand All @@ -67,7 +68,7 @@ frappe.ui.form.on('LinkedIn Settings', {
});
}
},
after_save: function(frm){
after_save: function(frm) {
frm.trigger("login");
}
});
3 changes: 2 additions & 1 deletion erpnext/crm/doctype/linkedin_settings/linkedin_settings.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
"actions": [],
"creation": "2020-01-30 13:36:39.492931",
"doctype": "DocType",
"documentation": "https://docs.erpnext.com/docs/user/manual/en/CRM/linkedin-settings",
"editable_grid": 1,
"engine": "InnoDB",
"field_order": [
Expand Down Expand Up @@ -87,7 +88,7 @@
],
"issingle": 1,
"links": [],
"modified": "2020-04-16 23:22:51.966397",
"modified": "2021-02-18 15:19:21.920725",
"modified_by": "Administrator",
"module": "CRM",
"name": "LinkedIn Settings",
Expand Down
112 changes: 78 additions & 34 deletions erpnext/crm/doctype/linkedin_settings/linkedin_settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,11 +3,12 @@
# For license information, please see license.txt

from __future__ import unicode_literals
import frappe, requests, json
import frappe
import requests
from frappe import _
from frappe.utils import get_site_url, get_url_to_form, get_link_to_form
from frappe.utils import get_url_to_form
from frappe.model.document import Document
from frappe.utils.file_manager import get_file, get_file_path
from frappe.utils.file_manager import get_file_path
from six.moves.urllib.parse import urlencode

class LinkedInSettings(Document):
Expand Down Expand Up @@ -42,11 +43,7 @@ def get_access_token(self, code):
self.db_set("access_token", response["access_token"])

def get_member_profile(self):
headers = {
"Authorization": "Bearer {}".format(self.access_token)
}
url = "https://api.linkedin.com/v2/me"
response = requests.get(url=url, headers=headers)
response = requests.get(url="https://api.linkedin.com/v2/me", headers=self.get_headers())
response = frappe.parse_json(response.content.decode())

frappe.db.set_value(self.doctype, self.name, {
Expand All @@ -55,16 +52,16 @@ def get_member_profile(self):
"session_status": "Active"
})
frappe.local.response["type"] = "redirect"
frappe.local.response["location"] = get_url_to_form("LinkedIn Settings","LinkedIn Settings")
frappe.local.response["location"] = get_url_to_form("LinkedIn Settings", "LinkedIn Settings")

def post(self, text, media=None):
def post(self, text, title, media=None):
if not media:
return self.post_text(text)
return self.post_text(text, title)
else:
media_id = self.upload_image(media)

if media_id:
return self.post_text(text, media_id=media_id)
return self.post_text(text, title, media_id=media_id)
else:
frappe.log_error("Failed to upload media.","LinkedIn Upload Error")

Expand All @@ -82,9 +79,7 @@ def upload_image(self, media):
}]
}
}
headers = {
"Authorization": "Bearer {}".format(self.access_token)
}
headers = self.get_headers()
response = self.http_post(url=register_url, body=body, headers=headers)

if response.status_code == 200:
Expand All @@ -100,24 +95,33 @@ def upload_image(self, media):

return None

def post_text(self, text, media_id=None):
def post_text(self, text, title, media_id=None):
url = "https://api.linkedin.com/v2/shares"
headers = {
"X-Restli-Protocol-Version": "2.0.0",
"Authorization": "Bearer {}".format(self.access_token),
"Content-Type": "application/json; charset=UTF-8"
}
headers = self.get_headers()
headers["X-Restli-Protocol-Version"] = "2.0.0"
headers["Content-Type"] = "application/json; charset=UTF-8"

body = {
"distribution": {
"linkedInDistributionTarget": {}
},
"owner":"urn:li:organization:{0}".format(self.company_id),
"subject": "Test Share Subject",
"subject": title,
"text": {
"text": text
}
}

reference_url = self.get_reference_url(text)
if reference_url:
body["content"] = {
"contentEntities": [
{
"entityLocation": reference_url
}
]
}

if media_id:
body["content"]= {
"contentEntities": [{
Expand All @@ -141,20 +145,60 @@ def http_post(self, url, headers=None, body=None, data=None):
raise

except Exception as e:
content = json.loads(response.content)

if response.status_code == 401:
self.db_set("session_status", "Expired")
frappe.db.commit()
frappe.throw(content["message"], title="LinkedIn Error - Unauthorized")
elif response.status_code == 403:
frappe.msgprint(_("You Didn't have permission to access this API"))
frappe.throw(content["message"], title="LinkedIn Error - Access Denied")
else:
frappe.throw(response.reason, title=response.status_code)

self.api_error(response)

return response

def get_headers(self):
return {
"Authorization": "Bearer {}".format(self.access_token)
}

def get_reference_url(self, text):
import re
regex_url = r"http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\(\),]|(?:%[0-9a-fA-F][0-9a-fA-F]))+"
urls = re.findall(regex_url, text)
if urls:
return urls[0]

def delete_post(self, post_id):
try:
response = requests.delete(url="https://api.linkedin.com/v2/shares/urn:li:share:{0}".format(post_id), headers=self.get_headers())
if response.status_code !=200:
raise
except Exception:
self.api_error(response)

def get_post(self, post_id):
url = "https://api.linkedin.com/v2/organizationalEntityShareStatistics?q=organizationalEntity&organizationalEntity=urn:li:organization:{0}&shares[0]=urn:li:share:{1}".format(self.company_id, post_id)

try:
response = requests.get(url=url, headers=self.get_headers())
if response.status_code !=200:
raise

except Exception:
self.api_error(response)

response = frappe.parse_json(response.content.decode())
if len(response.elements):
return response.elements[0]

return None

def api_error(self, response):
content = frappe.parse_json(response.content.decode())

if response.status_code == 401:
self.db_set("session_status", "Expired")
frappe.db.commit()
frappe.throw(content["message"], title=_("LinkedIn Error - Unauthorized"))
elif response.status_code == 403:
frappe.msgprint(_("You didn't have permission to access this API"))
frappe.throw(content["message"], title=_("LinkedIn Error - Access Denied"))
else:
frappe.throw(response.reason, title=response.status_code)

@frappe.whitelist(allow_guest=True)
def callback(code=None, error=None, error_description=None):
if not error:
Expand Down
Loading

0 comments on commit 14332ad

Please sign in to comment.