{
if (Defines.DEBUG && CAT.isEnabledFor(org.apache.log4j.Level.ERROR)) CAT.error("invalid contact list entry uin ignored, exception ignored", ex11);
continue;
}
if (this.uin == dstUin)
throw new MessagingNetworkException(
"cannot login with your own uin in a contact list",
MessagingNetworkException.CATEGORY_LOGGED_OFF_ON_BEHALF_OF_MESSAGING_SERVER_OR_PROTOCOL_ERROR,
MessagingNetworkException.ENDUSER_CANNOT_LOGIN_WITH_YOURSELF_ON_CONTACT_LIST);
Integer dstUin_ = new Integer(dstUin);
if (contactListUinInt2cli.put(dstUin_, makeContactListItem(dstLoginId)) != null)
{
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("" + dstLoginId + " already in a contact list, cl entry ignored");
continue;
}
}
}
synchronized (logoutLock)
{
if ((loginId) == null) Lang.ASSERT_NOT_NULL(loginId, "loginId");
if ((password) == null) Lang.ASSERT_NOT_NULL(password, "password");
snac_nextid = 1;
loggingIn = true;
}
setReconnectData(status_Oscar, contactListUinInt2cli);
FlapConsumer authServerFC = new FlapConsumer()
{
private int state = 10;
public boolean isBosConn()
{
return false;
}
public void parse(final int flapChannel, final byte[] flapBody, int ofs, int len) throws Exception
{
final int datalen = len;
switch (state)
{
case 10:
{
if (datalen < 4)
MLang.EXPECT(
datalen >= 4, "hello length must be >= 4, but it is " + datalen,
MessagingNetworkException.CATEGORY_LOGGED_OFF_ON_BEHALF_OF_MESSAGING_SERVER_OR_PROTOCOL_ERROR,
MessagingNetworkException.ENDUSER_LOGGED_OFF_DUE_TO_PROTOCOL_ERROR);
long hello = aimutil_get32(flapBody, ofs);
ofs+=4; len-=4;
if (hello != 1)
MLang.EXPECT_EQUAL(
hello, 1, "flap version", "00 00 00 01",
MessagingNetworkException.CATEGORY_LOGGED_OFF_ON_BEHALF_OF_MESSAGING_SERVER_OR_PROTOCOL_ERROR,
MessagingNetworkException.ENDUSER_LOGGED_OFF_DUE_TO_PROTOCOL_ERROR);
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("server hello received, sending login request");
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("entered loginSequence_10sendLogin()"); //, password="+StringUtil.toPrintableString(password));
if (StringUtil.isNullOrEmpty(password)) Lang.ASSERT_NOT_NULL_NOR_EMPTY(password, "icq password");
if (StringUtil.isNullOrEmpty(loginId)) Lang.ASSERT_NOT_NULL_NOR_EMPTY(loginId, "loginId");
final byte[] password_b = string2byteArray(password);
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("login, stage 10: password length = " + password_b.length);
int xorindex = 0;
for (int i = 0; i < password_b.length; i++)
{
password_b[i] ^= xor_table[xorindex++];
if (xorindex >= xor_table.length)
xorindex = 0;
}
final byte[] sn = string2byteArray(loginId);
{
byte[] pak = new byte[0x7e + password_b.length - 1 + sn.length - 8];
int ofs1 = 0;
ofs1 += aimutil_put32(pak, ofs1, 0x00000001);
ofs1 += aim_puttlv_str_(pak, ofs1, 1, sn);
ofs1 += aim_puttlv_str_(pak, ofs1, 2, password_b);
ofs1 += aim_puttlv_str_(pak, ofs1, 3, string2byteArray("ICQ Inc. - Product of ICQ (TM).2000b.4.63.1.3279.85"));
final byte[] trail = {//
(byte) 0x00, (byte) 0x16,//
(byte) 0x00, (byte) 0x02,//
(byte) 0x01, (byte) 0x0A,//
//
(byte) 0x00, (byte) 0x17,//
(byte) 0x00, (byte) 0x02,//
(byte) 0x00, (byte) 0x04,//
//
(byte) 0x00, (byte) 0x18,//
(byte) 0x00, (byte) 0x02,//
(byte) 0x00, (byte) 0x3F,//
//
(byte) 0x00, (byte) 0x19,//
(byte) 0x00, (byte) 0x02,//
(byte) 0x00, (byte) 0x01,//
//
(byte) 0x00, (byte) 0x1A,//
(byte) 0x00, (byte) 0x02,//
(byte) 0x0C, (byte) 0xCF,//
//
(byte) 0x00, (byte) 0x14,//
(byte) 0x00, (byte) 0x04,//
(byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x55,//
//
(byte) 0x00, (byte) 0x0F,//
(byte) 0x00, (byte) 0x02,//
(byte) 0x65, (byte) 0x6E,// "en"
//
(byte) 0x00, (byte) 0x0E,//
(byte) 0x00, (byte) 0x02,//
(byte) 0x75, (byte) 0x73// "us"
};
System.arraycopy(trail, 0, pak, ofs1, trail.length);
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("login/10: sending uin/password packet");
state = 20;
getAuthConnNotNull().send(pak, 1, opLogin);
}
break;
}
case 20:
{
//flap channel
if (flapChannel != 4)
{
handleAuthorizationError_alwaysThrowEx(flapBody, ofs, len, flapChannel, ctx);
//unreachable code
return;
}
Aim_tlvlist_t resp = new Aim_tlvlist_t(Session.this, flapBody, ofs, len);
bos_hostport = resp.getNthTlvOfTypeAsString(1, 5);
cookie = resp.getNthTlvOfTypeAsByteArray(1, 6);
if (cookie == null || bos_hostport == null)
{
cookie = null;
bos_hostport = null;
handleAuthorizationError_alwaysThrowEx(flapBody, ofs, len, flapChannel, ctx);
}
state = 30;
opLogin.runNow(
new MessagingTask("login/20", opLogin)
{
public void run() throws Exception
{
if (Defines.DEBUG && CAT.isDebugEnabled())
CAT.debug("aim_send_login(): cookie received, closing auth connection...");
{
Aim_conn_t oldconn;
synchronized (logoutLock)
{
oldconn = authconn;
authconn = null;
}
closeConnectionIfNotNull(oldconn);
}
checkShuttingdown();
if (Defines.DEBUG && CAT.isDebugEnabled())
CAT.debug("aim_send_login(): auth connection closed, connecting to bos...");
{
Aim_conn_t conn = aim_newconn(AIMConstants.AIM_CONN_TYPE_BOS, bos_hostport, bosFc, ctx);
bos_hostport = null;
synchronized (shuttingDownLock)
{
messageQueue = new OutgoingMessageQueue(conn, Session.this, ctx);
}
Aim_conn_t oldconn;
synchronized (logoutLock)
{
oldconn = bosconn;
bosconn = conn;
}
closeConnectionIfNotNull(oldconn);
if (isShuttingDown()) conn.closeSocket();
}
}
}
);
break;
} //end of case
} //end of switch(state)
ofs += datalen; len -= datalen;
} //end of parse()
}; //end of authServerFC
bosFc = new FlapConsumer()
{
private int state = 25;
public boolean isBosConn()
{
return true;
}
public void parse(final int flapChannel, final byte[] flapBody, final int ofs, final int len) throws Exception
{
final int datalen = len;
switch (state)
{
case 25:
{
checkShuttingdown();
byte[] xxx = new byte[8];
int offset = 0;
offset += aimutil_put16(xxx, offset, 0x0000);
offset += aimutil_put16(xxx, offset, 0x0001);
offset += aimutil_put16(xxx, offset, 0x0006);
offset += aimutil_put16(xxx, offset, cookie.length);
state = 30;
ByteArrayOutputStream ba = new ByteArrayOutputStream(8+cookie.length);
ba.write(xxx);
ba.write(cookie);
cookie = null;
getBosConnNotNull().send(ba.toByteArray(), 1, opLogin);
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("login/30 waiting for serverready");
break;
}
case 30:
{
//if (Thread.currentThread().isInterrupted())
// throw new InterruptedException();
//shutdownAt(stopTime, "waitForServerReady", ctx);
//byte[] flap_header = new byte[6];
//getBosConnNotNull().read(flap_header);
//int len = flap_header.length;
//FLAPHeader flap = new FLAPHeader(flap_header);
//byte[] flap_data_field = AllocUtil.createByteArray(this, flap.data_field_length);
//getBosConnNotNull().read(flap_data_field);
//len = flap_data_field.length;
if (flapChannel == 4)
{
rx_handleConnectionError(flapBody, ofs, len, ctx);
break; //continue waiting //not executed if the error is "logged on from another pc".
}
if (flapChannel != 2 && len < 4)
break; //continue waiting
int family = aimutil_get16(flapBody, ofs);
int subtype = aimutil_get16(flapBody, ofs+2);
if ((family != 0 && subtype == 1) || (family == 9 && subtype == 9))
{
rx_handleGenericServiceError(flapBody, ofs, len, ctx);
break;
}
if (family != AIM_CB_FAM_GEN /*1*/|| subtype != AIM_CB_GEN_SERVERREADY /*3*/)
break;
state = 40;
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("exited waitForServerReady, entered login/40 sendContactList()");
if (status_Oscar == StatusUtil.OSCAR_STATUS_ONLINE)
setStatus_Oscar_Internal(opLogin, status_Oscar, false, ctx, MessagingNetworkException.CATEGORY_NOT_CATEGORIZED, null, MessagingNetworkException.ENDUSER_NO_ERROR);
else
setStatus_Oscar_Internal(opLogin, status_Oscar, true, ctx, MessagingNetworkException.CATEGORY_NOT_CATEGORIZED, null, MessagingNetworkException.ENDUSER_NO_ERROR);
synchronized (logoutLock)
{
crAttempted = false;
}
SNAC p = null;
if (!FETCH_OFFLINE_MESSAGES)
{
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug("fetch offline messages: disabled.");
}
else
{
noIncomingOfflineMessages = true;
}
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 1/0x17, generic service controls/unknown");
p = new SNAC(0x0001, 0x0017);
p.addByteArray(new byte[] {
00, 01, 00, 03,
00, 02, 00, 01,
00, 03, 00, 01,
00, 0x15, 00, 01,
00, 04, 00, 01,
00, 06, 00, 01,
00, 0x09, 00, 01,
00, 0x0A, 00, 01
});
//this packet was exactly like in &rq (incl. snac reqids).
p.send(getBosConnNotNull(), opLogin);
/*
ignored: //NADO WAITAT' HERE FOR 1/0x18
server sends // got it, ack to 1,17
SERVER seq:61B5 size:48 service:01/18 ref:00008580 flags:0000
00 01 00 03 00 02 00 01 00 03 00 01 00 04 00 01 00 06 00 01
00 08 00 01 00 09 00 01 00 0A 00 01 00 0B 00 01 00 0C 00 01
00 13 00 02 00 15 00 01
*/
if (!REQUEST_RATEINFO)
{
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("request rate info: disabled.");
}
/*
else
{
rateInfoResponseReceived = false;
getBosConnNotNull().addHandler(new Rx HandlerImpl()
{
public boolean triggered(Session sess, final int flapChannel, final byte[] flapBody, final int ofs, final int len, final SNAC snac)
throws IOException, MessagingNetworkException, InterruptedException
{
getBosConnNotNull().removeHandler(getThis());
synchronized (rateResponseWaitLock)
{
rateInfoResponseReceived = true;
rateResponseWaitLock.notify();
}
return true;
}
}, 1, 7); //rate info response
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 1/6, rate info request");
p = new SNAC(0x0001, 0x0006);
p.send(getBosConnNotNull());
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): waiting for rate info response...");
long stopTime = System.currentTimeMillis() + 1000 * ICQ2KMessagingNetwork.REQPARAM_SERVER_RESPONSE_TIMEOUT1_SECONDS;
for (;;)
{
synchronized (rateResponseWaitLock)
{
if (rateInfoResponseReceived) break;
}
shutdownAt(stopTime, "rate info response wait", ctx);
t ick(ctx);
Thread.currentThread().sleep(10);
}
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("got rate info response, sending 1/8 rate info ack");
p = new SNAC(1, 8);
p.addByteArray(new byte[] {00, 01, 00, 02, 00, 03, 00, 04, 00, 05});
p.send(getBosConnNotNull());
//this packet was exactly like in &rq (incl. snac reqids).
}
*/
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 1/0xe, generic service controls/request my info");
p = new SNAC(0x0001, 0x000e);
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 2/2, location/Request rights information");
p = new SNAC(0x0002, 0x0002);
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 3/2, buddylist/Request rights information");
p = new SNAC(0x0003, 0x0002);
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 4/4, messaging/Request parameter information");
p = new SNAC(0x0004, 0x0004);
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 9/2, bos-specific/Request BOS Rights");
p = new SNAC(0x0009, 0x0002);
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
/*
ignored:
//NADO WAIT HERE FOR 1/0xf
server sends // response to 1,0E
SERVER seq:61B7 size:92 service:01/0F ref:00000000 flags:0000
45454734 _ % �� ;��m ;��n
08 34 35 34 35 34 37 33 34 00 00 00 06 00 01 00 02 00 80 00
0C 00 25 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
00 0A 00 04 C2 95 E0 03 00 0F 00 04 00 00 00 00 00 02 00 04
3B A1 D9 6D 00 03 00 04 3B A1 D9 6E
//NADO WAIT HERE FOR 2/3
SERVER seq:61B8 size:18 service:02/03 ref:00000000 flags:0000
00 01 00 02 04 00 00 02 00 02 00 10 00 03 00 02 00 0A
//NADO WAIT HERE FOR 3/3
SERVER seq:61B9 size:18 service:03/03 ref:00000000 flags:0000
X �
00 01 00 02 02 58 00 02 00 02 02 EE 00 03 00 02 02 00
//NADO WAIT HERE FOR 4/5
SERVER seq:61BA size:16 service:04/05 ref:00000000 flags:0000
� � �
00 02 00 00 00 03 02 00 03 E7 03 E7 00 00 03 E8
//NADO WAIT HERE FOR 0x9/3
SERVER seq:61BB size:12 service:09/03 ref:00000000 flags:0000
� �
00 02 00 02 00 A0 00 01 00 02 00 A0
*/
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 4/2, Messaging/Add ICBM parameter");
p = new SNAC(0x0004, 0x0002);
p.addByteArray(new byte[] {
00, 00,
00, 00,
00, 03,
0x1F, 0x40,
03, (byte) 0xE7,
03, (byte) 0xE7,
00, 00,
00, 00
});
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 2/4, Location Services/Set user information");
p = new SNAC(0x0002, 0x0004);
p.addDWord(0x00050020);//TLV(5)
p.addDWord(0x09461349);//capability1 //direct-message capability?
p.addDWord(0x4C7F11D1);//capability1 //licq doesn't send the capability1
p.addDWord(0x82224445);//capability1 //icq2k sends both cap1 and cap2
p.addDWord(0x53540000);//capability1
p.addDWord(0x09461344);//capability2
p.addDWord(0x4C7F11D1);//capability2
p.addDWord(0x82224445);//capability2
p.addDWord(0x53540000);//capability2
p.send(getBosConnNotNull(), opLogin);
p = null;
//this packet was exactly like in &rq (incl. snac reqids).
//send the buddy list and profile (required, even if empty)
//aim_bos_setbuddylist(sess, command->getBosConnNotNull(), buddies);
//
//Add buddy [Source: User_]
//Adds a number of buddies to your buddy list, causing AIM to send
//us on/off events for the given users. Len/buddy combinations can be
//repeated as many times as you have buddies to add.
//
//SNAC Information:
//
//Family 0x0003
//SubType 0x0004
//Flags {0x00, 0x00}
//
//--------------------------------------------------------------------------------
//
//RAW / Buddy name length (byte)
//RAW / Buddy name
java.io.ByteArrayOutputStream ba = new java.io.ByteArrayOutputStream();
for (int i = 0; i < contactList.length; i++)
{
String s15 = String.valueOf(IcqUinUtil.parseUin(contactList[i], "contactList[i]", MessagingNetworkException.CATEGORY_NOT_CATEGORIZED));
byte[] buddyName = string2byteArray(s15);
ba.write((byte) buddyName.length);
ba.write(buddyName);
}
ba.flush();
byte[] baa = ba.toByteArray();
ba.close();
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 3/4, send contact list");
p = new SNAC(0x0003, 0x0004);
p.addByteArray(baa);
p.send(getBosConnNotNull(), opLogin);
ba = null;
baa = null;
//this packet was exactly like in &rq (incl. snac reqids).
boolean webAware = true;
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 1/0x1e setInitialStatus");
p = new SNAC(0x0001, 0x001e);
// TLV(6) status-code
p.addDWord(0x00060004);
p.addWord(0x1000 | (webAware ? 1 : 0) ); //joxy: i used 0x0003 earlier
p.addWord(status_Oscar); //joxy: i used 0x0000 earlier
// TLV(8) unknown, usually 0000
p.addDWord(0x00080002);
p.addWord(0);
// TLV(C) direct-connection-info
p.addByteArray(new byte[] {
(byte) 0x00, (byte) 0x0C, (byte) 0x00, (byte) 0x25, (byte) 0x7F, (byte) 0x00, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x07, (byte) 0x58, (byte) 0x58, (byte) 0x58, (byte) 0x58, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x32, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x03, (byte) 0x3A, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x3A, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x3A, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00, (byte) 0x00
});
/*
joxy: for TLV(C), i used earlier:
(byte) 0x00, (byte) 0x0C, (byte) 0x00, (byte) 0x25,
(byte) 0xC0, (byte) 0xA8, (byte) 0x04, (byte) 0x6B,
(byte) 0x00, (byte) 0x00, (byte) 0x73, (byte) 0x74,
(byte) 0x04, (byte) 0x00, (byte) 0x07, (byte) 0x1D,
(byte) 0xAE, (byte) 0xF0, (byte) 0x9E, (byte) 0x00,
(byte) 0x00, (byte) 0x00, (byte) 0x50, (byte) 0x00,
(byte) 0x00, (byte) 0x00, (byte) 0x03, (byte) 0x3B,
(byte) 0x17, (byte) 0x6B, (byte) 0x57, (byte) 0x3B,
(byte) 0x18, (byte) 0xAC, (byte) 0xE9, (byte) 0x3B,
(byte) 0x17, (byte) 0x6B, (byte) 0x4E, (byte) 0x00,
(byte) 0x00
*/
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 1/0x11, generic service controls/unknown");
p = new SNAC(0x0001, 0x0011);
p.addDWord(0);
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 9/7, BOS-specific/Add deny list entries");
p = new SNAC(0x0009, 0x0007);
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 1/2, client ready");
p = new SNAC(0x0001, 0x0002);
p.addDWord(0x00010003); p.addDWord(0x0110028A);
p.addDWord(0x00020001); p.addDWord(0x0101028A);
p.addDWord(0x00030001); p.addDWord(0x0110028A);
p.addDWord(0x00150001); p.addDWord(0x0110028A);
p.addDWord(0x00040001); p.addDWord(0x0110028A);
p.addDWord(0x00060001); p.addDWord(0x0110028A);
p.addDWord(0x00090001); p.addDWord(0x0110028A);
p.addDWord(0x000A0001); p.addDWord(0x0110028A);
/*
p.addByteArray(new byte[] {//
(byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x03, (byte) 0x00, (byte) 0x04, (byte) 0x06, (byte) 0x86,
(byte) 0x00, (byte) 0x02, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01,
(byte) 0x00, (byte) 0x03, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01,
(byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01,
(byte) 0x00, (byte) 0x06, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01,
(byte) 0x00, (byte) 0x08, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01,
(byte) 0x00, (byte) 0x09, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01,
(byte) 0x00, (byte) 0x0a, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01,
(byte) 0x00, (byte) 0x0b, (byte) 0x00, (byte) 0x01, (byte) 0x00, (byte) 0x04, (byte) 0x00, (byte) 0x01
};
*/
p.send(getBosConnNotNull(), opLogin);
//this packet was exactly like in &rq (incl. snac reqids).
//2A 02 0A B8 00 18 //clt snds
//00 15 00 02 //sf 5, unknown/unknown
//00 00
//00 01 00 02 //snac reqid
//00 01 00 0A
// 08
// 00 BE 5C 94 01 3C 00 02 00
// ..............._\".<...
//2a 02 5da1 0018 0015 0002 0000 00010002 0001 000a 0800 1b374d07 3c 00 02 00
if (FETCH_OFFLINE_MESSAGES)
{
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("sending: get offline messages");
p = new SNAC(0x0015, 0x0002);
//"BE 5C 94 01" aka 0x01 94 5C BE == 26500286
p.addByteArray(new byte[] {//
0x00, 0x01, 0x00, 0x0a, 0x08, 0x00, //
(byte) (uin & 0xff), //
(byte) ((uin >> 8)& 0xff), //
(byte) ((uin >> 16)& 0xff), //
(byte) ((uin >> 24)& 0xff), //
(byte) 0x3C, (byte) 0x00, //
0, // <-- joxy: i used 2 in this byte earlier
(byte) 0x00});
p.send(getBosConnNotNull(), opLogin);
p = null;
//this packet was exactly like in &rq (incl. snac reqids).
}
/*
//2a 02 5da2 0033 0015 0002 0000 00020002 0001 0025 2300 1b374d07 d0 07 03 00 98 08 17 00 3c 6b 65 79 3e 44 61 74 61 46 69 6c 65 73 49 50 3c 2f 6b 65 79 3e 00
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 0x15/2, reqid 2/2");
p = new SNAC(0x0015, 0x0002, 0, 0, 0x00020002);
//"BE 5C 94 01" aka 0x01 94 5C BE == 26500286
p.addByteArray(new byte[] {//
0x00, 0x01, 0x00, 0x25, 0x23, 0x00, //
(byte) (uin & 0xff), //
(byte) ((uin >> 8)& 0xff), //
(byte) ((uin >> 16)& 0xff), //
(byte) ((uin >> 24)& 0xff), //
(byte) 0xd0, (byte) 0x07, (byte) 0x03, (byte) 0x00, (byte) 0x98, (byte) 0x08, (byte) 0x17, (byte) 0x00, (byte) 0x3c, (byte) 0x6b, (byte) 0x65, (byte) 0x79, (byte) 0x3e, (byte) 0x44, (byte) 0x61, (byte) 0x74, (byte) 0x61, (byte) 0x46, (byte) 0x69, (byte) 0x6c, (byte) 0x65, (byte) 0x73, (byte) 0x49, (byte) 0x50, (byte) 0x3c, (byte) 0x2f, (byte) 0x6b, (byte) 0x65, (byte) 0x79, (byte) 0x3e, (byte) 0x00});
p.send(getBosConnNotNull());
p = null;
//2a 02 5da3 0031 0015 0002 0000 00030002 0001 0023 2100 1b374d07 d0 07 04 00 98 08 15 00 3c 6b 65 79 3e 42 61 6e 6e 65 72 73 49 50 3c 2f 6b 65 79 3e 00
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 0x15/2, reqid 3/2");
p = new SNAC(0x0015, 0x0002, 0, 0, 0x00030002);
//"BE 5C 94 01" aka 0x01 94 5C BE == 26500286
p.addByteArray(new byte[] {//
0x00, 0x01, 0x00, 0x23, 0x21, 0x00, //
(byte) (uin & 0xff), //
(byte) ((uin >> 8)& 0xff), //
(byte) ((uin >> 16)& 0xff), //
(byte) ((uin >> 24)& 0xff), //
(byte) 0xd0, (byte) 0x07, (byte) 0x04, (byte) 0x00, (byte) 0x98, (byte) 0x08, (byte) 0x15, (byte) 0x00, (byte) 0x3c, (byte) 0x6b, (byte) 0x65, (byte) 0x79, (byte) 0x3e, (byte) 0x42, (byte) 0x61, (byte) 0x6e, (byte) 0x6e, (byte) 0x65, (byte) 0x72, (byte) 0x73, (byte) 0x49, (byte) 0x50, (byte) 0x3c, (byte) 0x2f, (byte) 0x6b, (byte) 0x65, (byte) 0x79, (byte) 0x3e, (byte) 0x00});
p.send(getBosConnNotNull());
p = null;
//2a 02 5da4 0032 0015 0002 0000 00040002 0001 0024 2200 1b374d07 d0 07 05 00 98 08 16 00 3c 6b 65 79 3e 43 68 61 6e 6e 65 6c 73 49 50 3c 2f 6b 65 79 3e 00
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login/40 sendContactList(): sending 0x15/2, reqid 4/2");
p = new SNAC(0x0015, 0x0002, 0, 0, 0x00040002);
//"BE 5C 94 01" aka 0x01 94 5C BE == 26500286
p.addByteArray(new byte[] {//
0x00, 0x01, 0x00, 0x24, 0x22, 0x00, //
(byte) (uin & 0xff), //
(byte) ((uin >> 8)& 0xff), //
(byte) ((uin >> 16)& 0xff), //
(byte) ((uin >> 24)& 0xff), //
(byte) 0xd0, (byte) 0x07, (byte) 0x05, (byte) 0x00, (byte) 0x98, (byte) 0x08, (byte) 0x16, (byte) 0x00, (byte) 0x3c, (byte) 0x6b, (byte) 0x65, (byte) 0x79, (byte) 0x3e, (byte) 0x43, (byte) 0x68, (byte) 0x61, (byte) 0x6e, (byte) 0x6e, (byte) 0x65, (byte) 0x6c, (byte) 0x73, (byte) 0x49, (byte) 0x50, (byte) 0x3c, (byte) 0x2f, (byte) 0x6b, (byte) 0x65, (byte) 0x79, (byte) 0x3e, (byte) 0x00});
p.send(getBosConnNotNull());
p = null;
*/
//"offl msg ack" start
////2a 02 5da5 0018 0015 0002 0000 00050002 0001 000a 0800 1b374d07 3e 00 06 00
//if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
//login/40 sendContactList(): sending 0x15/2, reqid 5/2");
//p = new SNAC(0x0015, 0x0002, 0, 0, 0x00050002);
////"BE 5C 94 01" aka 0x01 94 5C BE == 26500286
//p.addByteArray(new byte[] {//
//0x00, 0x01, 0x00, 0x0a, 0x08, 0x00, //
//(byte) (uin & 0xff), //
//(byte) ((uin >> 8)& 0xff), //
//(byte) ((uin >> 16)& 0xff), //
//(byte) ((uin >> 24)& 0xff), //
//(byte) 0x3e, (byte) 0x00, (byte) 0x06, (byte) 0x00});
//p.send(getBosConnNotNull());
//p = null;
//"offl msg ack" end
////AIM/Oscar Protocol Specification:
////Section 3: BOS Signon: Set Initial ICBM Parameter
////--------------------------------------------------------------------------------
////Set ICBM Paramter[Source: User_]
////Not sure what this one does, but it can't hurt to send it.
////SNAC Information:
////Family 0x0004
////SubType 0x0002
////Flags {0x00, 0x00}
////--------------------------------------------------------------------------------
////RAW SNAC Header
////RAW 0x0000
////RAW 0x00000003
////RAW 0x1f40
////RAW 0x03e7
////RAW 0x03e7
////RAW 0x0000
////RAW 0x0000
//
//SNAC p = new SNAC(4, 2);
//p.addWord(0);
//p.addDWord(3);
//p.addWord(0x1f40);
//p.addWord(0x03e7);
//p.addWord(0x03e7);
//p.addWord(0);
//p.addWord(0);
//p.send(getBosConnNotNull());
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("exited login/40 sendContactList()");
//loginSequence_50waitForWwwAolComPacket(ctx);
getBosConnNotNull().setRateControlOn(true);
if (Defines.DEBUG && CAT.isDebugEnabled()) CAT.debug
("login(): fetching my authorizationRequired flag from server...");
//long startGetUserDetailsInternal(String srcLoginId, String dstLoginId) adds an interna operation;
//events from this operationId are never delivered to a external listeners
//they are delivered to internal listeners only.
//addInternalMessagingNetworkListener() adds an internal listener.
//removeInternalMessagingNetworkListener() removes an internal listener.
MessagingNetworkListener l =
new MessagingNetworkAdapter()
{
public final void getUserDetailsFailed(byte networkId, long operationId,
String originalSrcLoginId, String originalDstLoginId,
MessagingNetworkException ex)
{
if (loginId.equals(originalSrcLoginId) && loginId.equals(originalDstLoginId))
authReq(false, ex);
}
public final void getUserDetailsSuccess(byte networkId, long operationId,
String originalSrcLoginId, String originalDstLoginId,
UserDetails userDetails)
{
if (loginId.equals(originalSrcLoginId) && loginId.equals(originalDstLoginId))
{
boolean ar = false;
try
{
ar = userDetails.isAuthorizationRequired();
}
catch (MessagingNetworkException exar)
{
ar = false;
}
authReq(ar, null);
}
}
private final void authReq(boolean authorizationRequired, MessagingNetworkException mex)
{
Session.this.authorizationRequired = authorizationRequired;
if (mex == null
|| mex.getLogger() == MessagingNetworkException.CATEGORY_STILL_CONNECTED)
{
if (Defines.DEBUG && CAT.isDebugEnabled())
CAT.debug("login(): fetching my authorizationRequired flag done.");
setupSessionTasks();
opLogin.success();
opLogin = null;
}
}
}
;
// try
// {
// ctx.getGal().addForcedAop();
// AsyncOperationImpl aop = null;
// try
// {
// Session.this.enqueue(aop = new AsyncOperations.
// OpGetUserDetails(loginId, Session.this, false, ctx), l);
// }
// catch (MessagingNetworkException mex)
// {
// ctx.getPlug().handleEarlyException(aop, mex);
// throw mex;
// }
// }
// catch (MessagingNetworkException mex1)
// {
// l.getUserDetailsFailed((byte) -1, -1L, loginId, loginId, mex1);
// }
l.getUserDetailsFailed((byte) -1, -1L, loginId, loginId, new MessagingNetworkException(MessagingNetworkException.CATEGORY_STILL_CONNECTED,MessagingNetworkException.ENDUSER_NO_ERROR));
break;
}
case 40: //mainloop state case; must deliver events to Rx handlers etc etc etc
{