2010-05-07 04:47:10 -05:00
|
|
|
/*
|
2011-12-03 16:38:03 -06:00
|
|
|
* Copyright 2009-2011, Andrea Anzani. All rights reserved.
|
2010-05-07 04:47:10 -05:00
|
|
|
* Distributed under the terms of the MIT License.
|
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Andrea Anzani, andrea.anzani@gmail.com
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <image.h>
|
|
|
|
|
2010-05-16 16:02:50 -05:00
|
|
|
#include <Directory.h>
|
|
|
|
#include <Entry.h>
|
|
|
|
#include <Handler.h>
|
2010-05-07 04:47:10 -05:00
|
|
|
|
2010-05-16 16:02:50 -05:00
|
|
|
#include "Account.h"
|
2010-05-07 04:47:10 -05:00
|
|
|
#include "ProtocolManager.h"
|
|
|
|
#include "CayaProtocol.h"
|
|
|
|
#include "CayaUtils.h"
|
2010-05-16 16:02:50 -05:00
|
|
|
#include "MainWindow.h"
|
|
|
|
#include "Server.h"
|
|
|
|
#include "TheApp.h"
|
2010-05-07 04:47:10 -05:00
|
|
|
|
|
|
|
static ProtocolManager* fInstance = NULL;
|
|
|
|
|
|
|
|
|
|
|
|
void
|
2010-05-16 16:02:50 -05:00
|
|
|
ProtocolManager::Init(BDirectory dir, BHandler* target)
|
2010-05-07 04:47:10 -05:00
|
|
|
{
|
|
|
|
BEntry entry;
|
|
|
|
BPath path;
|
|
|
|
|
2010-05-16 16:02:50 -05:00
|
|
|
dir.Rewind();
|
2010-05-07 04:47:10 -05:00
|
|
|
|
2010-05-16 16:02:50 -05:00
|
|
|
while (dir.GetNextEntry(&entry) == B_OK) {
|
2010-05-07 04:47:10 -05:00
|
|
|
path = BPath(&entry);
|
|
|
|
|
2010-05-16 16:02:50 -05:00
|
|
|
// Load protocol addon
|
2010-05-07 04:47:10 -05:00
|
|
|
image_id id = load_add_on(path.Path());
|
2010-05-16 16:02:50 -05:00
|
|
|
if (id < 0)
|
|
|
|
continue;
|
|
|
|
|
2010-07-10 14:28:29 -05:00
|
|
|
// If add-on's API version fits then load accounts...
|
2010-05-16 16:02:50 -05:00
|
|
|
CayaProtocolAddOn* addOn = new CayaProtocolAddOn(id, path.Path());
|
Allow multiple protocols per add-on
Now an add-on can contain multiple protocols, and the protocol API has
changed. An add-on must now export protocol_count() and protocol_at(),
with the latter replacing protocol(). protocol_count() returning the
amount of protocols in a given add-on, and protocol_at(i) giving a
new CayaProtocol* "at" the given index.
CayaProtocol has also been changed, adding Signature(),
FriendlySignature(), Icon(), Path(), and SetPath(). The reasoning is
that different protocols (even within a single add-on) will have
different signatures and icons, so this data should be accessible from
the protocol itself.
CayaProtocolAddOn now has CountProtocols() and ProtocolAt(i), allowing
the accessing of multiple protocols. A CayaProtocolAddOn can be given a
default protocol index in the constructor, whose protocol will be
returned with Protocol(). Version() was also moved from CayaProtocol to
CayaProtocolAddOn.
2021-05-21 13:33:43 -05:00
|
|
|
if (addOn->Version() != CAYA_VERSION)
|
|
|
|
continue;
|
|
|
|
|
|
|
|
fAddOnMap.AddItem(addOn->Signature(), addOn);
|
|
|
|
_GetAccounts(addOn, addOn->Signature(), target);
|
|
|
|
|
|
|
|
// If add-on has multiple protocols, also load them
|
|
|
|
for (int32 i = 1; i < addOn->CountProtocols(); i++) {
|
|
|
|
CayaProtocolAddOn* subAddOn =
|
|
|
|
new CayaProtocolAddOn(id,path.Path(), i);
|
|
|
|
CayaProtocol* proto = subAddOn->Protocol();
|
|
|
|
|
|
|
|
fAddOnMap.AddItem(proto->Signature(), subAddOn);
|
|
|
|
_GetAccounts(subAddOn, proto->Signature(), target);
|
|
|
|
delete proto;
|
2010-07-10 14:28:29 -05:00
|
|
|
}
|
2010-05-07 04:47:10 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ProtocolManager::ProtocolManager()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
ProtocolManager*
|
|
|
|
ProtocolManager::Get()
|
|
|
|
{
|
|
|
|
if (fInstance == NULL)
|
|
|
|
fInstance = new ProtocolManager();
|
|
|
|
return fInstance;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-05-28 12:11:16 -05:00
|
|
|
uint32
|
|
|
|
ProtocolManager::CountProtocolAddOns() const
|
2010-05-16 16:02:50 -05:00
|
|
|
{
|
2010-05-28 12:11:16 -05:00
|
|
|
return fAddOnMap.CountItems();
|
2010-05-16 16:02:50 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-05-28 12:11:16 -05:00
|
|
|
CayaProtocolAddOn*
|
|
|
|
ProtocolManager::ProtocolAddOnAt(uint32 i) const
|
2010-05-16 16:02:50 -05:00
|
|
|
{
|
2010-05-28 12:11:16 -05:00
|
|
|
return fAddOnMap.ValueAt(i);
|
2010-05-16 16:02:50 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-05-28 12:11:16 -05:00
|
|
|
CayaProtocolAddOn*
|
|
|
|
ProtocolManager::ProtocolAddOn(const char* signature)
|
2010-05-07 04:47:10 -05:00
|
|
|
{
|
2010-05-28 12:11:16 -05:00
|
|
|
return fAddOnMap.ValueFor(signature);
|
2010-05-07 04:47:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-05-28 12:11:16 -05:00
|
|
|
uint32
|
|
|
|
ProtocolManager::CountProtocolInstances() const
|
2010-05-07 04:47:10 -05:00
|
|
|
{
|
2010-05-28 12:11:16 -05:00
|
|
|
return fProtocolMap.CountItems();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
CayaProtocol*
|
|
|
|
ProtocolManager::ProtocolInstanceAt(uint32 i) const
|
|
|
|
{
|
|
|
|
return fProtocolMap.ValueAt(i);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
CayaProtocol*
|
|
|
|
ProtocolManager::ProtocolInstance(bigtime_t identifier)
|
|
|
|
{
|
|
|
|
return fProtocolMap.ValueFor(identifier);
|
2010-05-07 04:47:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-05-16 16:02:50 -05:00
|
|
|
void
|
|
|
|
ProtocolManager::AddAccount(CayaProtocolAddOn* addOn, const char* account,
|
|
|
|
BHandler* target)
|
2010-05-07 04:47:10 -05:00
|
|
|
{
|
2010-05-16 16:02:50 -05:00
|
|
|
bigtime_t instanceId = system_time();
|
|
|
|
CayaProtocol* cayap = addOn->Protocol();
|
2021-05-21 15:52:33 -05:00
|
|
|
(void)new Account(instanceId, cayap, account, addOn->Signature(), target);
|
2010-05-16 16:02:50 -05:00
|
|
|
fProtocolMap.AddItem(instanceId, cayap);
|
|
|
|
|
|
|
|
TheApp* theApp = reinterpret_cast<TheApp*>(be_app);
|
|
|
|
theApp->GetMainWindow()->GetServer()->AddProtocolLooper(
|
|
|
|
instanceId, cayap);
|
2010-05-07 04:47:10 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-05-16 16:02:50 -05:00
|
|
|
void
|
Allow multiple protocols per add-on
Now an add-on can contain multiple protocols, and the protocol API has
changed. An add-on must now export protocol_count() and protocol_at(),
with the latter replacing protocol(). protocol_count() returning the
amount of protocols in a given add-on, and protocol_at(i) giving a
new CayaProtocol* "at" the given index.
CayaProtocol has also been changed, adding Signature(),
FriendlySignature(), Icon(), Path(), and SetPath(). The reasoning is
that different protocols (even within a single add-on) will have
different signatures and icons, so this data should be accessible from
the protocol itself.
CayaProtocolAddOn now has CountProtocols() and ProtocolAt(i), allowing
the accessing of multiple protocols. A CayaProtocolAddOn can be given a
default protocol index in the constructor, whose protocol will be
returned with Protocol(). Version() was also moved from CayaProtocol to
CayaProtocolAddOn.
2021-05-21 13:33:43 -05:00
|
|
|
ProtocolManager::_GetAccounts(CayaProtocolAddOn* addOn, const char* subProtocol,
|
|
|
|
BHandler* target)
|
2010-05-07 04:47:10 -05:00
|
|
|
{
|
2010-05-16 16:02:50 -05:00
|
|
|
// Find accounts path for this protocol
|
Allow multiple protocols per add-on
Now an add-on can contain multiple protocols, and the protocol API has
changed. An add-on must now export protocol_count() and protocol_at(),
with the latter replacing protocol(). protocol_count() returning the
amount of protocols in a given add-on, and protocol_at(i) giving a
new CayaProtocol* "at" the given index.
CayaProtocol has also been changed, adding Signature(),
FriendlySignature(), Icon(), Path(), and SetPath(). The reasoning is
that different protocols (even within a single add-on) will have
different signatures and icons, so this data should be accessible from
the protocol itself.
CayaProtocolAddOn now has CountProtocols() and ProtocolAt(i), allowing
the accessing of multiple protocols. A CayaProtocolAddOn can be given a
default protocol index in the constructor, whose protocol will be
returned with Protocol(). Version() was also moved from CayaProtocol to
CayaProtocolAddOn.
2021-05-21 13:33:43 -05:00
|
|
|
BPath path(CayaAccountPath(addOn->Signature(), subProtocol));
|
2010-05-16 16:02:50 -05:00
|
|
|
if (path.InitCheck() != B_OK)
|
|
|
|
return;
|
|
|
|
|
|
|
|
BDirectory dir(path.Path());
|
|
|
|
BEntry entry;
|
|
|
|
while (dir.GetNextEntry(&entry) == B_OK) {
|
|
|
|
BFile file(&entry, B_READ_ONLY);
|
|
|
|
BMessage msg;
|
|
|
|
|
|
|
|
if (msg.Unflatten(&file) == B_OK) {
|
|
|
|
char buffer[B_PATH_NAME_LENGTH];
|
|
|
|
if (entry.GetName(buffer) == B_OK) {
|
2021-05-21 15:52:33 -05:00
|
|
|
printf("Found %s for protocol %s!\n", buffer, subProtocol);
|
2010-05-16 16:02:50 -05:00
|
|
|
AddAccount(addOn, buffer, target);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2010-05-07 04:47:10 -05:00
|
|
|
}
|
Allow multiple protocols per add-on
Now an add-on can contain multiple protocols, and the protocol API has
changed. An add-on must now export protocol_count() and protocol_at(),
with the latter replacing protocol(). protocol_count() returning the
amount of protocols in a given add-on, and protocol_at(i) giving a
new CayaProtocol* "at" the given index.
CayaProtocol has also been changed, adding Signature(),
FriendlySignature(), Icon(), Path(), and SetPath(). The reasoning is
that different protocols (even within a single add-on) will have
different signatures and icons, so this data should be accessible from
the protocol itself.
CayaProtocolAddOn now has CountProtocols() and ProtocolAt(i), allowing
the accessing of multiple protocols. A CayaProtocolAddOn can be given a
default protocol index in the constructor, whose protocol will be
returned with Protocol(). Version() was also moved from CayaProtocol to
CayaProtocolAddOn.
2021-05-21 13:33:43 -05:00
|
|
|
|
|
|
|
|