summaryrefslogtreecommitdiff
path: root/cppe/demo/IceE/chat/ChatClient.cpp
blob: 553ce8dcdbb8eb54970481f9634d8fef0b1eaf02 (plain)
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
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
// **********************************************************************
//
// Copyright (c) 2003-2005 ZeroC, Inc. All rights reserved.
//
// This copy of Ice is licensed to you under the terms described in the
// ICE_LICENSE file included in this distribution.
//
// **********************************************************************


#include "stdafx.h"
#include "ChatClient.h"
#include "ChatClientDlg.h"
#include "Router.h"
#include "Chat.h"
#include "LogI.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif

BEGIN_MESSAGE_MAP(CChatClientApp, CWinApp)
    ON_COMMAND(ID_HELP, CWinApp::OnHelp)
END_MESSAGE_MAP()

class ChatCallbackI : public Demo::ChatCallback
{
public:

    ChatCallbackI(LogIPtr log)
        : _log(log)
    {
    }

    virtual void
    message(const std::string& data, const Ice::Current&)
    {
	_log->message(data);
    }

private:

    LogIPtr _log;
};


CChatClientApp::CChatClientApp()
{
    // Place all significant initialization in InitInstance
}

// The one and only CChatClientApp object

CChatClientApp theApp;

BOOL CChatClientApp::InitInstance()
{
    //
    // InitCommonControls() is required on Windows XP if an application
    // manifest specifies use of ComCtl32.dll version 6 or later to enable
    // visual styles.  Otherwise, any window creation will fail.
    //
    InitCommonControls();

    CWinApp::InitInstance();

    //
    // Create a communicator and object adapter.
    //
    Ice::CommunicatorPtr communicator;
    Ice::ObjectAdapterPtr adapter;
    LogIPtr log;
    Demo::ChatSessionPrx session;
    try
    {
        int argc = 0;
        Ice::PropertiesPtr properties = Ice::createProperties();
	//properties->setProperty("Hello.Endpoints", "tcp -p 10000");
	properties->load("config");

        communicator = Ice::initializeWithProperties(argc, 0, properties);
        log = new LogI;
        communicator->setLogger(log);

	Ice::RouterPrx defaultRouter = communicator->getDefaultRouter();
	if(!defaultRouter)
	{
	    AfxMessageBox(CString("No default router set"), MB_OK|MB_ICONEXCLAMATION);
	    return FALSE;
	}

	Glacier2::RouterPrx router = Glacier2::RouterPrx::checkedCast(defaultRouter);
	if(!router)
	{
	    AfxMessageBox(CString("Configured router is not a Glacier2 router"), MB_OK|MB_ICONEXCLAMATION);
	    return FALSE;
	}

        try
        {
            session = Demo::ChatSessionPrx::uncheckedCast(router->createSession("username", "password"));
        }
        catch(const Glacier2::PermissionDeniedException& ex)
        {
            AfxMessageBox(CString(ex.toString().c_str()), MB_OK|MB_ICONEXCLAMATION);
            return FALSE;
        }

        std::string category = router->getServerProxy()->ice_getIdentity().category;
        Ice::Identity callbackReceiverIdent;
        callbackReceiverIdent.name = "callbackReceiver";
        callbackReceiverIdent.category = category;

        Ice::ObjectAdapterPtr adapter = communicator->createObjectAdapter("Chat.Client");
        Demo::ChatCallbackPrx callback = Demo::ChatCallbackPrx::uncheckedCast(
            adapter->add(new ChatCallbackI(log), callbackReceiverIdent));
        adapter->activate();

        session->setCallback(callback); 
    }
    catch(const Ice::Exception& ex)
    {
        AfxMessageBox(CString(ex.toString().c_str()), MB_OK|MB_ICONEXCLAMATION);
        return FALSE;
    }

    //
    // Create the dialog.
    //
    CChatClientDlg dlg(communicator, session, log);
        
    //
    // Show dialog and wait until it is closed, or until the servant receives
    // a shutdown request.
    //
    m_pMainWnd = &dlg;
    dlg.DoModal();

    //
    // Edit control no longer exists.
    //
    log->setControl(0);

    //
    // Clean up.
    //
    try
    {
        communicator->destroy();
    }
    catch(const Ice::Exception&)
    {
    }

    // Since the dialog has been closed, return FALSE so that we exit the
    // application, rather than start the application's message pump.
    return FALSE;
}