diff --git a/mod/profiles.php b/mod/profiles.php index e2cb0218..ea0b9afc 100644 --- a/mod/profiles.php +++ b/mod/profiles.php @@ -131,6 +131,46 @@ function profiles_content(&$a) { goaway($a->get_baseurl() . '/profiles'); } + if(($a->argc > 2) && ($a->argv[1] == 'clone')) { + + $r0 = q("SELECT `id` FROM `profile` WHERE `uid` = %d", + intval($_SESSION['uid'])); + $num_profiles = count($r0); + + $name = "Profile-" . ($num_profiles + 1); + $r1 = q("SELECT * FROM `profile` WHERE `uid` = %d AND `id` = %d LIMIT 1", + intval($_SESSION['uid']), + intval($a->argv[2]) + ); + if(! count($r1)) { + notice("Profile unavailable to clone." . EOL); + return; + } + unset($r1[0]['id']); + $r1[0]['is-default'] = 0; + $r1[0]['publish'] = 0; + $r1[0]['profile-name'] = dbesc($name); + + $r2 = q("INSERT INTO `profile` (`" + . implode("`, `", array_keys($r1[0])) + . "`) VALUES ('" + . implode("', '", array_values($r1[0])) + . "')" ); + + $r3 = q("SELECT `id` FROM `profile` WHERE `uid` = %d AND `profile-name` = '%s' LIMIT 1", + intval($_SESSION['uid']), + dbesc($name) + ); + $_SESSION['sysmsg'] .= "New profile created." . EOL; + if(count($r3) == 1) + goaway($a->get_baseurl() . '/profiles/' . $r3[0]['id']); + goaway($a->get_baseurl() . '/profiles'); + return; // NOTREACHED + } + + + + if(intval($a->argv[1])) { $r = q("SELECT * FROM `profile` WHERE `id` = %d AND `uid` = %d LIMIT 1", diff --git a/updates.sql b/updates.sql index 87d5e8b1..f74877d2 100644 --- a/updates.sql +++ b/updates.sql @@ -1,2 +1,19 @@ -ALTER TABLE `item` ADD `remote-id` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `contact-id` ; +|ALTER TABLE `item` ADD `remote-id` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `contact-id` ; + +ALTER TABLE `profile` ADD `politic` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `marital` , +ADD `religion` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `politic` ; + +ALTER TABLE `profile` ADD `sexual` CHAR( 255 ) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `marital` ; + + +ALTER TABLE `profile` ADD `music` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `about` , +ADD `book` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `music` , +ADD `tv` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `book` , +ADD `film` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `tv` , +ADD `interest` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `film` , +ADD `romance` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `interest` , +ADD `work` TEXT CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL AFTER `romance` ; +ALTER TABLE `profile` ADD `employer` CHAR( 255 ) NOT NULL AFTER `work` , +ADD `school` CHAR( 255 ) NOT NULL AFTER `employer` ; +ALTER TABLE `profile` ADD `summary` CHAR( 255 ) NOT NULL AFTER `about` ; diff --git a/view/profile_edit.tpl b/view/profile_edit.tpl index 687432f7..251fdae1 100644 --- a/view/profile_edit.tpl +++ b/view/profile_edit.tpl @@ -1,5 +1,7 @@