forked from Stwissel/node-red-contrib-salesforce
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstreaming.html
90 lines (88 loc) · 4 KB
/
streaming.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
<script type="text/javascript">
RED.nodes.registerType('streaming', {
category: 'Salesforce',
color: '#C0DEED',
defaults: {
name: {
value: ''
},
pushTopic: {
value: '',
required: true
},
topicType: {
value: 'platform',
required: true
},
connection: {
value: '',
type: 'connection-config',
required: true
}
},
inputs: 1,
outputs: 1,
icon: "salesforce.png",
label: function() {
return this.name || 'streaming';
},
oneditsave: function() {
this.topicType = $("#node-config-input-topicType").val();
}
});
</script>
<script type="text/x-red" data-template-name="streaming">
<div class="form-row">
<label for="node-input-name"><i class="icon-tag"></i> Name</label>
<input type="text" id="node-input-name" placeholder="Name">
</div>
<div class="form-row">
<label for="node-input-connection"><i class="fa fa-plug"></i> Connection</label>
<input type="text" id="node-input-connection">
</div>
<div class="form-row">
<label for="node-config-input-topicType"><i class="fa fa-bath"></i> Type</label>
<select id="node-config-input-topicType">
<option value="platform">Platform events</option>
<option value="pushtopic">Streaming (Push Topic)</option>
<option value="generic">Streaming (Generic)</option>
</select>
</div>
<div class="form-row">
<label for="node-input-connection"><i class="fa fa-bullhorn"></i>Topic</label>
<input type="text" id="node-input-pushTopic">
</div>
</script>
<script type="text/x-red" data-help-name="streaming">
<p>Creates a client that subscribes to a PushTopic for the Streaming API.</p>
<p>Extended to support platform API events too. Pick one of the following:</p>
<ul>
<li>Platform events: Listen to the Platform event API</li>
<li>Streaming (Push Topic): Listen to changes in sObjects</li>
<li>Streaming (Generic): Listen to generic Push Topics (deprecated)</li>
</ul>
<p>Subscription starts only when an incoming message is received once. The following `msg` properties are supported:</p>
<ul>
<li><code>action</code> with the value <code>subscribe</code> or <code>unsubscribe</code> (default: <code>subscribe</code>): start or stop a subscription</li>
<li><code>topic</code> the topic to subscribe to. Default is to use the topic from the config</li>
<li><code>sf</code> object containing: <code>username</code>, <code>password</code>, <code>consumerKey</code> and <code>consumerSecret</code>. When the configuration allows it (checkbox "allow message credentials"), these values take priority over
the configuration values). They don't have to be present together, they are applied individually</li>
</ul>
<p>When the client receives a message it sends <code>msg.payload</code> with the following:
<ul>
<li>msg.payload.event - the information on the event that was received.</li>
<li>msg.payload.sobject - the sobject information received.</li>
</ul>
</p>
<p>Assuming the PushTopic was created with the query <code>SELECT Id, Name FROM Contact</code>, then a resulting message would look like:</p>
<pre>{
"event": {
"type": "updated", "createdDate": "2015-07-31T18:38:21.000+0000"
},
"sobject": {
"Name": "Nikola Tesla", "Id": "a0037000001pplrZZZ"
}
}</pre>
<p>See the <a href="https://developer.salesforce.com/docs/atlas.en-us.api_streaming.meta/api_streaming/quick_start_workbench.htm">Quick Start Using Workbench</a> to get started or the <a href="https://developer.salesforce.com/docs/atlas.en-us.api_streaming.meta/api_streaming/"
target="_blank">Streaming API documentation</a> for complete details.</p>
</script>