SzkoleniaRiskoff/upgradescripts/2.20-2.30/upgrade.sql

1111 lines
41 KiB
Transact-SQL

--upgrade scripts from nopCommerce 2.20 to nopCommerce 2.30
--new locale resources
declare @resources xml
--a resource will be delete if its value is empty
set @resources='
<Language>
<LocaleResource Name="Admin.System.SystemInfo.ASPNETInfo.Hint">
<Value>ASP.NET info</Value>
</LocaleResource>
<LocaleResource Name="Admin.System.SystemInfo.IsFullTrust.Hint">
<Value>Is full trust level</Value>
</LocaleResource>
<LocaleResource Name="Admin.System.SystemInfo.NopVersion.Hint">
<Value>nopCommerce version</Value>
</LocaleResource>
<LocaleResource Name="Admin.System.SystemInfo.OperatingSystem.Hint">
<Value>Operating system</Value>
</LocaleResource>
<LocaleResource Name="Admin.System.SystemInfo.ServerLocalTime.Hint">
<Value>Server local time</Value>
</LocaleResource>
<LocaleResource Name="Admin.System.SystemInfo.ServerTimeZone.Hint">
<Value>Server time zone</Value>
</LocaleResource>
<LocaleResource Name="Admin.System.SystemInfo.UTCTime.Hint">
<Value>Greenwich mean time (GMT/UTC)</Value>
</LocaleResource>
<LocaleResource Name="Admin.Common.ConfigurationNotRequired">
<Value>Configuration is not required</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.CustomerUser.CheckUsernameAvailabilityEnabled">
<Value>Allow customers to check the availability of usernames</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.CustomerUser.CheckUsernameAvailabilityEnabled.Hint">
<Value>A value indicating whether customers are allowed to check the availability of usernames (when registering or changing in ''My Account'').</Value>
</LocaleResource>
<LocaleResource Name="Account.CheckUsernameAvailability.Available">
<Value>Username available</Value>
</LocaleResource>
<LocaleResource Name="Account.CheckUsernameAvailability.CurrentUsername">
<Value>Current username</Value>
</LocaleResource>
<LocaleResource Name="Account.CheckUsernameAvailability.NotAvailable">
<Value>Username not available</Value>
</LocaleResource>
<LocaleResource Name="Account.CheckUsernameAvailability.Button">
<Value>Check Availability</Value>
</LocaleResource>
<LocaleResource Name="Account.Login.WrongCredentials">
<Value>The credentials provided are incorrect</Value>
</LocaleResource>
<LocaleResource Name="Admin.Orders.Fields.BillingAddress.Hint">
<Value>Billing address info</Value>
</LocaleResource>
<LocaleResource Name="Admin.Orders.Fields.ShippingAddress.Hint">
<Value>Shipping address info</Value>
</LocaleResource>
<LocaleResource Name="Checkout.BillingToThisAddress">
<Value></Value>
</LocaleResource>
<LocaleResource Name="Checkout.BillToThisAddress">
<Value>Bill to this address</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Categories.Fields.AllowCustomersToSelectPageSize">
<Value>Allow customers to select page size</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Categories.Fields.AllowCustomersToSelectPageSize.Hint">
<Value>Whether customers are allowed to select the page size from a predefined list of options.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Categories.Fields.PageSizeOptions">
<Value>Page Size options (comma separated)</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Categories.Fields.PageSizeOptions.Hint">
<Value>Comma separated list of page size options (e.g. 10, 5, 15, 20). First option is the default page size if none are selected.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Manufacturers.Fields.AllowCustomersToSelectPageSize">
<Value>Allow customers to select page size</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Manufacturers.Fields.AllowCustomersToSelectPageSize.Hint">
<Value>Whether customers are allowed to select the page size from a predefined list of options.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Manufacturers.Fields.PageSizeOptions">
<Value>Page Size options (comma separated)</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Manufacturers.Fields.PageSizeOptions.Hint">
<Value>Comma separated list of page size options (e.g. 10, 5, 15, 20). First option is the default page size if none are selected.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.ProductsByTagAllowCustomersToSelectPageSize">
<Value>Allow customers to select ''Products by tag'' page size</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.ProductsByTagAllowCustomersToSelectPageSize.Hint">
<Value>Whether customers are allowed to select the ''Products by tag'' page size from a predefined list of options.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.ProductsByTagPageSizeOptions">
<Value>''Products by tag'' Page Size options (comma separated)</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.ProductsByTagPageSizeOptions.Hint">
<Value>Comma separated list of page size options (e.g. 10, 5, 15, 20). First option is the default page size if none are selected.</Value>
</LocaleResource>
<LocaleResource Name="Products.Tags.PageSize">
<Value>Display</Value>
</LocaleResource>
<LocaleResource Name="Products.Tags.PageSize.PerPage">
<Value>per page</Value>
</LocaleResource>
<LocaleResource Name="Categories.PageSize">
<Value>Display</Value>
</LocaleResource>
<LocaleResource Name="Categories.PageSize.PerPage">
<Value>per page</Value>
</LocaleResource>
<LocaleResource Name="Manufacturers.PageSize">
<Value>Display</Value>
</LocaleResource>
<LocaleResource Name="Manufacturers.PageSize.PerPage">
<Value>per page</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Countries.States.AddNew">
<Value>Add a new state/province</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Countries.States.EditStateDetails">
<Value>Edit state/province</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Shipping.Methods.Added">
<Value>The new shipping method has been added successfully.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Shipping.Methods.Updated">
<Value>The shipping method has been updated successfully.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Shipping.Methods.Deleted">
<Value>The shipping method has been deleted successfully.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Shipping.Methods.BackToList">
<Value>back to shipping method list</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Shipping.Methods.AddNew">
<Value>Add a new shipping method</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Shipping.Methods.EditMethodDetails">
<Value>Edit shipping method details</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.SpecialPrice">
<Value>Special price</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.SpecialPrice.Hint">
<Value>Set a special price for the product variant. New price will be valid between start and end dates. Leave empty to ignore field.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.SpecialPriceStartDateTimeUtc">
<Value>Special price start date</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.SpecialPriceStartDateTimeUtc.Hint">
<Value>The start date of the special price in Coordinated Universal Time (UTC).</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.SpecialPriceEndDateTimeUtc">
<Value>Special price end date</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.SpecialPriceEndDateTimeUtc.Hint">
<Value>The end date of the special price in Coordinated Universal Time (UTC).</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Plugins.Fields.Configure">
<Value>Configure</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Plugins.Misc.Configure">
<Value>Configure</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Plugins.Misc.BackToList">
<Value>back to plugin list</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.BulkEdit.List.SearchProductName">
<Value>Product name</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.BulkEdit.List.SearchProductName.Hint">
<Value>A product name.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.BulkEdit.List.SearchCategory">
<Value>Category</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.BulkEdit.List.SearchCategory.Hint">
<Value>Search by a specific category.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.BulkEdit.List.SearchManufacturer">
<Value>Manufacturer</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.BulkEdit.List.SearchManufacturer.Hint">
<Value>Search by a specific manufacturer.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.UseSSL">
<Value>Use SSL</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.UseSSL.Hint">
<Value>Click if your site is secured with SSL. Don''t tick if SSL certificate is not installed.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.SharedSSLUrl">
<Value>Shared SSL URL</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.SharedSSLUrl.Hint">
<Value>Enter your shared SSL URL (used when you have shared SSL certificate installed). For example, https://secure123.yourHosting.com/.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.NonSharedSSLUrl">
<Value>Non-secured URL</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.NonSharedSSLUrl.Hint">
<Value>Enter your non-secured URL (used when you have shared SSL certificate installed). Actually it is your site URL. For example, http://www.example.com/.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.AllowBackInStockSubscriptions">
<Value>Allow back in stock subscriptions</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.AllowBackInStockSubscriptions.Hint">
<Value>Allow customers to subscribe to a notification list for a product that has gone out of stock.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.CustomerUser.HideBackInStockSubscriptionsTab">
<Value>Hide ''Back in stock subscriptions'' tab</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.CustomerUser.HideBackInStockSubscriptionsTab.Hint">
<Value>Check to hide ''Back in stock subscriptions'' tab on ''My account'' page</Value>
</LocaleResource>
<LocaleResource Name="PageTitle.BackInStockSubscriptions">
<Value>Back in stock subscriptions</Value>
</LocaleResource>
<LocaleResource Name="Account.BackInStockSubscriptions">
<Value>Back in stock subscriptions</Value>
</LocaleResource>
<LocaleResource Name="Account.BackInStockSubscriptions.ProductColumn">
<Value>Product</Value>
</LocaleResource>
<LocaleResource Name="Account.BackInStockSubscriptions.DeleteSelected">
<Value>Delete selected</Value>
</LocaleResource>
<LocaleResource Name="Account.BackInStockSubscriptions.NoSubscriptions">
<Value>You are not currently subscribed to any Back In Stock notification lists</Value>
</LocaleResource>
<LocaleResource Name="Account.BackInStockSubscriptions.Description">
<Value>You will receive an e-mail when a particular product is back in stock.</Value>
</LocaleResource>
<LocaleResource Name="ForumSubscriptions.NoSubscriptions">
<Value>You are not currently subscribed to any forums</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.AlreadySubscribed">
<Value>You''re already subscribed for this product back in stock notification</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.PopupTitle">
<Value>Receive an email when this arrives in stock</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.NotAllowed">
<Value>Subscriptions are not allowed for this product</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.OnlyRegistered">
<Value>Only registered customers can used this feature</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.MaxSubscriptions">
<Value>You cannot subscribe. Maximum number of allowed subscriptions is {0}</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.Tooltip">
<Value>You''ll receive a one time e-mail when this product is available for ordering again. We will not send you any other e-mails or add you to our newsletter, you will only be e-mailed about this product!</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.Unsubscribe">
<Value>Unsubscribe</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.NotifyMe">
<Value>Notify me</Value>
</LocaleResource>
<LocaleResource Name="BackInStockSubscriptions.NotifyMeWhenAvailable">
<Value>Notify me when available</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.HidePricesForNonRegistered">
<Value></Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.HidePricesForNonRegistered.Hint">
<Value></Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.ShoppingCart.WishlistEnabled">
<Value></Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.ShoppingCart.WishlistEnabled.Hint">
<Value></Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.StoreClosedAllowForAdmins">
<Value>Allow an admin to view the closed store</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.StoreClosedAllowForAdmins.Hint">
<Value>Check to allow a user with admin access to view the store while it is set to closed.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Customers.Customers.List.SearchDateOfBirth">
<Value>Date of birth</Value>
</LocaleResource>
<LocaleResource Name="Admin.Customers.Customers.List.SearchDateOfBirth.Hint">
<Value>Filter by date of birth. Don''t select any value to load all records.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Customers.Customers.List.SearchDateOfBirth.Day">
<Value>Day</Value>
</LocaleResource>
<LocaleResource Name="Admin.Customers.Customers.List.SearchDateOfBirth.Month">
<Value>Month</Value>
</LocaleResource>
<LocaleResource Name="Account.Fields.Password.LengthValidation">
<Value>The password should have at least {0} characters.</Value>
</LocaleResource>
<LocaleResource Name="Account.ChangePassword.Fields.NewPassword.LengthValidation">
<Value>The password should have at least {0} characters.</Value>
</LocaleResource>
<LocaleResource Name="Account.PasswordRecovery.NewPassword.LengthValidation">
<Value>The password should have at least {0} characters.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.HideAdminMenuItemsBasedOnPermissions">
<Value>Hide admin menu items based on permissions</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.HideAdminMenuItemsBasedOnPermissions.Hint">
<Value>Hide admin menu items when access to them is denied according to access control list (permissions).</Value>
</LocaleResource>
<LocaleResource Name="Admin.Promotions.Discounts.Requirements.Saved">
<Value>Discount requirement saved</Value>
</LocaleResource>
<LocaleResource Name="ShoppingCart.DiscountCouponCode.CurrentCode">
<Value>Entered coupon code - {0}</Value>
</LocaleResource>
<LocaleResource Name="Products.Availability.Backordering">
<Value>Out of Stock - on backorder and will be dispatched once in stock.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.PdfLetterPageSizeEnabled">
<Value>Use Letter page size</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.GeneralCommon.PdfLetterPageSizeEnabled.Hint">
<Value>If checked, uses Letter page size for PDF documents. Uses A4 page size if unchecked.</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.GTIN">
<Value>GTIN (global trade item number)</Value>
</LocaleResource>
<LocaleResource Name="Admin.Catalog.Products.Variants.Fields.GTIN.Hint">
<Value>Enter global trade item number (GTIN). These identifiers include UPC (in North America), EAN (in Europe), JAN (in Japan), and ISBN (for books).</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.EmailAccounts.Fields.SendTestEmailTo.Hint">
<Value>Send test email to ensure that everything is properly configured.</Value>
</LocaleResource>
<LocaleResource Name="Checkout.NewAddress">
<Value>New Address</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.ShowGtin">
<Value>Show GTIN</Value>
</LocaleResource>
<LocaleResource Name="Admin.Configuration.Settings.Catalog.ShowGtin.Hint">
<Value>Check to show GTIN in public store.</Value>
</LocaleResource>
<LocaleResource Name="Products.GTIN">
<Value>GTIN</Value>
</LocaleResource>
</Language>
'
CREATE TABLE #LocaleStringResourceTmp
(
[ResourceName] [nvarchar](200) NOT NULL,
[ResourceValue] [nvarchar](max) NOT NULL
)
INSERT INTO #LocaleStringResourceTmp (ResourceName, ResourceValue)
SELECT nref.value('@Name', 'nvarchar(200)'), nref.value('Value[1]', 'nvarchar(MAX)')
FROM @resources.nodes('//Language/LocaleResource') AS R(nref)
--do it for each existing language
DECLARE @ExistingLanguageID int
DECLARE cur_existinglanguage CURSOR FOR
SELECT [ID]
FROM [Language]
OPEN cur_existinglanguage
FETCH NEXT FROM cur_existinglanguage INTO @ExistingLanguageID
WHILE @@FETCH_STATUS = 0
BEGIN
DECLARE @ResourceName nvarchar(200)
DECLARE @ResourceValue nvarchar(MAX)
DECLARE cur_localeresource CURSOR FOR
SELECT ResourceName, ResourceValue
FROM #LocaleStringResourceTmp
OPEN cur_localeresource
FETCH NEXT FROM cur_localeresource INTO @ResourceName, @ResourceValue
WHILE @@FETCH_STATUS = 0
BEGIN
IF (EXISTS (SELECT 1 FROM [LocaleStringResource] WHERE LanguageID=@ExistingLanguageID AND ResourceName=@ResourceName))
BEGIN
UPDATE [LocaleStringResource]
SET [ResourceValue]=@ResourceValue
WHERE LanguageID=@ExistingLanguageID AND ResourceName=@ResourceName
END
ELSE
BEGIN
INSERT INTO [LocaleStringResource]
(
[LanguageID],
[ResourceName],
[ResourceValue]
)
VALUES
(
@ExistingLanguageID,
@ResourceName,
@ResourceValue
)
END
IF (@ResourceValue is null or @ResourceValue = '')
BEGIN
DELETE [LocaleStringResource]
WHERE LanguageID=@ExistingLanguageID AND ResourceName=@ResourceName
END
FETCH NEXT FROM cur_localeresource INTO @ResourceName, @ResourceValue
END
CLOSE cur_localeresource
DEALLOCATE cur_localeresource
--fetch next language identifier
FETCH NEXT FROM cur_existinglanguage INTO @ExistingLanguageID
END
CLOSE cur_existinglanguage
DEALLOCATE cur_existinglanguage
DROP TABLE #LocaleStringResourceTmp
GO
--new setting
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'commonsettings.enablehttpcompression')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'commonsettings.enablehttpcompression', N'true')
END
GO
--customer can't be deleted until it has associated log records
IF EXISTS (SELECT 1
FROM sys.objects
WHERE name = 'Log_Customer'
AND parent_object_id = Object_id('Log')
AND Objectproperty(object_id,N'IsForeignKey') = 1)
ALTER TABLE dbo.[Log]
DROP CONSTRAINT Log_Customer
GO
ALTER TABLE [dbo].[Log] WITH CHECK ADD CONSTRAINT [Log_Customer] FOREIGN KEY([CustomerId])
REFERENCES [dbo].[Customer] ([Id])
ON DELETE CASCADE
GO
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'catalogsettings.defaultcategorypagesizeoptions')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'catalogsettings.defaultcategorypagesizeoptions', N'4, 2, 8, 12')
END
GO
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'catalogsettings.defaultmanufacturerpagesizeoptions')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'catalogsettings.defaultmanufacturerpagesizeoptions', N'4, 2, 8, 12')
END
GO
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'catalogsettings.productsbytagallowcustomerstoselectpagesize')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'catalogsettings.productsbytagallowcustomerstoselectpagesize', N'True')
END
GO
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'catalogsettings.productsbytagpagesizeoptions')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'catalogsettings.productsbytagpagesizeoptions', N'4, 2, 8, 12')
END
GO
--Add fields to Category
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[Category]') and NAME='AllowCustomersToSelectPageSize')
BEGIN
ALTER TABLE [dbo].[Category]
ADD [AllowCustomersToSelectPageSize] bit NULL
END
GO
UPDATE [dbo].[Category]
SET [AllowCustomersToSelectPageSize] = 1
WHERE [AllowCustomersToSelectPageSize] IS NULL
GO
ALTER TABLE [dbo].[Category] ALTER COLUMN [AllowCustomersToSelectPageSize] bit NOT NULL
GO
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[Category]') and NAME='PageSizeOptions')
BEGIN
ALTER TABLE [dbo].[Category]
ADD [PageSizeOptions] nvarchar(200) NULL
END
GO
UPDATE [dbo].[Category]
SET [PageSizeOptions] = N'4, 2, 8, 12'
WHERE [PageSizeOptions] IS NULL
GO
--Add fields to Manufacturer
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[Manufacturer]') and NAME='AllowCustomersToSelectPageSize')
BEGIN
ALTER TABLE [dbo].[Manufacturer]
ADD [AllowCustomersToSelectPageSize] bit NULL
END
GO
UPDATE [dbo].[Manufacturer]
SET [AllowCustomersToSelectPageSize] = 1
WHERE [AllowCustomersToSelectPageSize] IS NULL
GO
ALTER TABLE [dbo].[Manufacturer] ALTER COLUMN [AllowCustomersToSelectPageSize] bit NOT NULL
GO
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[Manufacturer]') and NAME='PageSizeOptions')
BEGIN
ALTER TABLE [dbo].[Manufacturer]
ADD [PageSizeOptions] nvarchar(200) NULL
END
GO
UPDATE [dbo].[Manufacturer]
SET [PageSizeOptions] = N'4, 2, 8, 12'
WHERE [PageSizeOptions] IS NULL
GO
--Add special price support
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[ProductVariant]') and NAME='SpecialPrice')
BEGIN
ALTER TABLE [dbo].[ProductVariant]
ADD [SpecialPrice] decimal(18, 4) NULL
END
GO
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[ProductVariant]') and NAME='SpecialPriceStartDateTimeUtc')
BEGIN
ALTER TABLE [dbo].[ProductVariant]
ADD [SpecialPriceStartDateTimeUtc] datetime NULL
END
GO
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[ProductVariant]') and NAME='SpecialPriceEndDateTimeUtc')
BEGIN
ALTER TABLE [dbo].[ProductVariant]
ADD [SpecialPriceEndDateTimeUtc] datetime NULL
END
GO
--Update stored procedure according to new special price properties
IF EXISTS (
SELECT *
FROM sys.objects
WHERE object_id = OBJECT_ID(N'[dbo].[ProductLoadAllPaged]') AND OBJECTPROPERTY(object_id,N'IsProcedure') = 1)
DROP PROCEDURE [dbo].[ProductLoadAllPaged]
GO
CREATE PROCEDURE [dbo].[ProductLoadAllPaged]
(
@CategoryId int = 0,
@ManufacturerId int = 0,
@ProductTagId int = 0,
@FeaturedProducts bit = null, --0 featured only , 1 not featured only, null - load all products
@PriceMin decimal(18, 4) = null,
@PriceMax decimal(18, 4) = null,
@Keywords nvarchar(MAX) = null,
@SearchDescriptions bit = 0,
@FilteredSpecs nvarchar(300) = null, --filter by attributes (comma-separated list). e.g. 14,15,16
@LanguageId int = 0,
@OrderBy int = 0, --0 position, 5 - Name, 10 - Price, 15 - creation date
@PageIndex int = 0,
@PageSize int = 2147483644,
@ShowHidden bit = 0,
@TotalRecords int = null OUTPUT
)
AS
BEGIN
--init
DECLARE @SearchKeywords bit
SET @SearchKeywords = 1
IF (@Keywords IS NULL OR @Keywords = N'')
SET @SearchKeywords = 0
SET @Keywords = isnull(@Keywords, '')
SET @Keywords = '%' + rtrim(ltrim(@Keywords)) + '%'
--filter by attributes
SET @FilteredSpecs = isnull(@FilteredSpecs, '')
CREATE TABLE #FilteredSpecs
(
SpecificationAttributeOptionId int not null
)
INSERT INTO #FilteredSpecs (SpecificationAttributeOptionId)
SELECT CAST(data as int) FROM dbo.[nop_splitstring_to_table](@FilteredSpecs, ',');
DECLARE @SpecAttributesCount int
SELECT @SpecAttributesCount = COUNT(1) FROM #FilteredSpecs
--paging
DECLARE @PageLowerBound int
DECLARE @PageUpperBound int
DECLARE @RowsToReturn int
SET @RowsToReturn = @PageSize * (@PageIndex + 1)
SET @PageLowerBound = @PageSize * @PageIndex
SET @PageUpperBound = @PageLowerBound + @PageSize + 1
CREATE TABLE #DisplayOrderTmp
(
[Id] int IDENTITY (1, 1) NOT NULL,
[ProductId] int NOT NULL
)
INSERT INTO #DisplayOrderTmp ([ProductId])
SELECT p.Id
FROM Product p with (NOLOCK)
LEFT OUTER JOIN Product_Category_Mapping pcm with (NOLOCK) ON p.Id=pcm.ProductId
LEFT OUTER JOIN Product_Manufacturer_Mapping pmm with (NOLOCK) ON p.Id=pmm.ProductId
LEFT OUTER JOIN Product_ProductTag_Mapping pptm with (NOLOCK) ON p.Id=pptm.Product_Id
LEFT OUTER JOIN ProductVariant pv with (NOLOCK) ON p.Id = pv.ProductId
--searching of the localized values
--comment the line below if you don't use it. It'll improve the performance
LEFT OUTER JOIN LocalizedProperty lp with (NOLOCK) ON p.Id = lp.EntityId AND lp.LanguageId = @LanguageId AND lp.LocaleKeyGroup = N'Product'
WHERE
(
(
@CategoryId IS NULL OR @CategoryId=0
OR (pcm.CategoryId=@CategoryId AND (@FeaturedProducts IS NULL OR pcm.IsFeaturedProduct=@FeaturedProducts))
)
AND (
@ManufacturerId IS NULL OR @ManufacturerId=0
OR (pmm.ManufacturerId=@ManufacturerId AND (@FeaturedProducts IS NULL OR pmm.IsFeaturedProduct=@FeaturedProducts))
)
AND (
@ProductTagId IS NULL OR @ProductTagId=0
OR pptm.ProductTag_Id=@ProductTagId
)
AND (
@ShowHidden = 1 OR p.Published = 1
)
AND
(
p.Deleted=0
)
AND
(
@ShowHidden = 1 OR pv.Published = 1
)
AND
(
@ShowHidden = 1 OR pv.Deleted = 0
)
AND (
--min price
(@PriceMin IS NULL OR @PriceMin=0)
OR
(
--special price (specified price and valid date range)
(pv.SpecialPrice IS NOT NULL AND (getutcdate() BETWEEN isnull(pv.SpecialPriceStartDateTimeUtc, '1/1/1900') AND isnull(pv.SpecialPriceEndDateTimeUtc, '1/1/2999')))
AND
(pv.SpecialPrice >= @PriceMin)
)
OR
(
--regular price (price isn't specified or date range isn't valid)
(pv.SpecialPrice IS NULL OR (getutcdate() NOT BETWEEN isnull(pv.SpecialPriceStartDateTimeUtc, '1/1/1900') AND isnull(pv.SpecialPriceEndDateTimeUtc, '1/1/2999')))
AND
(pv.Price >= @PriceMin)
)
)
AND (
--max price
(@PriceMax IS NULL OR @PriceMax=2147483644) -- max value
OR
(
--special price (specified price and valid date range)
(pv.SpecialPrice IS NOT NULL AND (getutcdate() BETWEEN isnull(pv.SpecialPriceStartDateTimeUtc, '1/1/1900') AND isnull(pv.SpecialPriceEndDateTimeUtc, '1/1/2999')))
AND
(pv.SpecialPrice <= @PriceMax)
)
OR
(
--regular price (price isn't specified or date range isn't valid)
(pv.SpecialPrice IS NULL OR (getutcdate() NOT BETWEEN isnull(pv.SpecialPriceStartDateTimeUtc, '1/1/1900') AND isnull(pv.SpecialPriceEndDateTimeUtc, '1/1/2999')))
AND
(pv.Price <= @PriceMax)
)
)
AND (
@SearchKeywords = 0 or
(
-- search standard content
patindex(@Keywords, p.name) > 0
or patindex(@Keywords, pv.name) > 0
or patindex(@Keywords, pv.sku) > 0
or (@SearchDescriptions = 1 and patindex(@Keywords, p.ShortDescription) > 0)
or (@SearchDescriptions = 1 and patindex(@Keywords, p.FullDescription) > 0)
or (@SearchDescriptions = 1 and patindex(@Keywords, pv.Description) > 0)
--searching of the localized values
--comment the lines below if you don't use it. It'll improve the performance
or (lp.LocaleKey = N'Name' and patindex(@Keywords, lp.LocaleValue) > 0)
or (@SearchDescriptions = 1 and lp.LocaleKey = N'ShortDescription' and patindex(@Keywords, lp.LocaleValue) > 0)
or (@SearchDescriptions = 1 and lp.LocaleKey = N'FullDescription' and patindex(@Keywords, lp.LocaleValue) > 0)
)
)
AND
(
@ShowHidden = 1
OR
(getutcdate() between isnull(pv.AvailableStartDateTimeUtc, '1/1/1900') and isnull(pv.AvailableEndDateTimeUtc, '1/1/2999'))
)
AND
(
--filter by specs
@SpecAttributesCount = 0
OR
(
NOT EXISTS(
SELECT 1
FROM #FilteredSpecs [fs]
WHERE [fs].SpecificationAttributeOptionId NOT IN (
SELECT psam.SpecificationAttributeOptionId
FROM dbo.Product_SpecificationAttribute_Mapping psam
WHERE psam.AllowFiltering = 1 AND psam.ProductId = p.Id
)
)
)
)
)
ORDER BY
CASE WHEN @OrderBy = 0 AND @CategoryId IS NOT NULL AND @CategoryId > 0
THEN pcm.DisplayOrder END ASC,
CASE WHEN @OrderBy = 0 AND @ManufacturerId IS NOT NULL AND @ManufacturerId > 0
THEN pmm.DisplayOrder END ASC,
CASE WHEN @OrderBy = 0
THEN p.[Name] END ASC,
CASE WHEN @OrderBy = 5
--THEN dbo.[nop_getnotnullnotempty](pl.[Name],p.[Name]) END ASC,
THEN p.[Name] END ASC,
CASE WHEN @OrderBy = 10
THEN pv.Price END ASC,
CASE WHEN @OrderBy = 15
THEN p.CreatedOnUtc END DESC
DROP TABLE #FilteredSpecs
CREATE TABLE #PageIndex
(
[IndexId] int IDENTITY (1, 1) NOT NULL,
[ProductId] int NOT NULL
)
INSERT INTO #PageIndex ([ProductId])
SELECT ProductId
FROM #DisplayOrderTmp with (NOLOCK)
GROUP BY ProductId
ORDER BY min([Id])
--total records
SET @TotalRecords = @@rowcount
SET ROWCOUNT @RowsToReturn
DROP TABLE #DisplayOrderTmp
--return products (returned properties should be synchronized with 'Product' entity)
SELECT
p.Id,
p.Name,
p.ShortDescription,
p.FullDescription,
p.AdminComment,
p.ProductTemplateId,
p.ShowOnHomePage,
p.MetaKeywords,
p.MetaDescription,
p.MetaTitle,
p.SeName,
p.AllowCustomerReviews,
p.ApprovedRatingSum,
p.NotApprovedRatingSum,
p.ApprovedTotalReviews,
p.NotApprovedTotalReviews,
p.Published,
p.Deleted,
p.CreatedOnUtc,
p.UpdatedOnUtc
FROM
#PageIndex [pi]
INNER JOIN Product p with (NOLOCK) on p.Id = [pi].[ProductId]
WHERE
[pi].IndexId > @PageLowerBound AND
[pi].IndexId < @PageUpperBound
ORDER BY
IndexId
SET ROWCOUNT 0
DROP TABLE #PageIndex
END
GO
--scheduled tasks are stored into database now
IF NOT EXISTS (SELECT 1 FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[ScheduleTask]') and OBJECTPROPERTY(object_id, N'IsUserTable') = 1)
BEGIN
CREATE TABLE [dbo].[ScheduleTask](
[Id] [int] IDENTITY(1,1) NOT NULL,
[Name] [nvarchar](MAX) NOT NULL,
[Seconds] [int] NOT NULL,
[Type] [nvarchar](MAX) NOT NULL,
[Enabled] [bit] NOT NULL,
[StopOnError] [bit] NOT NULL,
PRIMARY KEY CLUSTERED
(
[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
)
END
GO
IF NOT EXISTS (
SELECT 1
FROM [dbo].[ScheduleTask]
WHERE [Name] = N'Send emails')
BEGIN
INSERT [dbo].[ScheduleTask] ([Name], [Seconds], [Type], [Enabled], [StopOnError])
VALUES (N'Send emails', 60, N'Nop.Services.Messages.QueuedMessagesSendTask, Nop.Services', 1, 0)
END
GO
IF NOT EXISTS (
SELECT 1
FROM [dbo].[ScheduleTask]
WHERE [Name] = N'Delete guests')
BEGIN
INSERT [dbo].[ScheduleTask] ([Name], [Seconds], [Type], [Enabled], [StopOnError])
VALUES (N'Delete guests', 600, N'Nop.Services.Customers.DeleteGuestsTask, Nop.Services', 1, 0)
END
GO
IF NOT EXISTS (
SELECT 1
FROM [dbo].[ScheduleTask]
WHERE [Name] = N'Clear cache')
BEGIN
INSERT [dbo].[ScheduleTask] ([Name], [Seconds], [Type], [Enabled], [StopOnError])
VALUES (N'Clear cache', 600, N'Nop.Services.Caching.ClearCacheTask, Nop.Services', 0, 0)
END
GO
IF NOT EXISTS (
SELECT 1
FROM [dbo].[ScheduleTask]
WHERE [Name] = N'Update currency exchange rates')
BEGIN
INSERT [dbo].[ScheduleTask] ([Name], [Seconds], [Type], [Enabled], [StopOnError])
VALUES (N'Update currency exchange rates', 900, N'Nop.Services.Directory.UpdateExchangeRateTask, Nop.Services', 1, 0)
END
GO
--back in stock notification subscriptions
IF NOT EXISTS (SELECT 1 FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[BackInStockSubscription]') and OBJECTPROPERTY(object_id, N'IsUserTable') = 1)
BEGIN
CREATE TABLE [dbo].[BackInStockSubscription](
[Id] [int] IDENTITY(1,1) NOT NULL,
[ProductVariantId] [int] NOT NULL,
[CustomerId] [int] NOT NULL,
[CreatedOnUtc] [datetime] NOT NULL,
PRIMARY KEY CLUSTERED
(
[Id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON)
)
END
GO
IF EXISTS (SELECT 1
FROM sys.objects
WHERE name = 'BackInStockSubscription_ProductVariant'
AND parent_object_id = Object_id('BackInStockSubscription')
AND Objectproperty(object_id,N'IsForeignKey') = 1)
ALTER TABLE dbo.BackInStockSubscription
DROP CONSTRAINT BackInStockSubscription_ProductVariant
GO
ALTER TABLE [dbo].[BackInStockSubscription] WITH CHECK ADD CONSTRAINT [BackInStockSubscription_ProductVariant] FOREIGN KEY([ProductVariantId])
REFERENCES [dbo].[ProductVariant] ([Id])
ON DELETE CASCADE
GO
IF EXISTS (SELECT 1
FROM sys.objects
WHERE name = 'BackInStockSubscription_Customer'
AND parent_object_id = Object_id('BackInStockSubscription')
AND Objectproperty(object_id,N'IsForeignKey') = 1)
ALTER TABLE dbo.BackInStockSubscription
DROP CONSTRAINT BackInStockSubscription_Customer
GO
ALTER TABLE [dbo].[BackInStockSubscription] WITH CHECK ADD CONSTRAINT [BackInStockSubscription_Customer] FOREIGN KEY([CustomerId])
REFERENCES [dbo].[Customer] ([Id])
ON DELETE CASCADE
GO
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[ProductVariant]') and NAME='AllowBackInStockSubscriptions')
BEGIN
ALTER TABLE [dbo].[ProductVariant]
ADD [AllowBackInStockSubscriptions] bit NULL
END
GO
UPDATE [dbo].[ProductVariant]
SET [AllowBackInStockSubscriptions] = 0
WHERE [AllowBackInStockSubscriptions] IS NULL
GO
ALTER TABLE [dbo].[ProductVariant] ALTER COLUMN [AllowBackInStockSubscriptions] bit NOT NULL
GO
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'customersettings.hidebackinstocksubscriptionstab')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'customersettings.hidebackinstocksubscriptionstab', N'false')
END
GO
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'catalogsettings.maximumbackinstocksubscriptions')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'catalogsettings.maximumbackinstocksubscriptions', N'200')
END
GO
IF NOT EXISTS (
SELECT 1
FROM [dbo].[MessageTemplate]
WHERE [Name] = N'Customer.BackInStock')
BEGIN
INSERT [dbo].[MessageTemplate] ([Name], [BccEmailAddresses], [Subject], [Body], [IsActive], [EmailAccountId])
VALUES (N'Customer.BackInStock', null, N'%Store.Name%. Back in stock notification', N'<p><a href="%Store.URL%">%Store.Name%</a> <br /><br />Hello %Customer.FullName%, <br />Product "%BackInStockSubscription.ProductName%" is in stock.</p>', 1, 0)
END
GO
--permissions
UPDATE [PermissionRecord]
SET [Name] = N'Admin area. ' + [Name]
WHERE [Name] like N'Manage%'
GO
UPDATE [PermissionRecord]
SET [Name] = N'Plugins. Access Web Service'
WHERE [Name] = N'Access Web Service'
GO
--new 'permission records
IF NOT EXISTS (
SELECT 1
FROM [dbo].[PermissionRecord]
WHERE [SystemName] = N'DisplayPrices')
BEGIN
INSERT [dbo].[PermissionRecord] ([Name], [SystemName], [Category])
VALUES (N'Public store. Display Prices', N'DisplayPrices', N'PublicStore')
DECLARE @PermissionRecordId INT
SET @PermissionRecordId = @@IDENTITY
--add it to all roles
DECLARE @CustomerRoleId int
DECLARE cur_customerrole CURSOR FOR
SELECT Id
FROM [CustomerRole]
OPEN cur_customerrole
FETCH NEXT FROM cur_customerrole INTO @CustomerRoleId
WHILE @@FETCH_STATUS = 0
BEGIN
INSERT [dbo].[PermissionRecord_Role_Mapping] ([PermissionRecord_Id], [CustomerRole_Id])
VALUES (@PermissionRecordId, @CustomerRoleId)
FETCH NEXT FROM cur_customerrole INTO @CustomerRoleId
END
CLOSE cur_customerrole
DEALLOCATE cur_customerrole
END
GO
IF NOT EXISTS (
SELECT 1
FROM [dbo].[PermissionRecord]
WHERE [SystemName] = N'EnableWishlist')
BEGIN
INSERT [dbo].[PermissionRecord] ([Name], [SystemName], [Category])
VALUES (N'Public store. Enable wishlist', N'EnableWishlist', N'PublicStore')
DECLARE @PermissionRecordId INT
SET @PermissionRecordId = @@IDENTITY
--add it to all roles
DECLARE @CustomerRoleId int
DECLARE cur_customerrole CURSOR FOR
SELECT Id
FROM [CustomerRole]
OPEN cur_customerrole
FETCH NEXT FROM cur_customerrole INTO @CustomerRoleId
WHILE @@FETCH_STATUS = 0
BEGIN
INSERT [dbo].[PermissionRecord_Role_Mapping] ([PermissionRecord_Id], [CustomerRole_Id])
VALUES (@PermissionRecordId, @CustomerRoleId)
FETCH NEXT FROM cur_customerrole INTO @CustomerRoleId
END
CLOSE cur_customerrole
DEALLOCATE cur_customerrole
END
GO
IF NOT EXISTS (
SELECT 1
FROM [dbo].[PermissionRecord]
WHERE [SystemName] = N'EnableShoppingCart')
BEGIN
INSERT [dbo].[PermissionRecord] ([Name], [SystemName], [Category])
VALUES (N'Public store. Enable shopping cart', N'EnableShoppingCart', N'PublicStore')
DECLARE @PermissionRecordId INT
SET @PermissionRecordId = @@IDENTITY
--add it to all roles
DECLARE @CustomerRoleId int
DECLARE cur_customerrole CURSOR FOR
SELECT Id
FROM [CustomerRole]
OPEN cur_customerrole
FETCH NEXT FROM cur_customerrole INTO @CustomerRoleId
WHILE @@FETCH_STATUS = 0
BEGIN
INSERT [dbo].[PermissionRecord_Role_Mapping] ([PermissionRecord_Id], [CustomerRole_Id])
VALUES (@PermissionRecordId, @CustomerRoleId)
FETCH NEXT FROM cur_customerrole INTO @CustomerRoleId
END
CLOSE cur_customerrole
DEALLOCATE cur_customerrole
END
GO
--min password length
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'customersettings.passwordminlength')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'customersettings.passwordminlength', N'6')
END
GO
--new PayPal setting
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'paypalstandardpaymentsettings.enableipn')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'paypalstandardpaymentsettings.enableipn', N'true')
END
GO
--new setting indicating we should store last visited page URL for each customer
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'customersettings.storelastvisitedpage')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'customersettings.storelastvisitedpage', N'true')
END
GO
--new PDF setting enables PDF documents to use Letter page size if true, else A4 page size
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'pdfsettings.letterpagesizeenabled')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'pdfsettings.letterpagesizeenabled', N'false')
END
GO
--new GTIN property of product variants
IF NOT EXISTS (SELECT 1 FROM sys.columns WHERE object_id=object_id('[dbo].[ProductVariant]') and NAME='Gtin')
BEGIN
ALTER TABLE [dbo].[ProductVariant]
ADD [Gtin] nvarchar(400) NULL
END
GO
--new setting
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'ordersettings.onepagecheckoutdisplayordertotalsonpaymentinfotab')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'ordersettings.onepagecheckoutdisplayordertotalsonpaymentinfotab', N'false')
END
GO
--new setting (PDF font path)
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'pdfsettings.fontfilename')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'pdfsettings.fontfilename', N'FreeSerif.ttf')
END
GO
--new setting (display GTIN)
IF NOT EXISTS (SELECT 1 FROM [Setting] WHERE [name] = N'catalogsettings.showgtin')
BEGIN
INSERT [Setting] ([Name], [Value])
VALUES (N'catalogsettings.showgtin', N'false')
END
GO