+ echo "Failed feed fetch: {$response->getStatus()} for $feedurl\n";
+ return false;
+ }
+
+ echo "After:\n";
+ showProfileInfo($oprofile);
+ return true;
+}
+
+$ok = true;
+$validate = new Validate();
+if (have_option('all')) {
+ $oprofile = new Ostatus_profile();
+ $oprofile->find();
+ echo "Found $oprofile->N profiles:\n\n";
+ while ($oprofile->fetch()) {
+ try {
+ $ok = fixProfile($oprofile) && $ok;
+ } catch (Exception $e) {
+ $ok = false;
+ echo "Failed on URI=="._ve($oprofile->uri).": {$e->getMessage()}\n";
+ }
+ }
+} else if (have_option('suspicious')) {
+ $oprofile = new Ostatus_profile();
+ $oprofile->joinAdd(array('profile_id', 'profile:id'));
+ $oprofile->whereAdd("nickname rlike '^[0-9]$'");
+ $oprofile->find();
+ echo "Found $oprofile->N matching profiles:\n\n";
+ while ($oprofile->fetch()) {
+ try {
+ $ok = fixProfile($oprofile) && $ok;
+ } catch (Exception $e) {
+ $ok = false;
+ echo "Failed on URI=="._ve($oprofile->uri).": {$e->getMessage()}\n";
+ }
+ }
+} else if (!empty($args[0]) && $validate->uri($args[0])) {
+ $uri = $args[0];
+ $oprofile = Ostatus_profile::getKV('uri', $uri);
+
+ if (!$oprofile instanceof Ostatus_profile) {
+ print "No OStatus remote profile known for URI $uri\n";
+ return false;
+ }
+
+ try {
+ $ok = fixProfile($oprofile) && $ok;
+ } catch (Exception $e) {
+ $ok = false;
+ echo "Failed on URI=="._ve($oprofile->uri).": {$e->getMessage()}\n";