forked from GNUsocial/gnu-social
Fixes for Yammer groups import: pulling explicit list, fixed avatar fetch
This commit is contained in:
parent
7a381f2533
commit
acd7613933
@ -100,7 +100,7 @@ class SN_YammerClient
|
||||
*
|
||||
* @throws Exception for HTTP error or bad JSON return
|
||||
*/
|
||||
protected function api($method, $params=array())
|
||||
public function api($method, $params=array())
|
||||
{
|
||||
$body = $this->fetchApi("api/v1/$method.json", $params);
|
||||
$data = json_decode($body, true);
|
||||
@ -217,4 +217,20 @@ class SN_YammerClient
|
||||
{
|
||||
return $this->api('users', $params);
|
||||
}
|
||||
|
||||
/**
|
||||
* High-level API hit: fetch all groups in the network (up to 20 at a time).
|
||||
* Return data is the full JSON array returned, listing user items.
|
||||
*
|
||||
* The matching messages themselves will be in the 'users' item within.
|
||||
*
|
||||
* @param array $options optional set of additional params for the request.
|
||||
* @return array of JSON-sourced user data arrays
|
||||
*
|
||||
* @throws Exception on low-level or HTTP error
|
||||
*/
|
||||
public function groups($params=array())
|
||||
{
|
||||
return $this->api('groups', $params);
|
||||
}
|
||||
}
|
||||
|
@ -21,18 +21,18 @@ foreach ($data as $item) {
|
||||
echo "Imported Yammer user " . $item['id'] . " as $user->nickname ($user->id)\n";
|
||||
}
|
||||
|
||||
$data = $yam->messages();
|
||||
// @fixme pull the full group list; this'll be a partial list with less data
|
||||
// and only for groups referenced in the message set.
|
||||
foreach ($data['references'] as $item) {
|
||||
if ($item['type'] == 'group') {
|
||||
// Groups!
|
||||
// @fixme follow paging -- we only get 20 at a time
|
||||
$data = $yam->groups();
|
||||
foreach ($data as $item) {
|
||||
$group = $imp->importGroup($item);
|
||||
echo "Imported Yammer group " . $item['id'] . " as $group->nickname ($group->id)\n";
|
||||
}
|
||||
}
|
||||
|
||||
// Messages!
|
||||
// Process in reverse chron order...
|
||||
// @fixme follow paging -- we only get 20 at a time, and start at the most recent!
|
||||
$data = $yam->messages();
|
||||
$messages = $data['messages'];
|
||||
$messages = array_reverse($messages);
|
||||
foreach ($messages as $item) {
|
||||
|
@ -51,10 +51,12 @@ class YammerImporter
|
||||
} else {
|
||||
$user = User::register($data['options']);
|
||||
$profile = $user->getProfile();
|
||||
if ($data['avatar']) {
|
||||
try {
|
||||
$this->saveAvatar($data['avatar'], $profile);
|
||||
} catch (Exception $e) {
|
||||
common_log(LOG_ERROR, "Error importing Yammer avatar: " . $e->getMessage());
|
||||
common_log(LOG_ERR, "Error importing Yammer avatar: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
$this->recordImportedUser($data['orig_id'], $profile->id);
|
||||
return $profile;
|
||||
@ -76,10 +78,12 @@ class YammerImporter
|
||||
return User_group::staticGet('id', $groupId);
|
||||
} else {
|
||||
$group = User_group::register($data['options']);
|
||||
if ($data['avatar']) {
|
||||
try {
|
||||
$this->saveAvatar($data['avatar'], $group);
|
||||
} catch (Exception $e) {
|
||||
common_log(LOG_ERROR, "Error importing Yammer avatar: " . $e->getMessage());
|
||||
common_log(LOG_ERR, "Error importing Yammer avatar: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
$this->recordImportedGroup($data['orig_id'], $group->id);
|
||||
return $group;
|
||||
@ -111,7 +115,7 @@ class YammerImporter
|
||||
$content .= ' ' . $upload->shortUrl();
|
||||
$uploads[] = $upload;
|
||||
} catch (Exception $e) {
|
||||
common_log(LOG_ERROR, "Error importing Yammer attachment: " . $e->getMessage());
|
||||
common_log(LOG_ERR, "Error importing Yammer attachment: " . $e->getMessage());
|
||||
}
|
||||
}
|
||||
|
||||
@ -254,7 +258,8 @@ class YammerImporter
|
||||
$options['local'] = true;
|
||||
return array('orig_id' => $origId,
|
||||
'orig_url' => $origUrl,
|
||||
'options' => $options);
|
||||
'options' => $options,
|
||||
'avatar' => $avatar);
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
Reference in New Issue
Block a user