Salesforce App跟着停止工作

时间:2012-07-26 20:17:09

标签: salesforce

我的公司有一个应用程序,他们从应用程序交换中获取(注意:在我开始之前),允许您在salesforce.com中关注或取消关注大量案例/帐户/机会等。据说它以前工作过,现在它不起作用。我需要知道每个按钮的代码有什么问题。如果我无法修复它们,那么替换应用程序的任何想法?该应用已不再在应用交换中。

这是关注按钮的代码:

{!REQUIRESCRIPT("/soap/ajax/18.0/connection.js")}

//EDIT THE FOLLOWING LINE TO ALTER THE CODE FOR OTHER OBJECTS. USE THE PICKLISTS ABOVE        TO SELECT FIELD TYPE = $ObjectType AND THE OBJECT NAME THEN REPLACE "$ObjectType.Case" WITH   YOUR NEW OBJECT NAME
var records = {!GETRECORDIDS( $ObjectType.Case)};

function LBox() {
var box = new parent.SimpleDialog("steve"+Math.random(), true);
parent.box = box;`

 box.setTitle("Follow Records");

box.createDialog();
box.setWidth(220);

box.setContentInnerHTML("<img src='/img/loading32.gif' alt='' /> Running");

box.setupDefaultButtons();`

box.show();
}

function CBox(){
box.setContentInnerHTML("You are now following "+follow_count+" records<br /><br /><a href=\"#\" onclick=\"box.hide();\">Close</a>");
}



if (records[0] == null) { 
alert("Please select at least one record.");
} 
else { 
var follow_count = 0;

LBox();

for (var i = 0; i < records.length; i++){ 
var fol=new sforce.SObject("EntitySubscription");
fol.ParentId = records[i];
fol.SubscriberId = '{!User.Id}';

try{
sforce.connection.create([fol]); 
follow_count++;
}
catch(e){
alert(e);
}
}
CBox();

}

here's the unfollow button:
{!REQUIRESCRIPT("/soap/ajax/18.0/connection.js")}

// EDIT THE FOLLOWING LINE TO ALTER THE CODE FOR OTHER OBJECTS. USE THE PICKLISTS ABOVE TO SELECT FIELD TYPE = $ObjectType AND THE OBJECT NAME THEN REPLACE "$ObjectType.Case" WITH YOUR NEW OBJECT NAME
var records = {!GETRECORDIDS( $ObjectType.Case)};

// display running message popup
function LBox() {
var box = new parent.SimpleDialog("steve"+Math.random(), true);
parent.box = box;`

box.setTitle("Unfollow Records");

box.createDialog();
box.setWidth(220);

box.setContentInnerHTML("<img src='/img/loading32.gif' alt='' /> Running");

box.setupDefaultButtons();

box.show();
}

// display output message
function CBox(){
if (unfollow_count < records.length)
box.setContentInnerHTML("You have now unfollowed "+unfollow_count+" records. You were not following the other selected records. <br /><br /><a href=\"#\" onclick=\"box.hide();\">Close</a>");
else
box.setContentInnerHTML("You have now unfollowed "+unfollow_count+" records. <br /><br /><a href=\"#\" onclick=\"box.hide();\">Close</a>");
}

if (records[0] == null) {
alert("Please select at least one record.");
}
else {
var unfollow_count = 0;`

LBox();

try {
// find following records
var searchstring = "SELECT Id FROM EntitySubscription WHERE (ParentId IN (";
for (var i = 0; i < records.length - 1; i++) {
searchstring += "'" + records[i] + "',";
}
searchstring += "'" + records[records.length - 1] + "') AND SubscriberId ='{!User.Id}')";
var resultRecords = sforce.connection.query(searchstring).getArray("records");

// delete following records
var recordIds = [];
for (var i = 0; i < resultRecords.length; i++) {
recordIds.push(resultRecords[i].Id);
unfollow_count++;
}
sforce.connection.deleteIds(recordIds);
} catch(e) {
alert(e);
}

CBox();
}

第一条错误消息与权限有关,我没有收到此错误,因为我有管理员权限,第二个错误仅在帐户标签的按钮上。我更担心权限问题,有关于权限的任何内容。任何帮助都很棒!

2 个答案:

答案 0 :(得分:0)

我认为问题是throttle in SFDC,您仅限于每个用户只跟踪一定数量的记录。如果这个应用程序是按照你所描述的那样按照大量跟踪记录设计的,那么你可能会遇到这种限制,这是我从同事收到的关于at most 1000的错误中获得的印象,如果之前有效的话,最大限度地提高组织/用户的限制

是有意义的

答案 1 :(得分:0)

非系统管理员用户对EntitySubscription的查询必须包含LIMIT。如果您将按钮中的查询代码更改为以下内容,则应该可以正常工作:

// find following records
var searchstring = "SELECT Id FROM EntitySubscription WHERE (ParentId IN (";
for (var i = 0; i < records.length - 1; i++) {
   searchstring += "'" + records[i] + "',";
}
searchstring += "'" + records[records.length - 1] + "') AND SubscriberId ='{!User.Id}') LIMIT 1000";