// ********************************************************************** // // Copyright (c) 2003-2017 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 #include #include #include using namespace std; class AdminPermissionsVerifierI : public Glacier2::PermissionsVerifier { public: virtual bool checkPermissions(const string& userId, const string& passwd, string&, const Ice::Current& c) const { if(c.ctx.find("throw") != c.ctx.end()) { throw Test::ExtendedPermissionDeniedException("reason"); } if(userId == "shutdown") { c.adapter->getCommunicator()->shutdown(); return true; } return (userId == "admin1" && passwd == "test1") || (userId == "admin2" && passwd == "test2") || (userId == "admin3" && passwd == "test3"); } }; class PermissionsVerifierServer : public Ice::Application { public: virtual int run(int, char*[]) { Ice::ObjectAdapterPtr adapter = communicator()->createObjectAdapterWithEndpoints( "PermissionsVerifier", "tcp -p 12002"); adapter->add(new AdminPermissionsVerifierI, communicator()->stringToIdentity("AdminPermissionsVerifier")); adapter->activate(); communicator()->waitForShutdown(); return EXIT_SUCCESS; } }; int main(int argc, char* argv[]) { PermissionsVerifierServer app; return app.main(argc, argv); }