Conflicts: docs/gotcha.txt docs/previousVersion.sql docs/templates.txt lib/WebGUI.pm lib/WebGUI/Asset.pm lib/WebGUI/Asset/Event.pm lib/WebGUI/Asset/File.pm lib/WebGUI/Asset/MapPoint.pm lib/WebGUI/Asset/RichEdit.pm lib/WebGUI/Asset/Sku/Product.pm lib/WebGUI/Asset/Snippet.pm lib/WebGUI/Asset/Story.pm lib/WebGUI/Asset/Template.pm lib/WebGUI/Asset/Template/TemplateToolkit.pm lib/WebGUI/Asset/Wobject/Calendar.pm lib/WebGUI/Asset/Wobject/Carousel.pm lib/WebGUI/Asset/Wobject/Collaboration.pm lib/WebGUI/Asset/Wobject/Dashboard.pm lib/WebGUI/Asset/Wobject/DataForm.pm lib/WebGUI/Asset/Wobject/Folder.pm lib/WebGUI/Asset/Wobject/Map.pm lib/WebGUI/Asset/Wobject/Search.pm lib/WebGUI/Asset/Wobject/Shelf.pm lib/WebGUI/Asset/Wobject/StockData.pm lib/WebGUI/Asset/Wobject/StoryTopic.pm lib/WebGUI/Asset/Wobject/SyndicatedContent.pm lib/WebGUI/Asset/Wobject/Thingy.pm lib/WebGUI/Asset/Wobject/WeatherData.pm lib/WebGUI/AssetClipboard.pm lib/WebGUI/AssetCollateral/DataForm/Entry.pm lib/WebGUI/AssetExportHtml.pm lib/WebGUI/AssetLineage.pm lib/WebGUI/AssetMetaData.pm lib/WebGUI/AssetTrash.pm lib/WebGUI/AssetVersioning.pm lib/WebGUI/Auth.pm lib/WebGUI/Cache/CHI.pm lib/WebGUI/Content/AssetManager.pm lib/WebGUI/Fork/ProgressBar.pm lib/WebGUI/Form/JsonTable.pm lib/WebGUI/Form/TimeField.pm lib/WebGUI/Form/Zipcode.pm lib/WebGUI/Group.pm lib/WebGUI/International.pm lib/WebGUI/Macro/AssetProxy.pm lib/WebGUI/Macro/FileUrl.pm lib/WebGUI/Operation/SSO.pm lib/WebGUI/Operation/User.pm lib/WebGUI/Role/Asset/Subscribable.pm lib/WebGUI/Shop/Cart.pm lib/WebGUI/Shop/Transaction.pm lib/WebGUI/Shop/TransactionItem.pm lib/WebGUI/Test.pm lib/WebGUI/URL/Content.pm lib/WebGUI/URL/Uploads.pm lib/WebGUI/User.pm lib/WebGUI/Workflow/Activity/ExtendCalendarRecurrences.pm lib/WebGUI/Workflow/Activity/SendNewsletters.pm lib/WebGUI/i18n/English/Asset.pm lib/WebGUI/i18n/English/WebGUI.pm sbin/installClass.pl sbin/rebuildLineage.pl sbin/search.pl sbin/testEnvironment.pl t/Asset/Asset.t t/Asset/AssetClipboard.t t/Asset/AssetLineage.t t/Asset/AssetMetaData.t t/Asset/Event.t t/Asset/File.t t/Asset/File/Image.t t/Asset/Post/notification.t t/Asset/Sku.t t/Asset/Story.t t/Asset/Template.t t/Asset/Wobject/Collaboration/templateVariables.t t/Asset/Wobject/Collaboration/unarchiveAll.t t/Asset/Wobject/Shelf.t t/Auth.t t/Macro/EditableToggle.t t/Macro/FilePump.t t/Shop/Cart.t t/Shop/Transaction.t t/Storage.t t/User.t t/Workflow.t
40 lines
1.6 KiB
Perl
40 lines
1.6 KiB
Perl
|
|
use WebGUI::Upgrade::Script;
|
|
|
|
use WebGUI::Pluggable;
|
|
use WebGUI::ProfileField;
|
|
|
|
start_step "Move core profile fields to users table...";
|
|
|
|
my @fields = qw( ableToBeFriend alias allowPrivateMessages avatar cellPhone dateFormat
|
|
email firstDayOfWeek firstName language lastName publicProfile receiveInboxEmailNotifications
|
|
receiveInboxSmsNotifications showMessageOnLoginSeen showOnline signature timeFormat timeZone
|
|
toolbar uiLevel versionTagMode );
|
|
|
|
# Create the new columns
|
|
for my $fieldName ( @fields ) {
|
|
my $field = WebGUI::ProfileField->new( session, $fieldName );
|
|
my $fieldClass = $field->getFormControlClass;
|
|
eval { WebGUI::Pluggable::load( $fieldClass ) };
|
|
my $dbType = $fieldClass->getDatabaseFieldType;
|
|
session->db->write( sprintf q{ ALTER TABLE users ADD COLUMN `%s` %s }, $fieldName, $dbType );
|
|
}
|
|
|
|
# Update the table
|
|
my @pairs = map { q{`users`.`} . $_ . q{`=`userProfileData`.`} . $_ . q{`} } @fields;
|
|
session->db->write(
|
|
q{ UPDATE `users`,`userProfileData` SET } . join( ", ", @pairs ) .
|
|
q{ WHERE `users`.`userId` = `userProfileData`.`userId` }
|
|
);
|
|
|
|
# Drop the old tables
|
|
for my $fieldName ( @fields ) {
|
|
session->db->write( qq{ ALTER TABLE userProfileData DROP COLUMN `$fieldName` } );
|
|
}
|
|
|
|
# Move not-profile fields in userProfileData
|
|
session->db->write( qq{ ALTER TABLE users ADD privacyFields LONGTEXT } );
|
|
session->db->write( qq{ UPDATE users,userProfileData SET users.privacyFields = userProfileData.wg_privacySettings } );
|
|
session->db->write( qq{ ALTER TABLE userProfileData DROP COLUMN wg_privacySettings } );
|
|
|
|
done;
|