本文整理汇总了PHP中Channel::generate_certificate方法的典型用法代码示例。如果您正苦于以下问题:PHP Channel::generate_certificate方法的具体用法?PHP Channel::generate_certificate怎么用?PHP Channel::generate_certificate使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Channel
的用法示例。
在下文中一共展示了Channel::generate_certificate方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: Channel
if ($form->isValid) {
// make sure we are authorized to create the channel for this application
$mongodb = Renegade::database(RenegadeConstants::kDatabaseMongoDB, RenegadeConstants::kDatabaseApplications);
$redis = Renegade::database(RenegadeConstants::kDatabaseRedis, RenegadeConstants::kDatabaseCertificates);
$certificate = json_decode($redis->get($form->inputCertificate), true);
$data = $mongodb->findOne(array('_id' => $form->inputApplicationId));
if ($data['owner'] == $session->user && $certificate['owner'] == $session->user) {
// create the channel
$channel = new Channel($form->inputId);
$channel->setCertificate($form->inputCertificate);
$channel->setApplication($form->inputApplicationId);
$channel->setLabel($form->inputLabel);
$channel->setDescription($form->inputDescription);
$channel->setDefaultPermissions((int) $form->inputRead | (int) $form->inputWrite | (int) $form->inputDelete);
// channel owner gets all permissions by default
$certificate = $channel->generate_certificate(RenegadeConstants::kPermissionRead | RenegadeConstants::kPermissionWrite | RenegadeConstants::kPermissionDelete);
$metadata = $channel->generate_metadata();
$subscription = new Subscription();
$subscription->setCertificate($certificate['key']);
$subscription->setApplication($metadata['application']);
$subscription->setChannel($metadata['_id']);
$subscription->setMaster(true);
// place us in the application db context
$options = array('default' => Renegade::databaseForId($form->inputApplicationId));
$channels = Renegade::database(RenegadeConstants::kDatabaseMongoDB, RenegadeConstants::kDatabaseChannels, $options);
$subscriptions = Renegade::database(RenegadeConstants::kDatabaseMongoDB, RenegadeConstants::kDatabaseSubscriptions, $options);
$redis->set($certificate['key'], $certificate['value']);
$channels->insert($metadata);
$subscriptions->insert($subscription->toArray());
} else {
// error, something is potentially wrong, either from the user or the system
示例2: Channel
// the origin application.
/*
TODO
We need to add a subscription to the remote subscriptions db for the remote collection
We need to add the certificate for this channel
We need to add the channel to the local application's channels
Send an e-mail requesting extended permissions here if requested
*/
// we are giving the fully qualified channel id here
// so we will not need to set the application, it will be done for us
$channel = new Channel($remote_channel['_id']);
$channel->setCertificate($application['certificate']);
$channel->setLabel($remote_channel['label']);
$channel->setDescription($remote_channel['description']);
$channel->setDefaultPermissions($remote_channel['defaultPermissions']);
$certificate = $channel->generate_certificate($remote_channel['defaultPermissions']);
$metadata = $channel->generate_metadata();
$metadata['requests'] = $remote_channel['requests'];
$subscription = new Subscription();
$subscription->setCertificate($certificate['key']);
$subscription->setApplication($form->inputApplicationId);
$subscription->setChannel($metadata['_id']);
$subscription->setMaster(false);
$db_remote_options = array('default' => Renegade::databaseForId($remote_application));
$db_remote_subscriptions = Renegade::database(RenegadeConstants::kDatabaseMongoDB, RenegadeConstants::kDatabaseSubscriptions, $db_remote_options);
$certificates = Renegade::database(RenegadeConstants::kDatabaseRedis, RenegadeConstants::kDatabaseCertificates);
$db_remote_subscriptions->insert($subscription->toArray());
$db_channels->insert($metadata);
$certificates->set($certificate['key'], $certificate['value']);
// All Done
Renegade::redirect('/applications/' . $form->inputApplicationId . '/channels');