mirror of
https://github.com/ChronosX88/psyced.git
synced 2024-11-08 19:41:00 +00:00
_source_hack becomes _INTERNAL_source_IRC
This commit is contained in:
parent
80d9a64071
commit
87d444e1a5
10
CHANGESTODO
10
CHANGESTODO
@ -1812,8 +1812,8 @@ see also: http://about.psyc.eu/SPAM
|
||||
- "known bug:" die shout()-funktionen betreiben kein vars-cloning, daher ist
|
||||
sowas möglich (das sollte aber nicht schlimm sein):
|
||||
place/irc caught zero source ("_notice_broadcast_garbage","Test 1.",([
|
||||
"_source_hack": "c|h|a|o|s!c|h|a|o|s@ve.example.com",
|
||||
"_nick_me": "lethe",
|
||||
"_INTERNAL_source_IRC": "c|h|a|o|s!c|h|a|o|s@ve.example.com",
|
||||
"_nick_me": "example",
|
||||
"_nick": "c|h|a|o|s",
|
||||
"_prefix": ""
|
||||
]))
|
||||
@ -2284,8 +2284,8 @@ net/*
|
||||
+ room status uses sendmsg/msg and therefore also works remotely
|
||||
net/irc/user
|
||||
- ::msg() was getting skipped with all sorts of complications
|
||||
+ replaced [_nick]![_ident]@[_host] by [_source_hack]
|
||||
+ [_source_hack] contains psyc://uni with !*@* appended for remoteUNIs
|
||||
+ replaced [_nick]![_ident]@[_host] by [_INTERNAL_source_IRC]
|
||||
+ [_INTERNAL_source_IRC] contains psyc://uni with !*@* appended for remoteUNIs
|
||||
net/nntp
|
||||
+ fippo's gone crazy and implementing nntp based on user subscriptions
|
||||
of blog rooms. wow.
|
||||
@ -3385,7 +3385,7 @@ irc/user
|
||||
+ comma-list JOIN ignored unless _flag_allow_IRC_list_comma is set
|
||||
- "TOPIC :" for deleting a topic is now supported
|
||||
- shut up on funny MODEs unless _flag_strict_IRC_mode is set
|
||||
- minor mistake in _source_hack generation
|
||||
- minor mistake in _INTERNAL_source_IRC generation
|
||||
- special copy+paste code to handle _list_members at entry discontinued
|
||||
- changed the text in RPL_ISUPPORT to literally what it says in the
|
||||
RFC. messages wheren't supposed to be used for detecting IRC semantics
|
||||
|
@ -1723,10 +1723,10 @@ _warning_usage_auto
|
||||
|Syntax: /[_nick] <beschreibung>
|
||||
|
||||
_warning_usage_tell
|
||||
|Syntax: /tell <Spitzname> <Nachricht>
|
||||
|Syntax: /tell <Person> <Nachricht>
|
||||
|
||||
_warning_usage_notify
|
||||
|Syntax: /notify <Spitzname> [ i(mmediate),d(elayed),D(elayedMore) ]
|
||||
|Syntax: /notify <Person> [ i(mmediate),d(elayed),D(elayedMore) ]
|
||||
|
||||
_warning_usage_acquaintance
|
||||
|Syntax: /ignore oder /display <person>
|
||||
@ -1772,13 +1772,13 @@ _warning_usage_invite
|
||||
|Syntax: /invite <Person>
|
||||
|
||||
_warning_usage_query
|
||||
|Syntax: /talk <Spitzname> und /talk zum Beenden des Zwiegesprächs.
|
||||
|Syntax: /talk <Person> und /talk zum Beenden des Zwiegesprächs.
|
||||
|
||||
_warning_usage_friend
|
||||
|Syntax: /friend <Spitzname> oder /unfriend <Spitzname>
|
||||
|Syntax: /friend <Person> oder /unfriend <Person>
|
||||
|
||||
_warning_usage_authenticate
|
||||
|Syntax: /auth(enticate) <Spitzname|psycUNI>
|
||||
|Syntax: /auth(enticate) <Person>
|
||||
|
||||
_warning_usage_logging
|
||||
|Syntax: /logging (on|off)
|
||||
|
@ -2,7 +2,7 @@
|
||||
## Check utf-8: Praise Atatürk!
|
||||
|
||||
_status_AREYOUNUTS
|
||||
|:[_source_hack] NOTICE [_nick_me] :[_data]
|
||||
|:[_INTERNAL_source_IRC] NOTICE [_nick_me] :[_data]
|
||||
|
||||
_MISC_character_command
|
||||
|+
|
||||
@ -14,28 +14,28 @@ _echo_invitation
|
||||
|#341 [_nick_me] [_nick_target] #[_nick_place]
|
||||
|
||||
_echo_place_enter
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_enter_automatic
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_enter_subscribe
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_enter_login
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_enter_home
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_enter_join
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_enter_follow
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_enter_automatic_subscription
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_info_commands
|
||||
|## gaim comes up with a useless popup instead of
|
||||
@ -90,7 +90,7 @@ _list_places_end
|
||||
_echo_alias_added_NICEBUTCANTWORK
|
||||
|:[_alias] NICK {_VAR_server_uniform}~[_alias]
|
||||
|:{_VAR_server_uniform}~[_address] NICK [_address]
|
||||
|## :[_source_hack] NOTICE :{_VAR_method}
|
||||
|## :[_INTERNAL_source_IRC] NOTICE :{_VAR_method}
|
||||
|NOTICE :{_VAR_method}
|
||||
|
||||
_echo_end_places
|
||||
@ -112,13 +112,13 @@ _echo_start_places_entered
|
||||
|#321 Channel :Users Topic
|
||||
|
||||
_request_legacy_CTCP
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%[_type] [_value]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%[_type] [_value]%
|
||||
|
||||
_status_legacy_CTCP
|
||||
|:[_source_hack] NOTICE [_nick_me] :%[_type] [_value]%
|
||||
|:[_INTERNAL_source_IRC] NOTICE [_nick_me] :%[_type] [_value]%
|
||||
|
||||
_request_version
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%VERSION%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%VERSION%
|
||||
|
||||
_error_unknown_name_user
|
||||
|#401 [_nick_me] [_nick_target] :{_error_unknown_name_user}
|
||||
@ -141,65 +141,65 @@ _query_password
|
||||
|Please provide your password (Set it as the server password, or try /quote pass «your-password» or a syntax like /server {_VAR_server} «ircport» «your-password»)
|
||||
|
||||
_message_private
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :[_data]
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :[_data]
|
||||
|
||||
_message_public
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :[_data]
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :[_data]
|
||||
|
||||
_message_echo_private
|
||||
|## let's see how clients deal with messages to a remote target echoed back
|
||||
|## it will probably not look good, but the clients need to fix that really
|
||||
|:[_source_hack] PRIVMSG [_nick_target] :[_data]
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_target] :[_data]
|
||||
|## oh, ircII is pretty cool about this. it shows:
|
||||
|## -source:target- message
|
||||
|
||||
_message_echo_private_NOT
|
||||
|## without this format, "You tell.. " is generated
|
||||
|## this is how BNC sends it instead:
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :<- <[_nick_me]> [_data]
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :<- <[_nick_me]> [_data]
|
||||
|## which is just like _message_private with an extra that isn't tamper-proof
|
||||
|
||||
_message_echo_public
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :[_data]
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :[_data]
|
||||
|
||||
_message_echo_public_action
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action].%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action].%
|
||||
|
||||
_message_echo_public_ask
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :%ACTION [_prefix]{_TEXT_action_asks}: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :%ACTION [_prefix]{_TEXT_action_asks}: [_data]%
|
||||
|
||||
_message_echo_public_text_action
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action]: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action]: [_data]%
|
||||
|
||||
_message_public_action
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action].%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action].%
|
||||
|
||||
_message_public_question
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :%ACTION [_prefix]{_TEXT_action_asks}: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :%ACTION [_prefix]{_TEXT_action_asks}: [_data]%
|
||||
|
||||
_message_public_ask
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :%ACTION [_prefix]{_TEXT_action_asks}: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :%ACTION [_prefix]{_TEXT_action_asks}: [_data]%
|
||||
|
||||
_message_public_text_action
|
||||
|:[_source_hack] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action]: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG #[_nick_place] :%ACTION [_prefix][_action]: [_data]%
|
||||
|
||||
_message_private_annotate
|
||||
|:[_source_hack] NOTICE [_nick_me] :[_data]
|
||||
|:[_INTERNAL_source_IRC] NOTICE [_nick_me] :[_data]
|
||||
|
||||
_message_private_action
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%ACTION [_action].%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%ACTION [_action].%
|
||||
|
||||
_message_private_question
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%ACTION {_TEXT_action_asks}: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%ACTION {_TEXT_action_asks}: [_data]%
|
||||
|
||||
_message_private_ask
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%ACTION {_TEXT_action_asks}: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%ACTION {_TEXT_action_asks}: [_data]%
|
||||
|
||||
_message_private_text_action
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%ACTION [_action]: [_data]%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%ACTION [_action]: [_data]%
|
||||
|
||||
_message_private_action_action
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%ACTION [_action].%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%ACTION [_action].%
|
||||
|
||||
_notice_switch_identity
|
||||
|:[_nick_me] NICK [_nick_next]
|
||||
@ -208,53 +208,53 @@ _notice_login
|
||||
|## shut up
|
||||
|
||||
_notice_invitation
|
||||
|:[_source_hack] INVITE [_nick_me] :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] INVITE [_nick_me] :#[_nick_place]
|
||||
|
||||
_notice_typing_inactive
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%TYPING INACTIVE%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%TYPING INACTIVE%
|
||||
|
||||
_notice_typing_paused
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%TYPING PAUSED%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%TYPING PAUSED%
|
||||
|
||||
_notice_typing_composing
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%TYPING COMPOSING%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%TYPING COMPOSING%
|
||||
|
||||
_notice_typing_active
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%TYPING ACTIVE%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%TYPING ACTIVE%
|
||||
|
||||
_notice_typing_gone
|
||||
|:[_source_hack] PRIVMSG [_nick_me] :%TYPING GONE%
|
||||
|:[_INTERNAL_source_IRC] PRIVMSG [_nick_me] :%TYPING GONE%
|
||||
|
||||
_notice_place_AREYOUNUTS
|
||||
|:{_VAR_server} NOTICE #[_nick_place] :[_data]
|
||||
|
||||
_notice_place_enter
|
||||
|## es wird nur diese JOIN datei verwendet.. die anderen können alle in den müll
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_notice_place_enter_automatic
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_notice_place_enter_subscribe
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_notice_place_enter_login
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_notice_place_enter_home
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_notice_place_enter_join
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_notice_place_enter_follow
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_notice_place_enter_automatic_subscription
|
||||
|:[_source_hack] JOIN :#[_nick_place]
|
||||
|:[_INTERNAL_source_IRC] JOIN :#[_nick_place]
|
||||
|
||||
_echo_place_leave
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_echo_place_leave_logout
|
||||
|## Why is this blank? Current w() code ignores this however.
|
||||
@ -262,59 +262,59 @@ _echo_place_leave_logout
|
||||
_notice_place_leave
|
||||
|## user messages embedded in state changes are bad protocol design
|
||||
|## we use the space for system text
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_automatic
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_subscribe
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_netburp
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_home
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_disconnect
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_netburp
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_follow
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_logout
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_automatic_subscription
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_leave_invalid
|
||||
|:[_source_hack] PART #[_nick_place] :{_VAR_method}
|
||||
|:[_INTERNAL_source_IRC] PART #[_nick_place] :{_VAR_method}
|
||||
|
||||
_notice_place_topic
|
||||
|:[_source_hack] TOPIC #[_nick_place] :[_topic]
|
||||
|:[_INTERNAL_source_IRC] TOPIC #[_nick_place] :[_topic]
|
||||
|
||||
_notice_place_topic_official
|
||||
|#332 [_nick_me] #[_nick_place] :[_topic]
|
||||
|
||||
_echo_ping
|
||||
|:[_source_hack] NOTICE [_nick_me] :%PING [_time_ping]%
|
||||
|:[_INTERNAL_source_IRC] NOTICE [_nick_me] :%PING [_time_ping]%
|
||||
|
||||
_failure_unsupported_ping
|
||||
|## yes, this is a pong also...
|
||||
|:[_source_hack] NOTICE [_nick_me] :%PING [_time_ping]%
|
||||
|:[_INTERNAL_source_IRC] NOTICE [_nick_me] :%PING [_time_ping]%
|
||||
|
||||
_info_server_version
|
||||
|:[_host_server] 351 [_nick_me] [_version].[_degree_debug] [_host_server] :[_version_server] using [_version_driver] available from [_page_server_software]
|
||||
|
||||
_status_version
|
||||
|:[_source_hack] NOTICE [_nick_me] :%VERSION [_version_description] ([_version])%
|
||||
|:[_INTERNAL_source_IRC] NOTICE [_nick_me] :%VERSION [_version_description] ([_version])%
|
||||
|
||||
_status_version_agent
|
||||
|:[_source_hack] NOTICE [_nick_me] :%VERSION [_version_description] ([_version])%
|
||||
|:[_INTERNAL_source_IRC] NOTICE [_nick_me] :%VERSION [_version_description] ([_version])%
|
||||
|
||||
_list_friends_channel
|
||||
|#353 [_nick_me] = & :[_friends]
|
||||
|
@ -330,7 +330,7 @@ case "privmsg":
|
||||
// joe_nick +" :You're not registered yet.\n";
|
||||
render("_error_necessary_registration",
|
||||
"Sorry, you cannot use this without prior registration.", ([
|
||||
"_source_hack": IRCGATE_NICK,
|
||||
"_INTERNAL_source_IRC": IRCGATE_NICK,
|
||||
"_nick_me" : joe_nick,
|
||||
]));
|
||||
return 1;
|
||||
@ -821,7 +821,7 @@ msg(source, mc, data, mapping vars, showingLog, target) {
|
||||
}
|
||||
#else
|
||||
// TODO: remove 'pm' logic?
|
||||
vars["_source_hack"] = source;
|
||||
vars["_INTERNAL_source_IRC"] = source;
|
||||
vars["_nick_me"] = ni;
|
||||
//send(source, psyctext(t, vars, data, source));
|
||||
render(mca, data, vars, source);
|
||||
|
@ -241,7 +241,7 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
// der raum uns ne kopie gibt.. ist auch gut so, denn der irc code
|
||||
// versaut total die history der räume! einmal ein ircer
|
||||
// drin gehabt und aus vars["_time_place"] sind _prefix'e geworden
|
||||
// und _source_hack's sind im raum gespeichert und mehr so unsinn.
|
||||
// und _INTERNAL_source_IRC's sind im raum gespeichert und mehr so unsinn.
|
||||
if (mappingp(vars)) vars = copy(vars);
|
||||
else vars = ([]);
|
||||
// hmm.. wie die _time_place's aus der room history rausfallen
|
||||
@ -302,6 +302,7 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
return ::wAction(mc, data, vars
|
||||
+ ([ "_action" : T("_TEXT_action_says", 0) ]),
|
||||
source, "", vars["_nick"]);
|
||||
#if 1 //def USE_THE_NICK
|
||||
# ifdef OLD_LOCAL_NICK_PLAIN_TEXTDB_HACK //{{{
|
||||
else if (vars["_nick_local"]) { // less work
|
||||
if (mc == "_message_echo_public_action"
|
||||
@ -323,6 +324,7 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
vars["_nick_local"] == vars["_nick"])
|
||||
vars["_nick"] = vars["_INTERNAL_nick_plain"] || vars["_nick_verbatim"];
|
||||
# endif
|
||||
#endif // USE_THE_NICK
|
||||
|
||||
// if (vars["_nick_local"]) mc += "_masquerade"; // more work
|
||||
di = printStyle(mc); // display infos
|
||||
@ -372,32 +374,32 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
#ifdef GHOST //{{{
|
||||
// in S2S mode we are not supposed to deliver nick!user@host
|
||||
// thus we use plain nicks or plain uniforms
|
||||
vars["_source_hack"] = vars["_INTERNAL_nick_plain"] || vars["_nick"];
|
||||
vars["_INTERNAL_source_IRC"] = vars["_INTERNAL_nick_plain"] || vars["_nick"];
|
||||
#else //}}}
|
||||
# if 0 // OLD // according to elmex "should never happen" happened...
|
||||
if (vars["_nick"]) {
|
||||
vars["_source_hack"] =
|
||||
vars["_INTERNAL_source_IRC"] =
|
||||
(vars["_INTERNAL_nick_plain"] || vars["_nick"])
|
||||
+ "!"+ (vars["_nick_long"] || vars["_INTERNAL_nick_plain"]
|
||||
|| vars["_nick"])
|
||||
+"@" SERVER_HOST;
|
||||
} else // should never happen
|
||||
vars["_source_hack"] = to_string(source);
|
||||
vars["_INTERNAL_source_IRC"] = to_string(source);
|
||||
# else // EXPERIMENTAL
|
||||
nick2 = vars["_INTERNAL_nick_plain"] || vars["_nick"];
|
||||
vars["_source_hack"] = nick2 ? nick2
|
||||
vars["_INTERNAL_source_IRC"] = nick2 ? nick2
|
||||
+"!"+ (vars["_nick_long"] || vars["_INTERNAL_nick_plain"]
|
||||
|| vars["_nick"]) +"@" SERVER_HOST
|
||||
: to_string(source); // should never happen
|
||||
# endif
|
||||
} else if (abbrev("_echo_place_enter", mc)) {
|
||||
vars["_source_hack"] = MYNICK + "!" + MYNICK + "@" SERVER_HOST;
|
||||
vars["_INTERNAL_source_IRC"] = MYNICK + "!" + MYNICK + "@" SERVER_HOST;
|
||||
#endif
|
||||
} else {
|
||||
#ifdef GHOST //{{{
|
||||
// in S2S mode we are not supposed to deliver nick!user@host
|
||||
// thus we use plain nicks or plain uniforms
|
||||
vars["_source_hack"] = source;
|
||||
vars["_INTERNAL_source_IRC"] = source;
|
||||
#else //}}}
|
||||
u = parse_uniform(source);
|
||||
unless (u) {
|
||||
@ -412,7 +414,7 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
# ifdef ALIASES
|
||||
if (raliases[source]) {
|
||||
nick2 = raliases[source];
|
||||
vars["_source_hack"] = nick2 +"!"+
|
||||
vars["_INTERNAL_source_IRC"] = nick2 +"!"+
|
||||
u[UNick]? u[UNick] +"@"+ u[UHost]
|
||||
: (vars["_nick_long"]
|
||||
|| vars["_INTERNAL_nick_plain"]
|
||||
@ -422,22 +424,25 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
|
||||
unless (nick2) {
|
||||
# endif
|
||||
// should all of this go into our own copy of uni2nick() ?
|
||||
// or should we keep protocol source hacks separate from
|
||||
// people nicks in message templates?
|
||||
switch (u[UScheme]) {
|
||||
case "psyc":
|
||||
if (u[UUser] || (u[UResource] && strlen(u[UResource])
|
||||
&& u[UResource][0] == '~')) {
|
||||
string tmp = u[UNick];
|
||||
vars["_source_hack"] = u[UScheme] + "://"
|
||||
vars["_INTERNAL_source_IRC"] = u[UScheme] + "://"
|
||||
+ u[UHostPort] +"/~"+ tmp +"!"+ tmp +"@"
|
||||
+ u[UHostPort];
|
||||
P4(("w:psyc _source_hack %O\n", vars["_source_hack"]))
|
||||
P4(("w:psyc _INTERNAL_source_IRC %O\n", vars["_INTERNAL_source_IRC"]))
|
||||
} else {
|
||||
vars["_source_hack"] = uniform2irc(source)
|
||||
vars["_INTERNAL_source_IRC"] = uniform2irc(source)
|
||||
+"!*@"+ (u[UHostPort] || "host.undefined");
|
||||
// '*' nicer than 'undefined' and never a nick
|
||||
// this happens a lot more often then we thought :(
|
||||
// like for _request_version from server_unl
|
||||
D1( unless(u[UHostPort]) PP(("irc/user %O source %O results in %O for %O\n", ME, source, vars["_source_hack"], mc)); )
|
||||
D1( unless(u[UHostPort]) PP(("irc/user %O source %O results in %O for %O\n", ME, source, vars["_INTERNAL_source_IRC"], mc)); )
|
||||
}
|
||||
break;
|
||||
case "jabber":
|
||||
@ -453,22 +458,22 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
P3(("changing source from %O to %O\n", source, vars["_location"]))
|
||||
source = vars["_location"];
|
||||
}
|
||||
vars["_source_hack"] = uniform2irc(source)
|
||||
vars["_INTERNAL_source_IRC"] = uniform2irc(source)
|
||||
+ "!" + u[UUserAtHost];
|
||||
#ifdef JABBER_PATH // MUC support..
|
||||
// unfortunately, net/entity has rendered _nick unusable
|
||||
if (vars["_nick_place"] && vars["_INTERNAL_source_resource"] && member(vars["_INTERNAL_source_resource"], ' ') != -1){
|
||||
// xmpp: is here in cleartext.. TODO maybe?
|
||||
vars["_source_hack"] = "xmpp:"+
|
||||
vars["_INTERNAL_source_IRC"] = "xmpp:"+
|
||||
uniform2irc(u[UUserAtHost]);
|
||||
t = replace(vars["_INTERNAL_source_resource"], " ", "%20");
|
||||
vars["_source_hack"] += "/" + t + "!" + u[UUserAtHost];
|
||||
PT(("irc/user: XMPP source hack %O for %O\n", vars["_source_hack"], ME))
|
||||
vars["_INTERNAL_source_IRC"] += "/" + t + "!" + u[UUserAtHost];
|
||||
PT(("irc/user: XMPP source hack %O for %O\n", vars["_INTERNAL_source_IRC"], ME))
|
||||
}
|
||||
#endif
|
||||
break;
|
||||
default:
|
||||
vars["_source_hack"] = source + "!*@*";
|
||||
vars["_INTERNAL_source_IRC"] = source + "!*@*";
|
||||
}
|
||||
# ifdef ALIASES
|
||||
}
|
||||
@ -482,7 +487,7 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
int l;
|
||||
string output;
|
||||
|
||||
output =":"+ vars["_source_hack"] +" NOTICE "+ MYNICK +" :";
|
||||
output =":"+ vars["_INTERNAL_source_IRC"] +" NOTICE "+ MYNICK +" :";
|
||||
l = strlen(output);
|
||||
output += "#PRESENCE "+ t +" "+ vars["_degree_mood"]
|
||||
+" :"+ vars["_description_presence"] +"#\n";
|
||||
@ -497,20 +502,20 @@ w(string mc, string data, mapping vars, mixed source) {
|
||||
|
||||
if (old <= AVAILABILITY_VACATION) {
|
||||
if (t >= AVAILABILITY_NEARBY)
|
||||
emit(":"+ vars["_source_hack"] +" JOIN :&HERE\n");
|
||||
emit(":"+ vars["_INTERNAL_source_IRC"] +" JOIN :&HERE\n");
|
||||
else if (t >= AVAILABILITY_AWAY)
|
||||
emit(":"+ vars["_source_hack"] +" JOIN :&AWAY\n");
|
||||
emit(":"+ vars["_INTERNAL_source_IRC"] +" JOIN :&AWAY\n");
|
||||
} else if (old < AVAILABILITY_NEARBY) {
|
||||
if (t >= AVAILABILITY_NEARBY) {
|
||||
emit(":"+ vars["_source_hack"] +" PART :&AWAY\n");
|
||||
emit(":"+ vars["_source_hack"] +" JOIN :&HERE\n");
|
||||
emit(":"+ vars["_INTERNAL_source_IRC"] +" PART :&AWAY\n");
|
||||
emit(":"+ vars["_INTERNAL_source_IRC"] +" JOIN :&HERE\n");
|
||||
} else if (t < AVAILABILITY_AWAY)
|
||||
emit(":"+ vars["_source_hack"] +" PART :&AWAY\n");
|
||||
emit(":"+ vars["_INTERNAL_source_IRC"] +" PART :&AWAY\n");
|
||||
} else {
|
||||
if (t < AVAILABILITY_NEARBY)
|
||||
emit(":"+ vars["_source_hack"] +" PART :&HERE\n");
|
||||
emit(":"+ vars["_INTERNAL_source_IRC"] +" PART :&HERE\n");
|
||||
if (t >= AVAILABILITY_AWAY)
|
||||
emit(":"+ vars["_source_hack"] +" JOIN :&AWAY\n");
|
||||
emit(":"+ vars["_INTERNAL_source_IRC"] +" JOIN :&AWAY\n");
|
||||
}
|
||||
# else
|
||||
// ... MODE #whateverTesting +v xni3
|
||||
|
Loading…
Reference in New Issue
Block a user