mourningdove/cgi-bin/DW/Worker/ContentImporter/LiveJournal/Friends.pm
2026-05-24 01:03:05 +00:00

98 lines
3.3 KiB
Perl

#!/usr/bin/perl
#
# DW::Worker::ContentImporter::LiveJournal
#
# Importer worker for LiveJournal-based sites friends and trust groups.
#
# Authors:
# Andrea Nall <anall@andreanall.com>
# Mark Smith <mark@dreamwidth.org>
#
# Copyright (c) 2009 by Dreamwidth Studios, LLC.
#
# This program is free software; you may redistribute it and/or modify it under
# the same terms as Perl itself. For a copy of the license, please reference
# 'perldoc perlartistic' or 'perldoc perlgpl'.
#
package DW::Worker::ContentImporter::LiveJournal::Friends;
use strict;
use base 'DW::Worker::ContentImporter::LiveJournal';
use Carp qw/ croak confess /;
sub work {
# VITALLY IMPORTANT THAT THIS IS CLEARED BETWEEN JOBS
%DW::Worker::ContentImporter::LiveJournal::MAPS = ();
my ( $class, $job ) = @_;
my $opts = $job->arg;
my $data = $class->import_data( $opts->{userid}, $opts->{import_data_id} );
return $class->decline($job) unless $class->enabled($data);
eval { try_work( $class, $job, $opts, $data ); };
if ( my $msg = $@ ) {
$msg =~ s/\r?\n/ /gs;
return $class->temp_fail( $data, 'lj_friends', $job, 'Failure running job: %s', $msg );
}
}
sub try_work {
my ( $class, $job, $opts, $data ) = @_;
# failure wrappers for convenience
my $fail = sub { return $class->fail( $data, 'lj_friends', $job, @_ ); };
my $ok = sub { return $class->ok( $data, 'lj_friends', $job ); };
my $temp_fail = sub { return $class->temp_fail( $data, 'lj_friends', $job, @_ ); };
# if this is a usejournal request, we have no friends (it's a comm or something) so
# bail very early
return $ok->() if $data->{usejournal};
# setup
my $u = LJ::load_userid( $data->{userid} )
or return $fail->( 'Unable to load target with id %d.', $data->{userid} );
$0 = sprintf( 'content-importer [friends: %s(%d)]', $u->user, $u->id );
my $r = $class->call_xmlrpc( $data, 'getfriends', { includegroups => 1 } );
my $xmlrpc_fail = 'XMLRPC failure: ' . ( $r ? $r->{faultString} : '[unknown]' );
return $temp_fail->($xmlrpc_fail) if !$r || $r->{fault};
my ( @friends, @feeds );
foreach my $friend ( @{ $r->{friends} || [] } ) {
# if we have no type, or type is identity, allow it
next if $friend->{type} && $friend->{type} ne 'identity';
# must be visible
next if $friend->{status};
# remap into a local OpenID userid and feed if we can
my ( $local_oid, $local_fid ) = $class->get_remapped_userids( $data, $friend->{username} );
push @friends,
{
userid => $local_oid,
groupmask => $class->remap_groupmask( $data, $friend->{groupmask} ),
}
if $local_oid && $local_oid != $data->{userid};
# We aren't doing feeds right now / maybe not ever, when we solve the
# authenticated feed reading problem. (which we're on track for)
# push @feeds, {
# fgcolor => $friend->{fgcolor},
# bgcolor => $friend->{bgcolor},
# userid => $local_fid,
# } if $local_fid;
}
DW::Worker::ContentImporter->merge_trust( $u, $opts, \@friends );
# DW::Worker::ContentImporter->merge_watch( $u, $opts, \@feeds );
return $ok->();
}
1;