本文整理汇总了C++中OperationContext::getUserInfo方法的典型用法代码示例。如果您正苦于以下问题:C++ OperationContext::getUserInfo方法的具体用法?C++ OperationContext::getUserInfo怎么用?C++ OperationContext::getUserInfo使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类OperationContext
的用法示例。
在下文中一共展示了OperationContext::getUserInfo方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: lns
bool
SimpleAuthorizer2::checkAccess(const String& opType, const String& ns,
const ServiceEnvironmentIFCRef& env, OperationContext& context)
{
OW_ASSERT(opType == ACCESS_READ || opType == ACCESS_WRITE
|| opType == ACCESS_READWRITE);
UserInfo userInfo = context.getUserInfo();
if (userInfo.getInternal())
{
return true;
}
CIMOMHandleIFCRef lch = env->getCIMOMHandle(context,
ServiceEnvironmentIFC::E_USE_PROVIDERS);
LoggerRef lgr = env->getLogger(COMPONENT_NAME);
if (!userInfo.getUserName().empty())
{
String superUser =
env->getConfigItem(ConfigOpts::ACL_SUPERUSER_opt);
if (superUser.equalsIgnoreCase(userInfo.getUserName()))
{
OW_LOG_DEBUG(lgr, "User is SuperUser: checkAccess returning.");
return true;
}
}
String lns(ns);
while (lns.startsWith('/'))
{
lns = lns.substring(1);
}
lns.toLowerCase();
for (;;)
{
if (!userInfo.getUserName().empty())
{
try
{
CIMClass cc = lch->getClass("root/security",
"OpenWBEM_UserACL", E_NOT_LOCAL_ONLY, E_INCLUDE_QUALIFIERS,
E_INCLUDE_CLASS_ORIGIN, NULL);
}
catch(CIMException&)
{
OW_LOG_DEBUG(lgr, "OpenWBEM_UserACL class non-existent in"
" /root/security. ACLs disabled");
return true;
}
CIMObjectPath cop("OpenWBEM_UserACL");
cop.setKeyValue("username", CIMValue(userInfo.getUserName()));
cop.setKeyValue("nspace", CIMValue(lns));
CIMInstance ci(CIMNULL);
try
{
ci = lch->getInstance("root/security", cop,
E_NOT_LOCAL_ONLY, E_INCLUDE_QUALIFIERS,
E_INCLUDE_CLASS_ORIGIN, NULL);
}
catch(const CIMException&)
{
ci.setNull();
}
if (ci)
{
String capability;
CIMProperty capabilityProp = ci.getProperty("capability");
if (capabilityProp)
{
CIMValue cv = capabilityProp.getValue();
if (cv)
{
capability = cv.toString();
}
}
capability.toLowerCase();
if (opType.length() == 1)
{
if (capability.indexOf(opType) == String::npos)
{
// Access to namespace denied for user
OW_THROWCIM(CIMException::ACCESS_DENIED);
}
}
else
{
if (!capability.equals("rw") && !capability.equals("wr"))
{
// Access to namespace denied for user
OW_THROWCIM(CIMException::ACCESS_DENIED);
}
}
// Access to namespace granted for user
return true;
}
//.........这里部分代码省略.........