1 | virtualIdentityExtension.ns(function() { with (virtualIdentityExtension.LIB) { |
---|
2 | |
---|
3 | const Ci = Components.interfaces; |
---|
4 | const Cc = Components.classes; |
---|
5 | const Cu = Components.utils; |
---|
6 | |
---|
7 | let pref = Cc["@mozilla.org/preferences-service;1"] |
---|
8 | .getService(Components.interfaces.nsIPrefService) |
---|
9 | .getBranch("extensions.virtualIdentity."); |
---|
10 | |
---|
11 | const AccountManager = Cc["@mozilla.org/messenger/account-manager;1"] |
---|
12 | .getService(Components.interfaces.nsIMsgAccountManager); |
---|
13 | |
---|
14 | const HeaderParser = Cc["@mozilla.org/messenger/headerparser;1"] |
---|
15 | .getService(Ci.nsIMsgHeaderParser); |
---|
16 | |
---|
17 | let virtualIdentityData; |
---|
18 | let virtualIdSenderName; |
---|
19 | let virtualIdInUse; |
---|
20 | let virtualSenderNameElem; |
---|
21 | let Log; |
---|
22 | let _rdfDatasourceAccess; |
---|
23 | |
---|
24 | let changeIdentityToSmartIdentity = function(allIdentities, index) { |
---|
25 | _changeIdentityToSmartIdentity(allIdentities.identityDataCollection[index]); |
---|
26 | }; |
---|
27 | |
---|
28 | let _changeIdentityToSmartIdentity = function(identityData) { |
---|
29 | Log.debug("## changeIdentityToSmartIdentity\n"); |
---|
30 | // add code to set stored base identity |
---|
31 | if ( identityData.id.key != null ) { |
---|
32 | currentParams.identity = AccountManager.getIdentity(identityData.id.key); |
---|
33 | Log.debug("## changed base identity to ", identityData.id.key); |
---|
34 | virtualSenderNameElem.text(virtualIdSenderName); |
---|
35 | } |
---|
36 | virtualIdInUse = !(identityData.isExistingIdentity(false)); |
---|
37 | Log.debug("## changeIdentityToSmartIdentity virtualIdInUse=" + virtualIdInUse + "\n"); |
---|
38 | if (virtualIdInUse) { |
---|
39 | virtualIdentityData = identityData; |
---|
40 | virtualIdSenderName = virtualIdentityData.combinedName; |
---|
41 | } |
---|
42 | virtualSenderNameElem.text(identityData.combinedName); // change this also to reflect changes of base id |
---|
43 | }; |
---|
44 | |
---|
45 | let conversationHook = { |
---|
46 | onComposeSessionConstructDone: function (recipientString, params, senderNameElem, ExternalLog) { |
---|
47 | // this.params = { identity: ???, msgHdr: ???, subject: ??? }; |
---|
48 | Log = ExternalLog; |
---|
49 | |
---|
50 | currentParams = params; virtualSenderNameElem = senderNameElem; // to enable access from out of this class. |
---|
51 | virtualIdentityData = null; virtualIdInUse = false; virtualIdSenderName = ""; |
---|
52 | |
---|
53 | let recipients = []; var combinedNames = {}; var number; |
---|
54 | number = HeaderParser.parseHeadersWithArray(recipientString, {}, {}, combinedNames); |
---|
55 | for (var index = 0; index < number; index++) |
---|
56 | recipients.push( { recipient: combinedNames.value[index], recipientType: "addr_to" } ) |
---|
57 | |
---|
58 | var localSmartIdentityCollection = new vI.smartIdentityCollection(params.msgHdr, params.identity, false, false, recipients); |
---|
59 | localSmartIdentityCollection.Reply(); // we can always use the reply-case, msgHdr is set the right way |
---|
60 | |
---|
61 | if (localSmartIdentityCollection._allIdentities.number == 0) return; |
---|
62 | |
---|
63 | if (pref.getBoolPref("idSelection_preferExisting")) { |
---|
64 | var existingIDIndex = localSmartIdentityCollection._foundExistingIdentity(); |
---|
65 | if (existingIDIndex) { |
---|
66 | Log.debug("## smartIdentity: found existing Identity, use without interaction.\n", existingIDIndex.key); |
---|
67 | changeIdentityToSmartIdentity(localSmartIdentityCollection._allIdentities, existingIDIndex.key); |
---|
68 | return; |
---|
69 | } |
---|
70 | } |
---|
71 | |
---|
72 | if (pref.getBoolPref("idSelection_ask") && |
---|
73 | ((localSmartIdentityCollection._allIdentities.number == 1 && pref.getBoolPref("idSelection_ask_always")) |
---|
74 | || localSmartIdentityCollection._allIdentities.number > 1)) { |
---|
75 | window.openDialog("chrome://v_identity/content/vI_smartReplyDialog.xul",0, |
---|
76 | "chrome, dialog, modal, alwaysRaised, resizable=yes", |
---|
77 | localSmartIdentityCollection._allIdentities, |
---|
78 | /* callback: */ changeIdentityToSmartIdentity).focus(); |
---|
79 | } |
---|
80 | else if (pref.getBoolPref("idSelection_autocreate")) changeIdentityToSmartIdentity(localSmartIdentityCollection._allIdentities, 0); |
---|
81 | }, |
---|
82 | |
---|
83 | onMessageBeforeSendOrPopup: function(gComposeParams, recipientString, popOut, aStatus, ExternalLog) { |
---|
84 | Log = ExternalLog; |
---|
85 | Log.debug("## onMessageBeforeSendOrPopup", recipientString); |
---|
86 | |
---|
87 | if (virtualIdInUse) { |
---|
88 | if (!popOut) { |
---|
89 | let recipients = []; var combinedNames = {}; var number; |
---|
90 | number = HeaderParser.parseHeadersWithArray(recipientString, {}, {}, combinedNames); |
---|
91 | for (var index = 0; index < number; index++) |
---|
92 | recipients.push( { recipient: combinedNames.value[index], recipientType: "addr_to" } ) |
---|
93 | |
---|
94 | returnValue = vI.prepareSendMsg(virtualIdInUse, Ci.nsIMsgCompDeliverMode.Now, |
---|
95 | virtualIdentityData, gComposeParams.identity, recipients ); |
---|
96 | Log.debug("returnValue.update:", returnValue.update); |
---|
97 | |
---|
98 | if (returnValue.update == "abort") { |
---|
99 | aStatus.canceled = true; return aStatus; |
---|
100 | } |
---|
101 | else if (returnValue.update == "takeover") { |
---|
102 | _changeIdentityToSmartIdentity(returnValue.storedIdentity); |
---|
103 | aStatus.canceled = true; return aStatus; |
---|
104 | } |
---|
105 | |
---|
106 | gComposeParams.identity = vI.account._account.defaultIdentity |
---|
107 | if (!vI.finalCheck(virtualIdentityData, gComposeParams.identity)) { |
---|
108 | vI.account.removeUsedVIAccount(); |
---|
109 | aStatus.canceled = true; return aStatus; |
---|
110 | } |
---|
111 | } |
---|
112 | else { |
---|
113 | // code virtual Identity into subject - this will be decoded by smartIdentity - newMail |
---|
114 | gComposeParams.subject = gComposeParams.subject + "\nvirtualIdentityExtension\n" + virtualIdSenderName; |
---|
115 | Log.debug("coding virtualIdentity into subject:", gComposeParams.subject); |
---|
116 | } |
---|
117 | } |
---|
118 | Log.debug("onSendMessage done"); |
---|
119 | return aStatus; |
---|
120 | }, |
---|
121 | |
---|
122 | onStopSending: function () { |
---|
123 | vI.account.removeUsedVIAccount(); |
---|
124 | Log.debug("onStopSending done"); |
---|
125 | }, |
---|
126 | |
---|
127 | onRecipientAdded: function onRecipientAdded(recipient, recipientType, count, ExternalLog) { |
---|
128 | Log = ExternalLog; |
---|
129 | Log.debug("onRecipientAdded", recipient, recipientType, count); |
---|
130 | if (!pref.getBoolPref("storage")) return; |
---|
131 | if (recipientType == "bcc") return; |
---|
132 | if (recipient == "") return; |
---|
133 | |
---|
134 | // if we are editing the "cc" or not the first recipient, recognize this. |
---|
135 | var isNotFirstInputElement = !(recipientType == "to" && count == 0); |
---|
136 | Log.debug("onRecipientAdded isNotFirstInputElement", isNotFirstInputElement); |
---|
137 | |
---|
138 | if (!_rdfDatasourceAccess) _rdfDatasourceAccess = new vI.rdfDatasourceAccess(); |
---|
139 | else _rdfDatasourceAccess.clean(); |
---|
140 | |
---|
141 | var storageResult = _rdfDatasourceAccess.updateVIdentityFromStorage(recipient, "addr_to", |
---|
142 | virtualIdentityData, virtualIdInUse, isNotFirstInputElement); |
---|
143 | |
---|
144 | if (storageResult.identityCollection.number == 0) return; // return if there was no match |
---|
145 | if (storageResult.result != "accept") return; // return if we don't like the resulting id |
---|
146 | |
---|
147 | changeIdentityToSmartIdentity(storageResult.identityCollection, 0); |
---|
148 | } |
---|
149 | } |
---|
150 | |
---|
151 | vI.conversationHook = conversationHook; |
---|
152 | }}); |
---|