From fcc0025a074fb33d971e7e62016b974bed35e031 Mon Sep 17 00:00:00 2001 From: Shannon Date: Tue, 15 Jan 2019 13:16:08 +1100 Subject: [PATCH] Fixes #87 --- appveyor.build.yml | 2 +- appveyor.yml | 2 +- src/SolutionInfo.cs | 6 +- .../UmbracoIdentityAccountController.cs | 94 +- .../ExternalLoginConfirmationViewModel.cs | 12 - .../ExternalLoginFailure.cshtml | 25 + .../bin/EN/System.Data.SqlServerCe.xml | 2892 ----------------- .../System.Data.SqlServerCe.Entity.dll | Bin 240352 -> 0 bytes 8 files changed, 65 insertions(+), 2968 deletions(-) delete mode 100644 src/UmbracoIdentity.Web/App_Code/Models/UmbracoIdentity/ExternalLoginConfirmationViewModel.cs delete mode 100644 src/UmbracoIdentity.Web/bin/EN/System.Data.SqlServerCe.xml delete mode 100644 src/UmbracoIdentity.Web/bin/System.Data.SqlServerCe.Entity/System.Data.SqlServerCe.Entity.dll diff --git a/appveyor.build.yml b/appveyor.build.yml index 8109243..5e26f99 100644 --- a/appveyor.build.yml +++ b/appveyor.build.yml @@ -1,4 +1,4 @@ -version: 6.0.0-build.{build} +version: 6.1.0-build.{build} skip_tags: true image: Visual Studio 2017 build_script: diff --git a/appveyor.yml b/appveyor.yml index eda6d23..4982d05 100644 --- a/appveyor.yml +++ b/appveyor.yml @@ -1,4 +1,4 @@ -version: 6.0.1 +version: 6.1.0 skip_non_tags: true image: Visual Studio 2017 build_script: diff --git a/src/SolutionInfo.cs b/src/SolutionInfo.cs index 87a90cc..681f681 100644 --- a/src/SolutionInfo.cs +++ b/src/SolutionInfo.cs @@ -7,6 +7,6 @@ [assembly: AssemblyCulture("")] -[assembly: AssemblyVersion("6.0.1")] -[assembly: AssemblyFileVersion("6.0.1")] -[assembly: AssemblyInformationalVersion("6.0.1")] +[assembly: AssemblyVersion("6.1.0")] +[assembly: AssemblyFileVersion("6.1.0")] +[assembly: AssemblyInformationalVersion("6.1.0")] diff --git a/src/UmbracoIdentity.Web/App_Code/Controllers/UmbracoIdentityAccountController.cs b/src/UmbracoIdentity.Web/App_Code/Controllers/UmbracoIdentityAccountController.cs index 1c08ed6..2cc0acf 100644 --- a/src/UmbracoIdentity.Web/App_Code/Controllers/UmbracoIdentityAccountController.cs +++ b/src/UmbracoIdentity.Web/App_Code/Controllers/UmbracoIdentityAccountController.cs @@ -9,13 +9,10 @@ using Microsoft.Owin.Security; using UmbracoIdentity.Web.Models.UmbracoIdentity; using Umbraco.Web; -using UmbracoIdentity.Web; using Umbraco.Core; using Umbraco.Web.Models; using Umbraco.Web.Mvc; -using UmbracoIdentity; using UmbracoIdentity.Models; -using IdentityExtensions = UmbracoIdentity.IdentityExtensions; namespace UmbracoIdentity.Web.Controllers { @@ -105,67 +102,46 @@ public async Task ExternalLoginCallback(string returnUrl) await SignInAsync(user, isPersistent: false); return RedirectToLocal(returnUrl); } - else - { - // If the user does not have an account, then prompt the user to create an account - ViewBag.ReturnUrl = returnUrl; - ViewBag.LoginProvider = loginInfo.Login.LoginProvider; - return View("ExternalLoginConfirmation", new ExternalLoginConfirmationViewModel { Email = loginInfo.Email }); - } - } - - [HttpPost] - [AllowAnonymous] - [ValidateAntiForgeryToken] - public async Task ExternalLoginConfirmation(ExternalLoginConfirmationViewModel model, string returnUrl) - { - if (User.Identity.IsAuthenticated) + if (loginInfo.Email.IsNullOrWhiteSpace()) { - //go home, already authenticated - return RedirectToLocal(returnUrl); + ViewBag.Description = "No email address found in the claims, ensure your OAuth provider is configured to return the Email address"; + return View("ExternalLoginFailure"); } - if (ModelState.IsValid) - { - // Get the information about the user from the external login provider - var info = await OwinContext.Authentication.GetExternalLoginInfoAsync(); - if (info == null) - { - return View("ExternalLoginFailure"); - } + // If the user does not have an account, then create one - var user = new UmbracoApplicationMember() - { - Name = info.ExternalIdentity.Name, - UserName = model.Email, - Email = model.Email - }; + user = new UmbracoApplicationMember() + { + Name = loginInfo.ExternalIdentity.Name, + UserName = loginInfo.Email, + Email = loginInfo.Email + }; - var result = await UserManager.CreateAsync(user); + var result = await UserManager.CreateAsync(user); + if (result.Succeeded) + { + result = await UserManager.AddLoginAsync(user.Id, loginInfo.Login); if (result.Succeeded) { - result = await UserManager.AddLoginAsync(user.Id, info.Login); - if (result.Succeeded) - { - await SignInAsync(user, isPersistent: false); + await SignInAsync(user, isPersistent: false); - // For more information on how to enable account confirmation and password reset please visit http://go.microsoft.com/fwlink/?LinkID=320771 - // Send an email with this link - // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id); - // var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme); - // SendEmail(user.Email, callbackUrl, "Confirm your account", "Please confirm your account by clicking this link"); + // For more information on how to enable account confirmation and password reset please visit http://go.microsoft.com/fwlink/?LinkID=320771 + // Send an email with this link + // string code = await UserManager.GenerateEmailConfirmationTokenAsync(user.Id); + // var callbackUrl = Url.Action("ConfirmEmail", "Account", new { userId = user.Id, code = code }, protocol: Request.Url.Scheme); + // SendEmail(user.Email, callbackUrl, "Confirm your account", "Please confirm your account by clicking this link"); - return RedirectToLocal(returnUrl); - } + return RedirectToLocal(returnUrl); } - AddModelErrors(result); } - ViewBag.ReturnUrl = returnUrl; - return View(model); + //something went wrong + AddModelErrors(result); + return View("ExternalLoginFailure"); } + [HttpPost] [ValidateAntiForgeryToken] public ActionResult LinkLogin(string provider, string returnUrl = null) @@ -190,7 +166,7 @@ public async Task LinkLoginCallback(string returnUrl) TempData["LinkLoginError"] = new[] { "An error occurred, could not get external login info" }; return RedirectToLocal(returnUrl); } - var result = await UserManager.AddLoginAsync(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity), loginInfo.Login); + var result = await UserManager.AddLoginAsync(User.Identity.GetUserId(), loginInfo.Login); if (result.Succeeded) { return RedirectToLocal(returnUrl); @@ -205,12 +181,12 @@ public async Task LinkLoginCallback(string returnUrl) public async Task Disassociate(string loginProvider, string providerKey) { var result = await UserManager.RemoveLoginAsync( - UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity), + User.Identity.GetUserId(), new UserLoginInfo(loginProvider, providerKey)); if (result.Succeeded) { - var user = await UserManager.FindByIdAsync(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity)); + var user = await UserManager.FindByIdAsync(User.Identity.GetUserId()); await SignInAsync(user, isPersistent: false); return RedirectToCurrentUmbracoPage(); } @@ -230,7 +206,7 @@ public ActionResult ExternalLoginFailure() [ChildActionOnly] public ActionResult RemoveAccountList() { - var linkedAccounts = UserManager.GetLogins(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity)); + var linkedAccounts = UserManager.GetLogins(User.Identity.GetUserId()); ViewBag.ShowRemoveButton = HasPassword() || linkedAccounts.Count > 1; return PartialView(linkedAccounts); } @@ -243,7 +219,7 @@ public async Task ToggleRole(string roleName) { if (string.IsNullOrWhiteSpace(roleName)) throw new ArgumentNullException("role cannot be null"); - var user = await UserManager.FindByIdAsync(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity)); + var user = await UserManager.FindByIdAsync(User.Identity.GetUserId()); if (user != null) { var found = user.Roles.FirstOrDefault(x => x.RoleName == roleName); @@ -276,7 +252,7 @@ public async Task ToggleRole(string roleName) [ChildActionOnly] public async Task ShowRoles() { - var user = await UserManager.FindByIdAsync(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity)); + var user = await UserManager.FindByIdAsync(User.Identity.GetUserId()); var model = new RoleManagementModel(); @@ -314,10 +290,10 @@ public async Task ManagePassword([Bind(Prefix = "managePasswordMod { if (ModelState.IsValid) { - IdentityResult result = await UserManager.ChangePasswordAsync(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity), model.OldPassword, model.NewPassword); + IdentityResult result = await UserManager.ChangePasswordAsync(User.Identity.GetUserId(), model.OldPassword, model.NewPassword); if (result.Succeeded) { - var user = await UserManager.FindByIdAsync(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity)); + var user = await UserManager.FindByIdAsync(User.Identity.GetUserId()); await SignInAsync(user, isPersistent: false); TempData["ChangePasswordSuccess"] = true; return RedirectToCurrentUmbracoPage(); @@ -339,7 +315,7 @@ public async Task ManagePassword([Bind(Prefix = "managePasswordMod if (ModelState.IsValid) { - IdentityResult result = await UserManager.AddPasswordAsync(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity), model.NewPassword); + IdentityResult result = await UserManager.AddPasswordAsync(User.Identity.GetUserId(), model.NewPassword); if (result.Succeeded) { TempData["ChangePasswordSuccess"] = true; @@ -480,7 +456,7 @@ private void AddModelErrors(IdentityResult result, string prefix = "") private bool HasPassword() { - var user = UserManager.FindById(UmbracoIdentity.IdentityExtensions.GetUserId(User.Identity)); + var user = UserManager.FindById(User.Identity.GetUserId()); if (user != null) { return !user.PasswordHash.IsNullOrWhiteSpace(); diff --git a/src/UmbracoIdentity.Web/App_Code/Models/UmbracoIdentity/ExternalLoginConfirmationViewModel.cs b/src/UmbracoIdentity.Web/App_Code/Models/UmbracoIdentity/ExternalLoginConfirmationViewModel.cs deleted file mode 100644 index 5928282..0000000 --- a/src/UmbracoIdentity.Web/App_Code/Models/UmbracoIdentity/ExternalLoginConfirmationViewModel.cs +++ /dev/null @@ -1,12 +0,0 @@ -using System.ComponentModel.DataAnnotations; - -namespace UmbracoIdentity.Web.Models.UmbracoIdentity -{ - public class ExternalLoginConfirmationViewModel - { - [Required] - [EmailAddress] - [Display(Name = "Email")] - public string Email { get; set; } - } -} \ No newline at end of file diff --git a/src/UmbracoIdentity.Web/Views/UmbracoIdentityAccount/ExternalLoginFailure.cshtml b/src/UmbracoIdentity.Web/Views/UmbracoIdentityAccount/ExternalLoginFailure.cshtml index 9684615..bf01763 100644 --- a/src/UmbracoIdentity.Web/Views/UmbracoIdentityAccount/ExternalLoginFailure.cshtml +++ b/src/UmbracoIdentity.Web/Views/UmbracoIdentityAccount/ExternalLoginFailure.cshtml @@ -4,3 +4,28 @@

@ViewBag.Title.

Unsuccessful login with service.

+ +@if (ViewBag.Description != null) +{ +

@ViewBag.Description

+} + +@if (ViewData.ModelState.Count > 0) +{ +
    + @foreach (var state in ViewData.ModelState) + { +
  • + @state.Key : +
      + @foreach (var error in state.Value.Errors) + { +
    • + @error.ErrorMessage +
    • + } +
    +
  • + } +
+} diff --git a/src/UmbracoIdentity.Web/bin/EN/System.Data.SqlServerCe.xml b/src/UmbracoIdentity.Web/bin/EN/System.Data.SqlServerCe.xml deleted file mode 100644 index 6d5416c..0000000 --- a/src/UmbracoIdentity.Web/bin/EN/System.Data.SqlServerCe.xml +++ /dev/null @@ -1,2892 +0,0 @@ - - - - System.Data.SqlServerCe - - - - Determines whether the subscription will be added to an existing database or whether a new database will be created when the subscription is added. - - - Adds the subscription to the existing database that defined in the connection string. - - - Causes a new SQL Server Compact 4.0 database to be created when the subscription is created. - - - When passed to the function, the CommitMode specifies when the commit occurs. - - - Changes are committed to disk after user-specified flush interval. The default flush interval is 10 seconds but can be modified within the . - - - Changes are committed immediately. - - - Specifies the options to use when using the method. - - - Maintains the current position after inserting a new row. - - - Positions the cursor on the newly-inserted row. - - - Specifies the options used by the method when specifying the index range over which to seek. - - - Includes the startData value in the range. - - - Includes the endData value in the range. - - - Excludes the startData value from the range. - - - Excludes the endData value from the range. - - - Excludes null values from the range. - - - Specifies a range in which index values begin with the value of startData. When using the Prefix option, endData must be set to null. - - - Specifies a range in which index values match the value of startData. When using the Match option, endData must be set to null. - - - Equivalent to setting both the and flags. - - - Options that specify how the method will seek on an index. - - - Advances to the first matching row (in index order) on the index. - - - Advances to the last matching row (in index order) on the index. - - - Advances to the last matching row on the index. If there are no matching rows, advances to the first row with values after the seek value, in index order. - - - Advances to the first row with values (in index order) after the seek value. - - - Advances to the first matching row on the index. If there are no matching rows, advances to the last row with values before the seek value, in index order. - - - Advances to the last row with values (in index order) before the seek value. - - - Specifies whether to leave or delete the database when dropping a subscription using the method. - - - Deletes the replication system tables and all replication system columns in the user tables when you drop a subscription using the method, but does not delete the SQL Server Compact database. - - - Deletes the SQL Server Compact database when you drop a subscription using the method. - - - Unregisters the SQL Server Compact database from a subscription.  - - - Specifies whether data is merged up to the Publisher only, or merge in both directions between the Publisher and the Subscriber. - - - No options are specified. - - - Merges only the Subscriber changes with the Publisher. - - - Merges all changes between the Publisher and Subscriber. This is the default setting. - - - Specifies the network protocol to use when setting the or properties of the object. - - - Use the currently-configured Net-Library when setting the or properties of the object. - - - Use the TCP/IP Sockets Net-Library when setting the or properties of the object. - - - Use the Multiprotocol Net-Library when setting the or properties of the object. - - - A user-defined delegate to the event that fires at the start of downloading table changes from the server. - The interface returned by the method. - The name of the table being downloaded from the server. - - - A user-defined delegate to the event that fires at the start of uploading table changes to the server. - The interface returned by the BeginSynchronize method. - The name of the table being uploaded to the server. - - - A user-defined delegate that consumes the ongoing synchronization events reported during the reconciler work. - The interface returned by the BeginSynchronize method. - The value returned by the reconciler that represents the percent of replication work completed by the reconciler. - - - Specifies the criteria to use to purge metadata when using the method or the method of the class. - - - This value is reserved for use by the tracking infrastructure. Do not use it in your code. - - - Specifies that metadata will be deleted based on whether it is older than a specified number of days. - - - Specifies that metadata will be deleted based on the Commit Sequence Number (CSN) of the last transaction to modify it. - - - This value is reserved for use by the tracking infrastructure. Do not use it in your code. - - - Specifies whether or not the rows associated with the should be batched together in a single transaction. - - - Indicates that SQL Server Compact does not batch rows pushed to SQL Server. The server processes each row separately. This is the default setting. - - - Indicates that SQL Server Compact batches the rows pushed to SQL Server into a single transaction. - - - Specifies whether or not the table being pulled to the device is tracked. - - - Indicates that SQL Server Compact does not track changes to the pulled table. No PRIMARY KEY constraints are created locally. - - - Indicates that SQL Server Compact tracks all changes to the pulled table. PRIMARY KEY constraints related to the value specified for are created on the local table. This is the default setting. - - - Indicates that SQL Server Compact tracks all changes to the pulled table. Indexes and PRIMARY KEY constraints that existed on the SQL Server table specified in are created on the local table. - - - Indicates that SQL Server Compact does not track changes to the pulled table. Indexes and PRIMARY KEY constraints that existed on the SQL Server table specified in are created on the local table. - - - When passed to the method, specifies the type of database repair to perform. - - - Deletes all corrupted rows without attempting to fix them. - - - Attempts to fix all corrupted rows rather than deleting them. - - - Fixes all of the corrupted rows that it is possible to fix. Rows that cannot be fixed are left unmodified. - - - Attempts to fix all corrupted rows. If not all of the rows can be fixed, none of them are modified and the operation fails. - - - An enumerator that can be used to iterate through a collection of records in a ResultSet object. The is not designed to be used directly from within your code. You will get more functionality by working directly with the object. - - - Initializes a new instance of the class. - A object containing the records to be enumerated. - - - The current record in the . - - - Moves to the next record in the . - - - Positions the cursor before the first record in the . - - - - Sets options for the . - - - No ResultSet options are specified. - - - The ResultSet allows updates. - - - The ResultSet can be scrolled both forward and backward. - - - The ResultSet detects changes made to the data source. - - - The ResultSet does not detect changes made to the data source. - - - Sets the sensitivity of the . - - - No sensitivity is set for the ResultSet. - - - The ResultSet does not detect changes made to the data source. - - - The ResultSet detects changes made to the data source. - - - Implements data binding interfaces and provides a bridge between user interface controls and the . - - - Gets or sets the columns by name in a which will be bound to a given control. - - - This event is raised when items are added or removed from the . - - - Gets or sets the columns by ordinal position in a which will be bound to a given control. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Specifies the mode of security to use when connecting to the Publisher or Distributor during Replication. - - - Use SQL Server Authentication when connecting to the Publisher or Distributor during Replication. This is the default. - - - Use Integrated Windows Authentication when connecting to the Publisher or Distributor during Replication. - - - Controls how snapshot files are transferred from the Distributor to the computer running IIS. - - - The snapshot file will be transferred from the Universal Naming Convention (UNC) share on the server. This is the default. - - - The snapshot file will be transferred via the FTP protocol. - - - [SECURITY CRITICAL] Provides methods that can be used to track changes to tables in a SQL Server Compact database. - - - [SECURITY CRITICAL] Initializes a new instance of the class with a . - A that represents the connection to a data source. - - - [SECURITY CRITICAL] Initializes a new instance of the class with a . - A that represents the transaction in which change tracking executes. - - - [SECURITY CRITICAL] Disables tracking on the specified table. - The name of the table on which to disable change tracking. - - - [SECURITY CRITICAL] Releases all resources used by the current instance of the class. - - - [SECURITY CRITICAL] Releases the unmanaged resources used by the class and optionally releases the managed resources. - true to release both managed and unmanaged resources; false to release only unmanaged resources. - - - [SECURITY CRITICAL] Enables tracking on the specified table. - The name of the table on which to enable tracking. - One of the values of that specifies the row key to use for tracked data. The row key uniquely identifies table rows to the tracking system and can be either the primary key of the table or a column of type uniqueidentifier that has the ROWGUIDCOL attribute applied. - A bitwise combination values that specifies the database operations to be tracked on the table. - - - [SECURITY CRITICAL] Returns the Commit Sequence Number (CSN) of the last transaction committed for the data source associated with the object. - The CSN for the data source. - - - [SECURITY CRITICAL] Gets a value that indicates the database operations that are currently being tracked on the specified table. - true if the table is currently being tracked (tracking is enabled); otherwise, false. - The name of the table for which to retrieve the operations that are currently being tracked. - When this method returns, contains a bitwise combination of values, which indicates the operations that are currently being tracked. This parameter is passed uninitialized. - - - [SECURITY CRITICAL] Converts the row key from the specified table into the format used for the row key in the tombstone table. - An array of bytes that represents the value of the row key in the tombstone table. - The name of the table containing the row. - An array that contains the column values of the row key. - - - [SECURITY CRITICAL] Purges tombstone data for the specified table. - The name of the table for which to delete the tombstone data. - One of the values of that specifies whether the purge is time based or based on the commit sequence number (CSN) of the last transaction to modify the tombstone data. - A number that specifies the limit up to which tombstone rows should be retained. In the case of a time based purge the parameter specifies the number of days from the present date for which to retain tombstone data. In the case of a CSN based purge, the parameter specifies the CSN of the last transaction for which tombstone data should be retained. - - - [SECURITY CRITICAL] Purges the specified data from the transaction history table. - One of the values of that specifies whether the purge is time based or based on the commit sequence number (CSN) of the last transaction to modify the transaction history data. - A number that specifies the limit up to which rows should be retained. In the case of a time based purge the parameter specifies the number of days from the present date for which to retain transaction history data. In the case of a CSN based purge, the parameter specifies the CSN of the last transaction for which transaction history data should be retained. - - - [SECURITY CRITICAL] Converts the representation of a row key used in the tombstone table into the column values of the row key used in the specified table. - An array of objects that contains the column values of the row key used in the table. - The name of the table. - An array of bytes that represents the value of the row key in the tombstone table. - - - [SECURITY CRITICAL] Upgrades tracking metadata in a SQL Server Compact SP2 database, on which tracking has been enabled, for use by Microsoft Sync Framework Service Pack 1 (SP1) and later versions of Sync Framework. - true if the database was successfully upgraded or if the database is not currently being tracked; otherwise, false. - A connection string to the data source. - - - Represents an SQL statement to execute against a data source. - - - Initializes a new instance of the class. - - - Initializes a new instance of the class with the text of the query. - The text of the query. - - - Initializes a new instance of the class with the text of the query and a . - The text of the query. - A that represents the connection to a data source. - - - Initializes a new instance of the class with the text of the query, a , and the . - The text of the query. - A that represents the connection to a data source. - The transaction in which the executes. - - - Attempts to cancel the execution of a . - - - Gets or sets an SQL statement to execute at the data source. - The SQL statement to execute or the name of the base table to open. The default value is an empty string. - - - Gets or sets the wait time before terminating the attempt to execute a command and generating an error. - Always zero (0) for SQL Server Compact. - - - Gets or sets a value indicating how the property is interpreted. - One of the values. The default is . - The value was not a valid . - - - Gets or sets the used by this instance of the . - The connection to a data source. The default value is null. - The property was changed while a transaction was in progress. - - - Creates a new instance of a object. - A object. - - - Get always returns false; set always throws a . - - - Executes an SQL statement against the and returns the number of rows affected. - The number of rows affected. - The connection does not exist.-or- The connection is not open.-or- Cannot execute a command within a transaction context that differs from the context in which the connection was originally enlisted. - - - Sends the to the and builds a . - A object. - Cannot execute a command within a transaction context that differs from the context in which the connection was originally enlisted. - - - Sends the to the and builds a by using one of the values. - A object. - One of the values. - Cannot execute a command within a transaction context that differs from the context in which the connection was originally enlisted. - - - Sends the to the and builds a by using the . - The ResultSetOptions to use when building the ResultSet. - - - Sends the to the and builds a by using the . - The ResultSetOptions to use when building the ResultSet. - The ResultSet to build. - - - Executes the query and returns the first column of the first row in the result set that is returned by the query. Extra columns or rows are ignored. - The first column of the first row in the result set. - Cannot execute a command within a transaction context that differs from the context in which the connection was originally enlisted. - - - Specifies the index to be opened. - The name of the index to be opened. - - - Gets the . - The parameters of the SQL statement. The default is an empty collection. - - - Creates a prepared (or compiled) version of the command on the data source. - The is not set.-or -The is not . - - - Restricts the set of rows that will be read by the . - The options used when specifying the range. - The starting key values for the range. - The ending key values for the range. - - property has not been set. - - - - Gets or sets the transaction in which the executes. - The . The default value is null. - - - Gets or sets how command results are applied to the when used by the method of the . This property should not be used with the .NET Compact Framework Data Provider for SQL Server Compact. - One of the values. The default is Both. If the command is automatically generated, the default is None. - The value entered was not one of the values. - - - Provides a means of automatically generating single-table commands used to reconcile changes made to a with the associated database. This class cannot be inherited. - - - Initializes a new instance of the class. - - - Initializes a new instance of the class with associated and objects. - The name of the . - - - Not supported in SQL Server Compact. - - - Not supported in SQL Server Compact. - - - Specifies which is to be used by the . - A object. - - - Gets or sets a object for which SQL statements are automatically generated. - A object. - - - Gets the automatically generated object required to perform deletions on the database when an application calls on the . - The automatically generated object required to perform deletions. - - - Gets the automatically generated object required to perform inserts on the database when an application calls on the . - The automatically generated object required to perform inserts. - - - Gets the automatically generated object required to perform updates on the database when an application calls on the . - The automatically generated object required to perform updates. - - - Returns the correct quoted form of the specified identifier. - The quoted form of the identifier. - The identifier for which to return the quoted form. - - is null. - - - Gets or sets the beginning character or characters to use when specifying SQL Server database objects (for example, tables or columns) whose names contain characters such as spaces or reserved tokens. - The beginning character or characters to use. The default is an empty string. - This property cannot be changed after an INSERT, UPDATE, or DELETE command has been generated. - - - Gets or sets the ending character or characters to use when specifying SQL Server database objects (for example, tables or columns) whose names contain characters, such as spaces or reserved tokens. - The ending character or characters to use. The default is an empty string. - This property cannot be changed after an INSERT, UPDATE, or DELETE command has been generated. - - - Not supported in SQL Server Compact. - - - Returns the correct unquoted form of the specified identifier. - The identifier with all quotes removed. - The identifier for which to return the unquoted form. - - is null. - - - Represents an open connection to a SQL Server Compact data source. - - - Initializes a new instance of the class. - - - Initializes a new instance of the class with the specified connection string. - The connection used to open the database. - - - Begins a database transaction. - An object representing the new transaction. - - - Begins a database transaction with the current value. - An object representing the new transaction. - The transaction isolation level for this connection. - - - Changes the current database for an open . - The database name. - The database name is not valid. - The connection is not open. - The databases cannot be changed. - - - Closes the connection to the data source. This is the preferred method of closing any open connection. - - - Gets or sets the string used to open a database. - The .NET Compact Framework Data Provider for SQL Server Compact connection string that includes the data source name and other parameters needed to establish the initial connection. The default value is an empty string. - An invalid connection string argument has been supplied. - - - Gets the time to wait while trying to establish a connection before terminating the attempt and generating an error. - The time (in seconds) to wait for a connection to open. The value is always 0 in SQL Server Compact. - - - Creates and returns a object associated with the . - A object. - - - Gets the name of the current database or the database to be used when a connection is open. - The name of the current database or the name of the database to be used when a connection is open. The default value is an empty string. For SQL Server Compact, the value for this property should be the full path of the database file; for example, "\myApp\myDB.sdf". - - - Gets the unique identifier of the current database while synchronizing. - The unique identifier of the current database. - - - Gets the file name of the data source. - The location and file name of the data source. The default value is an empty string. - - - Releases all resources used by the current instance of the class. - - - Enlists in the specified . - The transaction in which you want to enlist - The connection is already enlisted in a local transaction.-or-The connection could not be enlisted in the transaction. - - is null. - - - Occurs when the background flush fails. - - - Returns a set of Key Value pairs with information about locale, encryption mode, and case-sensitivity setting of the connected database. - Sorted list with the name value pairs of locale, encryption mode, and case sensitivity. - - - Returns schema information for the data source of this . - A that contains schema information. - - - Returns schema information for the data source of this using the specified string for the schema name. - A that contains schema information. - The schema name. - - - Returns schema information for the data source of this using the specified string for the schema name and the specified string array for the restriction values. - A that contains schema information. - The schema name. - A set of restriction values. - - - Occurs when the .NET Compact Framework Data Provider for SQL Server sends a warning or an informational message. - - - Opens a database connection with the property settings specified by the . - The connection is already open. - A connection-level error occurred while opening the connection. - - - Returns the database version number as a string. - A string of the version of SQL Server Compact. - - - Gets the current state of the connection. - A bitwise combination of the values. The default is Closed. - - - Occurs when the state of the connection changes. - - - Provides a simple way to create and manage the contents of connection strings used by the class. - - - Initializes a new instance of the class using default values. - - - Initializes a new instance of the class using the specified connection string that provides the data for the instance’s internal connection information. - The Connection String. - - - Gets or sets the percent of free space in the database file that is allowed before autoshrink begins. - A value of 100 disables autoshrink. If not specified, the default value is 60. - - - Gets or sets a value that indicates whether or not the database collation is case-sensitive. - true if the database is case-sensitive; otherwise, false. - - - Clears the contents of the instance. - - - Determines whether the contains a specific key. - true if the contains an element that has the specified key; otherwise, false. - The key to locate in the . - - - Gets or sets the file path and name of the SQL Server Compact database. - The file path and name of the SQL Server Compact database. - - - Gets or sets the number of locks a transaction will acquire before attempting escalation from row to page, or from page to table. - The number of locks a transaction will acquire before attempting escalation from row to page, or from page to table. - - - Gets or sets the default number of milliseconds that a transaction will wait for a lock. - The number of milliseconds that a transaction will wait for a lock. The default value is 2000 if not specified. - - - Gets or sets a value that indicates whether or not the database is encrypted. - true if the database is encrypted; otherwise, false. Must be set to true to enable encryption or false for no encryption. - - - Gets or sets the encryption mode with which the database is to be created against. - The encryption mode with which the database is to be created against. - - - Gets or sets a value that indicates whether a connection database is opened by using Enlist. - true if a connection database is opened by using Enlist, otherwise, false. - - - Gets or sets the mode to use when opening the database file. - The mode value to use when opening the database file. - - - Gets or sets the specified interval time (in seconds) before all committed transactions are flushed to disk. - The specified interval time (in seconds). If not specified, the default value is 10. - - - Gets or sets the locale ID (LCID) to use with the database. - The value of the locale ID (LCID). - - - Gets a value that indicates whether the SqlCeConnectionStringBuilder has a fixed size. - true if the SqlCeConnectionStringBuilder has a fixed size; otherwise, false. - - - Gets or sets the value associated with the specified key. - The value associated with the specified key. - The key of the item to get or set. - - - Gets an ICollection that contains the keys in the . - An ICollection that contains the keys in the . - - - Gets or sets the largest amount of memory, in kilobytes that SQL Server Mobile can use before it starts flushing changes to disk. - The largest amount of memory in kilobytes. The default value is 640 if not specified. - - - Gets or sets the maximum size of the database, in Megabytes. - The maximum size of the database, in Megabytes. The default value is 128. - - - Gets or sets the database password, which can be up to 40 characters in length. - The value of the database password. - - - Gets or sets a value that indicates whether the security-sensitive information, such as the password is not returned as part of the connection. - true if the security-sensitive information is returned as part of the connection; otherwise, false. The default value is false. - - - Removes the entry with the specified key from the instance. - true if the key existed within the connection string and was removed; false if the key did not exist. - The key of the key/value pair to be removed from the connection string in this . - - - Indicates whether the specified key exists in this instance. - true if the contains an entry with the specified key; otherwise, false. - The key to locate in the . - - - Gets or sets the maximum size of the temporary database file, in Megabytes. - The maximum size of the temporary database file, in Megabytes. The default value is 128. - - - Gets or sets the location of the temporary database. - The location of the temporary database. - - - Retrieves a value corresponding to the supplied key from this . - true if keyword was found within the connection string; otherwise, false. - The key of the item to retrieve. - The value corresponding to keyword. - - - Gets an ICollection that contains the values in the . - An ICollection than contains the values in the . - - - Represents a set of data commands and a database connection that are used to fill the and update the data source. - - - Initializes a new instance of the class. - - - Initializes a new instance of the class with the specified as the property. - A that is a SELECT statement. This is set as the property of the . - - - Initializes a new instance of the class with a and a object. - A that is an SQL SELECT statement to be used as the of the property of the . - A that represents the connection. - - - Initializes a new instance of the class with a and a connection string. - A that is an SQL SELECT statement to be used as the of the property of the . - The connection string. - - - Gets or sets an SQL statement for deleting records from the data set. - A used during to delete records in the data source that correspond to deleted rows in the . - - - Disposes the current instance. - - - Gets or sets an SQL statement used to insert new records into the data source. - A used during to insert records in the data source that correspond to new rows in the . - - - Occurs during a call to after an update command is executed against the data source. The attempt to update is made and then this event fires. - - - Occurs during a call to before an update command is executed against the data source. The attempt to update is made, and then this event fires. - - - Gets or sets an SQL statement used to select records in the data source. - A that is used during to select records from data source for placement in the . - - - For a description of this member, see . - Returns . - - - Gets or sets an SQL statement used to update records in the data source. - A used during to update records in the data source that correspond to modified rows in the . - - - Provides a way of reading a forward-only stream of data rows from a data source. This class cannot be inherited. - - - Closes the object. - - - Gets a value indicating the depth of nesting for the current row. - The depth of nesting for the current row. The .NET Compact Framework Data Provider for SQL Server Compact does not support nesting and always returns zero. - - - Releases the resources consumed by this . - - - Releases the unmanaged resources used by this , and optionally releases the managed resources as well. - Specifies whether to release managed resources. - - - Gets the number of columns in the query's SELECT clause. - When not positioned in a valid recordset, 0; otherwise, the number of columns in the current record. - There is no current connection to a data source. - - - Releases unmanaged resources and performs other cleanup operations before the is reclaimed by garbage collection. - - - Gets the value of the specified column as a Boolean. - The value of the column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a byte. - The value of the specified column as a byte. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Reads a stream of bytes from the specified column offset into the buffer as an array starting at the given buffer offset. - The actual number of bytes read. - The zero-based column ordinal. - The index within the field from which to begin the read operation. - The buffer into which to read the stream of bytes. - The index for to begin the read operation. - The maximum length to copy into the buffer. - The operation is not valid. The may be positioned after the last row in the result set. - - - Not supported in the .NET Compact Framework Data Provider for SQL Server Compact. - Returns . - - - Reads a stream of characters from the specified column offset into the buffer as an array starting at the given buffer offset. - The actual number of characters read. - The zero-based column ordinal. - The index within the row from which to begin the read operation. - The buffer into which to copy data. - The index for to begin the read operation. - The number of characters to read. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the name of the source data type. - The name of the back-end data type. - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a object. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a object. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a double-precision floating point number. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Returns . - - - Gets the that is the data type of the object. - The that is the data type of the object. - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a single-precision floating point number. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a globally unique identifier (GUID). - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a 16-bit signed integer. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a 32-bit signed integer. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a 64-bit signed integer. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the name of the specified column. - The name of the specified column. - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the column ordinal, given the name of the column. - The zero-based column ordinal. - The name of the column. - The name specified is not a valid column name. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets a that is a representation of the underlying provider-specific field type. - The object that describes the data type of the specified column. - The zero-based column ordinal. - - - Returns a that describes the column metadata of the . - A that describes the column metadata. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - The value of the column. - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a . - A . - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the specified column as a string. - The value of the specified column. - The zero-based column ordinal. - The specified cast is not valid. - The value is null. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets the value of the column at the specified ordinal in its native format. - The value to return. - The zero-based column ordinal. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets all the attribute columns in the current row. - The number of instances of in the array. - An array of into which to copy the attribute columns. - The operation is not valid. The may be positioned after the last row in the result set. - - - Gets a value that indicates whether the contains one or more rows - A value. - - - Returns . - - - Indicates whether the data reader is closed. - true if the is closed; otherwise, false. - - - Determines whether the specified matches that of this . - true if the behaviors match; otherwise, false. - The command behavior. - - - Gets a value indicating whether the column contains nonexistent or missing values. - true if the specified column value is equivalent to ; otherwise, false. - The zero-based column ordinal. - - - Gets the value of the specified column in its native format given the column ordinal. - The value of the specified column in its native format. - The column ordinal. - - - Gets the value of the specified column in its native format given the column name. - The value of the specified column in its native format. - The column name. - - - Not supported in the .NET Compact Framework Data Provider for SQL Server Compact. - Returns . - - - - Advances to the next record. - true if there are more rows; otherwise, false. - - - Gets the number of rows changed, inserted, or deleted by execution of the SQL statement. - The number of rows changed, inserted, or deleted; 0 if no rows were affected or the statement failed; and -1 for SELECT statements. - - - Places the on the record with indexed values that match the specified parameters. - A Boolean value; true indicates the cursor is positioned on a row. - The to use. - The index of the record. - The value was not found, or another error occurred. - - - Represents the properties, methods, and other objects of the SQL Server Compact Engine object. This class cannot be inherited. - - - Initializes a new instance of the class. - - - Initializes a new instance of the class with the specified local connection string. - - - Reclaims wasted space in the SQL Server Compact database by creating a new database file from the existing file. This method is also used to change the collating order, encryption, or password settings of the database. - The connection string to the destination database. - - - Creates a new database. - - - Releases all SQL Server Compact  resources. - - - Gets or sets the connection string to the SQL Server Compact database. - The connection string. - - - Repairs a corrupted database. - The local connection string to the database. - The RepairOption to use when repairing the database. - - - Reclaims wasted space in the SQL Server Compact database by moving empty pages to the end of the file, and then truncating the file. - - - Upgrades a SQL Server Compact database from version 3.5 to 4.0. After the upgrade, the database will be encrypted if the source database was encrypted. If it was not, the upgraded database will be unencrypted. - - - Upgrades a SQL Server Compact database from version 3.5 to 4.0. The destination database will be encrypted if the encryption mode was specified in the Destination Connection string. The collation of the database will be case sensitive if the case-sensitive property is set to true in the connection string. - The connection string to the destination database. - - - Recalculates the checksums for each page in the database and compares the new checksums to the expected values. - True if the checksums match and there is no database corruption; otherwise, false. - - - Verifies the integrity of the database based on the VerifyOption. - True if there is no database corruption; otherwise, false. - Determines the level of database verification to use. For information about available option values, see . - - - Collects information relevant to a warning or error returned by the data source. This class cannot be inherited. - - - Gets the last three error parameters. Error parameters are used by SQL Server Compact to provide additional details about an error. - A string array that contains the last three error parameters. - - - Returns an HRESULT value that identifies the type of error. - The HR number that identifies the type of error. - - - Gets the text describing the error. - The text describing the error. - - - Gets the native error number of the . For more information about these errors, see "SQL Server Compact Errors" in the Troubleshooting section of SQL Server Compact Books Online. - The native error number of the . - - - Gets the first three error parameters. Error parameters are used by SQL Server Compact to provide additional details about an error. - An integer array that contains the first three error parameters. - - - Gets the name of the provider that generated the error. - The name of the provider that generated the error. For example, the property may return a string such as "OLE DB Provider for SQL Server Compact." - - - Gets the complete text of the error message. - The complete text of the error message. - - - Collects all errors generated by the .NET Compact Framework Data Provider for SQL Server Compact. This class cannot be inherited. - - - Copies the elements of the into an , starting at the given index within the . - The into which to copy the elements. - The starting index of the . - The sum of and the number of elements in the is greater than the of the . - The is null. - The is not valid for the . - - - Gets the number of objects in the collection. - The total number of objects in the collection. - - - Returns an enumerator that can iterate through the . - - - - - - Gets the error at the specified index. - A that contains the error at the specified index. - The zero-based index of the to retrieve. - - - - - The exception thrown when the underlying provider returns a warning or error from a SQL Server Compact data source. This class cannot be inherited. - - - Constructor that helps in serialization. - The serialization information. - The streaming context. - - - Gets a collection of one or more objects that contain detailed information about exceptions generated by the .NET Compact Framework Data Provider for SQL Server Compact. - The object that contains the collected instances of the class for the exception. - - - [SECURITY CRITICAL] Populates a with the data required to serialize the object. - The serialization information. - The streaming context. - - - Gets the HRESULT value of the exception. This value is the same as the value of for the first instance of in the for the exception. - The HRESULT value. - - - Gets the text describing the first instance of in the for this exception. - The text describing the error. - - - Gets the native error number of the first in the . For more information about the error, see the "SQL Server Compact Errors" topic in the Troubleshooting section of SQL Server Compact Books Online. - Returns . - - - Gets the name of the OLE DB provider that generated the error. - The name of the OLE DB provider that generated the error. - - - Encapsulates event arguments for the event. - - - The collection of objects that caused the flush to fail. - - - Gets the text describing the that caused the flush to fail. - - - - The delegate that must be implemented to listen for events. - The source of the event. - The that contains the event data. - - - Provides data for the event. This class cannot be inherited. - - - Gets the collection of warnings sent from the data source. - The collection of warnings sent from the data source. - - - Gets the complete text of the error sent from the data source. - The complete text of the error. - - - Retrieves a string representation of the event. - A string representing the event. - - - Represents the method that will handle the event of a . - The source of the event. - The that contains the event data. - - - The exception thrown when the underlying provider returns an error from a Microsoft SQL Server Compact data source when SQL Server Compact attempts to open a database file of an older or newer version. - - - Constructor that helps in serialization. - The serialization information. - The streaming context. - - - [SECURITY CRITICAL] Populates a with the data needed to serialize the object. - The serialization information. - The streaming context. - - - This exception is thrown if the lock timeout has been reached. - - - Constructor that helps in serialization. - The serialization information. - The streaming context. - - - [SECURITY CRITICAL] Populates a SerializationInfo with the data needed to serialize the object. - The serialization information. - The streaming context. - - - Represents a parameter to a and, optionally, its mapping to a column. This class cannot be inherited. - - - Initializes a new instance of the class. - - - Initializes a new instance of the class with the parameter name and data type. - The name of the parameter to map. - One of the values. - - - Initializes a new instance of the class with the parameter name, data type, and length. - The name of the parameter to map. - One of the values. - The length of the parameter. - - - Initializes a new instance of the class with the parameter name, data type, length, and other properties. SQL Server Compact supports only input parameters. - The name of the parameter. - One of the values. - The length of the parameter. - true if the value of the field can be null; otherwise, false. - The total number of digits to the left and right of the decimal point to which is resolved. - The total number of decimal places to which is resolved. - The name of the source column. - One of the values. - An that is the value of the . - - - Initializes a new instance of the class with the parameter name, data type, length, parameter direction, and other properties. SQL Server Compact only supports input parameters. - The name of the parameter. - One of the values. - The length of the parameter. - The to use. - true if the value of the field can be null; otherwise, false. - The total number of digits to the left and right of the decimal point to which is resolved. - The total number of decimal places to which is resolved. - The name of the source column. - One of the values. - An that is the value of the . - - - Initializes a new instance of the class with the parameter name, data type, length, and source column name. - The name of the parameter to map. - One of the values. - The length of the parameter. - The name of the source column. - - - Initializes a new instance of the class with the parameter name and the value of the new . - The name of the parameter to map. - The value of the new object. - The value supplied for the parameter cannot be converted to a database type supported by SQL Server Compact. - - - Gets or sets the of the parameter. - One of the values. The default is . - The property was not set to a valid . - - - This property always returns ParameterDirection.Input for .NET Compact Framework Data Provider for SQL Server Compact. Setting this property to a different value causes an to be thrown. - This property always returns ParameterDirection.Input for SQL Server Compact Data Provider. Setting this property is not supported. - The user attempted to set this property. - - - Gets or sets a value indicating whether or not the parameter accepts null values. - true if null values are accepted; otherwise, false. The default is false. - - - - Gets or sets the name of the . - The name of the . The default is an empty string. - - - Gets or sets the maximum number of digits used to represent the property. - The maximum number of digits used to represent the property. The default value is 0. - - - Resets the type associated with this . - - - Gets or sets the number of decimal places to which is resolved. - The number of decimal places to which is resolved. The default is 0. - - - Gets or sets the maximum length of the data within the column. - The maximum length of the data within the column. The default value is inferred from the parameter value. - - - Gets or sets the name of the source column mapped to the and used for loading or returning the . - The name of the source column mapped to the . The default is an empty string. - - - - Gets or sets the to use when loading . - One of the values. The default is Current. - The property was not set to one of the values. - - - Gets or sets the of the parameter. - One of the values. The default is NVarChar. - - - - Gets a string containing the . - A string containing the . - - - Gets or sets the value of the parameter. - An that is the value of the parameter. The default value is null. - - - Collects all parameters relevant to a as well as their respective mappings to columns. - - - Adds the specified to the . - A reference to the new object. - The to add to the collection. - - - Adds a object to the . - The index of the new object in the collection. - The object to add to the collection. - The parameter passed was not a . - - - Adds a to the given the parameter name and data type. - A reference to the new object. - The name of the parameter. - One of the SqlDbType values. - - - Adds a to the given the parameter name, data type, and column width. - A reference to the new object. - The name of the parameter. - One of the SqlDbType values. - The width of the column. - - - Adds a to the given the parameter name, data type, column width, and source column name. - A reference to the new object. - The name of the parameter. - One of the SqlDbType values. - The width of the column. - The name of the source column. - - - Adds a to the given the parameter name and value. - A reference to the new object. - The name of the parameter. - The value of the to add to the collection. - The object supplied as the parameter cannot be converted to a string. This can happen if the object is not a primitive type, SqlDbType or byte array. - - - Adds an array of objects to . - An array of values of type to add to the collection. - - - Adds a new to the and sets its value. - Name of the . - Value of the . - - - Removes all items from the collection. - - - Gets a value indicating whether or not a object exists in the collection. - true if the collection contains the ; otherwise, false. - The value of the object to find. - - - Gets a value indicating whether a with the specified parameter name exists in the collection. - true if the collection contains the parameter; otherwise, false. - The name of the parameter. - - - Copies objects from the to the specified array. - The into which to copy the objects. - The starting index of the array. - - - Gets the number of objects in the collection. - The number of objects in the collection. - - - - Gets the location of the object in the collection. - The zero-based location of the in the collection. - The object to locate. - - - Gets the location of the in the collection with the specified parameter name. - The location of the in the collection. - The name of the parameter to find. - - - Inserts a in the collection at the specified index. - The zero-based index where the parameter is to be inserted within the collection. - The to add to the collection. - - - - - - Gets or sets the at the specified index. - The at the specified index. - The zero-based index of the parameter to retrieve. - The index specified does not exist. - - - Gets or sets the with the specified name. - The with the specified name. - The name of the parameter to retrieve. - The name specified does not exist. - - - Removes the specified from the collection. - The object to remove from the collection. - The parameter does not exist. - The parameter is not a . - - - Removes the at the specified index from the collection. - The zero-based index of the parameter to remove. - The specified index does not exist. - - - Removes the with the specified name from the collection. - The name of the parameter to remove. - A parameter with the specified name does not exist in the collection. - - - - Represents a set of methods for creating instances of a provider's implementation of the data source classes. - - - Initializes a new instance of the class. - - - Returns a new instance of the provider's class that implements the . - A new instance of . - - - Returns a new instance of the provider's class that implements the . - A new instance of . - - - Returns a new instance of the provider's class that implements the . - A new instance of . - - - Returns a new instance of the provider's class that implements the class. - A new instance of the class. - - - Returns a new instance of the provider's class that implements the . - A new instance of - - - Returns a new instance of the provider's class that implements the . - A new instance of . - - - An instance of . - - - Gets the service type. - Returns . - The service type. - - - [SECURITY CRITICAL] Initializes a new instance of the object. For more information about Remote Data Access, see Using Remote Data Access (RDA). - - - [SECURITY CRITICAL] Initializes a new instance of the object. - - - [SECURITY CRITICAL] Initializes a new instance of the object and configures it for anonymous access to Microsoft Internet Information Services (IIS). - The URL used to connect to the SQL Server Compact Server Agent. - The OLE DB connection string for the SQL Server Compact database. - - - [SECURITY CRITICAL] Initializes a new instance of the object and configures it for a Basic or Integrated Windows authentication to Microsoft Internet Information Services (IIS). - The URL used to connect to the SQL Server Compact Server Agent. - The login name used when connecting to the SQL Server Compact Server Agent. - The password used when connecting to the SQL Server Compact Server Agent. - The OLE DB connection string for the SQL Server Compact database. - - - [SECURITY CRITICAL] Specifies the amount of compression that will be used by the compression routines during Push and Pull operations. - The compression level that has been set. - - - [SECURITY CRITICAL] Enables the object to use the smart device's Connection Manager API to establish a network connection. The connection is released at the end of synchronization. - - - [SECURITY CRITICAL] Specifies how long (in seconds) the SQL Server Compact client will continue to retry sending failed requests. - The value, with a default value of 120 seconds. - - - [SECURITY CRITICAL] Gets or sets the amount of time, in milliseconds, that the object waits for a connection to the server. - An value that represents the time-out, in milliseconds, with no default. - - - [SECURITY CRITICAL] Releases all unmanaged resources. - - - [SECURITY CRITICAL] Specifies the Microsoft Internet Information Services (IIS) login name used when connecting to the SQL Server Compact Server Agent. - The IIS login name used when connecting to the SQL Server Compact Server Agent. The default is no login. - - - [SECURITY CRITICAL] Specifies the Microsoft Internet Information Services (IIS) password used when connecting to the SQL Server Compact Server Agent. - The IIS password string used when connecting to the SQL Server Compact Server Agent. The default is no password. - - - [SECURITY CRITICAL] Specifies the login name used when connecting to a proxy server (defined in the property) that requires authentication. - The proxy server login name. The default is no login. - - - [SECURITY CRITICAL] Specifies the password used when connecting to a proxy server (defined in the property) that requires authentication. - The proxy server password string. The default is no password. - - - [SECURITY CRITICAL] Specifies the proxy server to use when accessing the HTTP resource specified in the property. - The proxy server name (or IP address) and the port number () used when accessing the specified HTTP resource. - - - [SECURITY CRITICAL] Specifies the URL used to connect to the SQL Server Compact Server Agent. The SQL Server Compact Server Agent is the Microsoft Internet Information Services (IIS) ISAPI DLL that connects the SQL Server Compact client to the Microsoft SQL Server Database. This property must be specified. - The string containing the URL of the SQL Server Compact Server Agent (including its file name, Sqlcesa35.dll). - - - [SECURITY CRITICAL] Specifies the connection string for the SQL Server Compact database. - The connection string for the SQL Server Compact database. - - - [SECURITY CRITICAL] Downloads data from a remote SQL Server database and stores that data in a single table in a local SQL Server Compact database. - The name of the SQL Server Compact table that will receive the extracted SQL Server records. An error occurs if the table already exists. - Any valid Transact-SQL statement—including SELECT statements and stored procedures—that specifies which table, columns, and records to extract from the SQL Server database for storing in the SQL Server Compact database. - - - [SECURITY CRITICAL] Downloads data from a remote SQL Server database and stores that data in a single table in a local SQL Server Compact database. - The name of the SQL Server Compact table that will receive the extracted SQL Server records. An error occurs if the table already exists. - Any valid Transact-SQL statement—including SELECT statements and stored procedures—that specifies which table, columns, and records to extract from the SQL Server database for storing in the SQL Server Compact database. - The option indicating whether SQL Server Compact tracks changes made to the pulled table, and whether the indexes that exist on the table being pulled are brought down to the device with the PRIMARY KEY constraints. - - - [SECURITY CRITICAL] Downloads data from a remote SQL Server database and stores that data in a single table in a local SQL Server Compact database. - The name of the SQL Server Compact table that will receive the extracted SQL Server records. An error occurs if the table already exists. - Any valid Transact-SQL statement—including SELECT statements and stored procedures—that specifies which table, columns, and records to extract from the SQL Server database for storing in the SQL Server Compact database. - The option indicating whether SQL Server Compact tracks changes made to the pulled table, and whether the indexes that exist on the table being pulled are brought down to the device with the PRIMARY KEY constraints. - The name of the local error table that is created if an error occurs when the method is later called to send changes back to SQL Server. This option can be specified only when the value is or . - - - [SECURITY CRITICAL] Transmits changes from a pulled tracked table in SQL Server Compact back to the originating SQL Server table. These changes are individually applied to the server in separate transactions. - The name of the SQL Server Compact table that will receive the extracted SQL Server records. An error occurs if the table already exists. - - - [SECURITY CRITICAL] Transmits changes from a pulled tracked table in SQL Server Compact back to the SQL Server table. These changes can be either individually applied to the server or batched together in a single transaction. - The name of the SQL Server Compact table that will receive the extracted SQL Server records. An error occurs if the table already exists. - The option indicates whether the changes being sent back to the SQL Server table should be batched together in a single transaction or individually applied. - - - [SECURITY CRITICAL] Gets or sets the amount of time, in milliseconds, that the object waits for the response to a server request. - An value that represents the time-out, in milliseconds, with a default of 60 seconds. - - - [SECURITY CRITICAL] Gets or sets the amount of time, in milliseconds, that the object waits to send a request to the server. - An value that represents the time-out, in milliseconds, with no default. - - - [SECURITY CRITICAL] Submits SQL statements for execution on a database in SQL Server on a remote server. - Any SQL statement that does not return rows. - The OLE DB connection string for the remote SQL Server database. - - - [SECURITY CRITICAL] Initializes a new instance of the object. For more information about SQL Server replication, see the SQL Server Books Online. For more information about merge replication with SQL Server Compact, see the SQL Server Compact Books Online. - - - [SECURITY CRITICAL] Initializes a new instance of the object. This is the default constructor. - - - [SECURITY CRITICAL] Initializes a new instance of the object and sets the required properties for connecting to a publication. - The URL used to connect to the SQL Server Compact Server Agent. - The login name used when connecting to the SQL Server Compact Server Agent. - The password used when connecting to the SQL Server Compact Server Agent. - The name of the Publisher. - The name of the publication database. - The publication name that has been enabled for anonymous merge subscriptions. - The name of the Subscriber. - The OLE DB connection string for the SQL Server Compact database on the Windows Mobile-based device. - - - [SECURITY CRITICAL] Initializes a new instance of the object and sets the properties for connecting to a publication. - The URL used to connect to the SQL Server Compact Server Agent. - The login name used when connecting to the SQL Server Compact Server Agent. - The password used when connecting to the SQL Server Compact Server Agent. - The name of the Publisher. - The name of the publication database. - The login name used when connecting to the Publisher. - The login password used when connecting to the Publisher. - The publication name that has been enabled for anonymous merge subscriptions. - The name of the Subscriber. - The OLE DB connection string for the SQL Server Compact database on the Windows Mobile-based device. - - - [SECURITY CRITICAL] Creates a new anonymous subscription to an existing SQL Server publication. After calling the method, the application must call the method to synchronize the new subscription to the publication based on the latest snapshot. - - - [SECURITY CRITICAL] Starts an asynchronous data synchronization operation. When the synchronization ends, the delegates are called. During the synchronization, synchronization status reports are sent to the SyncStatusReport delegates. - The interface for the asynchronous operation that has been started by calling this function. You can use this interface for testing for completion, or waiting until synchronization ends. - The delegate that is implemented by the caller called at the end of synchronization. - A user-defined delegate to the event that fires at the start of uploading table changes to the server. - A user-defined delegate to the event that fires at the start of downloading table changes from the server. - A user-defined delegate that consumes the ongoing synchronization events that are reported during the reconciler work. - A user-defined object that is returned by the property. - - - [SECURITY CRITICAL] Starts an asynchronous data synchronization operation. When synchronization ends, the delegates are called. During synchronization, no status reporting is performed. - The interface for the asynchronous operation that has been started by calling this function. You can use this interface for testing for completion, or waiting until synchronization ends. - The delegates that are implemented by the caller and called at the end of synchronization. - A user-defined object that is returned by the property. - - - [SECURITY CRITICAL] Cancels an ongoing asynchronous data synchronization that was started by calling the method. - - - [SECURITY CRITICAL] Specifies the amount of compression that will be used by the compression routines during replication. - The compression level. - - - [SECURITY CRITICAL] Enables the Replication object to use the smart device's Connection Manager API to establish a network connection. The connection is released at the end of synchronization. - true if the Connection Manager settings are used; otherwise, false. - - - [SECURITY CRITICAL] Specifies how long (in seconds) the SQL Server Compact client will continue to retry sending requests after an established connection has failed. - The value, with a default value of 120 seconds. - - - [SECURITY CRITICAL] Gets or sets the amount of time, in milliseconds, that the object waits for a connection to the server. - An value that represents the time-out, in milliseconds, with no default. - - - [SECURITY CRITICAL] Releases all native resources. - - - [SECURITY CRITICAL] Specifies the SQL Server Distributor. - The name of the Distributor used by the Publisher. - - - [SECURITY CRITICAL] Specifies the network address used when the SQL Server Reconciler is connecting to the Distributor. - The network address used when connecting to the Distributor. - - - [SECURITY CRITICAL] Specifies the login name used when connecting to the Distributor. - The login name used when connecting to the Distributor. - - - [SECURITY CRITICAL] Specifies the network protocol used when the SQL Server Reconciler communicates with the Distributor. - The constant used by the SQL Server Reconciler to communicate with the Distributor. - - - [SECURITY CRITICAL] Specifies the login password used when connecting to the Distributor. - The password used when connecting to the Distributor. - - - [SECURITY CRITICAL] Specifies the security mode used when connecting to the Distributor. - The constant that specifies the mode of security enforced at the Distributor. - - - [SECURITY CRITICAL] Drops the subscription to a SQL Server publication and optionally deletes the SQL Server Compact database from the Windows Mobile-based device. - - - [SECURITY CRITICAL] Ends an asynchronous data synchronization that was started by a call to the method. - The interface returned by the method. - - - [SECURITY CRITICAL] Specifies whether the synchronization between the Publisher and the Subscriber is bi-directional or upload only. - The constant that specifies whether data merges up to the Publisher only, or in both directions between the Publisher and the Subscriber. - - - [SECURITY CRITICAL] Gets or sets the host name used for the device when connecting to the Publisher. - The host name for the device. The default is no host name. - - - [SECURITY CRITICAL] Specifies the login name used when connecting to the SQL Server Compact Server Agent. - The Internet Information Services (IIS) login name. The default is no login name. - - - [SECURITY CRITICAL] Specifies the password used when connecting to the SQL Server Compact Server Agent. - The Internet Information Services (IIS) password string. The default is no password. - - - [SECURITY CRITICAL] Specifies the login name used when connecting to an that requires authentication. - The proxy server login name. The default is no login name. - - - [SECURITY CRITICAL] Specifies the password used when connecting to an that requires authentication. - The proxy server password string. The default is no password. - - - [SECURITY CRITICAL] Specifies the proxy server to use when accessing the HTTP resource specified in the property. - The proxy server name (or IP address) and optionally the port number, in the following format: : - - - [SECURITY CRITICAL] Specifies the URL used to connect to the SQL Server Compact Server Agent. - The URL string. - - - [SECURITY CRITICAL] Retrieves all values stored for the synchronization properties, and then populates the class properties with these saved values. - - - [SECURITY CRITICAL] Specifies the maximum number of seconds to wait for connections to be established. This property affects the connection time between the computer running Internet Information Services (IIS) and the Publisher or Distributor. It does not control the connection time between the smart device and IIS. - The number of seconds for connections to be established. The default is 15 seconds. - - - [SECURITY CRITICAL] Gets or sets a value that selectively enables or disables the types of post sync cleanup operations that are performed. - A value that specifies which post sync cleanup operations to perform. The Update Statistics operation (UpdateStats) and the Clean by Retention operation (CleanByRetention) can be selectively enabled or disabled. See the Remarks section for details. - - - [SECURITY CRITICAL] Specifies the name of the agent profile at the Distributor to be used by the object. - The agent profile name. - - - [SECURITY CRITICAL] Specifies the SQL Server publication name that has been enabled for SQL Server Compact subscribers. - The name of the Publication. - - - [SECURITY CRITICAL] Specifies the name of the SQL Server Publisher. The Publisher is the computer that is running SQL Server and that contains the publication. - The name of the Publisher. - - - [SECURITY CRITICAL] Specifies the network address used when connecting to the Publisher. - The network address used when connecting to the Publisher. - - - [SECURITY CRITICAL] Specifies the total number of Publisher changes applied at the Subscriber when the method was last called. - The total number of Publisher rows that were inserted, updated, and deleted. - - - [SECURITY CRITICAL] Specifies the total number of conflicts that occurred at the Publisher when the method was last called. - The number of conflicts that occurred. - - - [SECURITY CRITICAL] Specifies the name of the publication database. - The name of the publication database. - - - [SECURITY CRITICAL] Specifies the login name used when connecting to the Publisher. - The Publisher login name. - - - [SECURITY CRITICAL] Specifies the network protocol used when the SQL Server Replication Provider communicates with the Publisher. - The constant that specifies the network protocol used. - - - [SECURITY CRITICAL] Specifies the login password used when connecting to the Publisher. - The login password. The default is no password (empty string). - - - [SECURITY CRITICAL] Specifies the security mode used when connecting to the Publisher. - The constant that specifies the security mode. - - - [SECURITY CRITICAL] Specifies the number of seconds allowed for internal queries to complete. - The number of seconds allowed for internal queries to be returned. The default is 300 seconds. - - - [SECURITY CRITICAL] Gets or sets the amount of time, in milliseconds, that the object waits for the response to a server request. - An value that represents the time-out, in milliseconds, with a default of 60 seconds. - - - [SECURITY CRITICAL] Marks a subscription for reinitialization. After calling this method, an application must call the method to download the latest snapshot of the publication to the device. - If True, the changes in the subscription database are uploaded to the Publisher before the snapshot is applied at the Subscriber. The default is False. - - - [SECURITY CRITICAL] Retrieves all of the values stored in the class properties for the current subscription and stores them in a system table. - - - [SECURITY CRITICAL] Gets or sets the amount of time, in milliseconds, that the object waits to send a request to the server. - An value that represents the time-out, in milliseconds, with no default. - - - [SECURITY CRITICAL] Controls how snapshot files are transferred from the Distributor to the computer running IIS. Snapshot files can be transferred using either the HTTP or the FTP protocol. - The value. - - - [SECURITY CRITICAL] Specifies the name of the Subscriber. - The Subscriber name. - - - [SECURITY CRITICAL] Specifies the total number of Subscriber changes applied at the Publisher when the method was last called. - The total number of Subscriber rows that were inserted, updated, and deleted. - - - [SECURITY CRITICAL] This property is not used by SQL Server Compact. - - - [SECURITY CRITICAL] Specifies the connection string to the SQL Server Compact database. - The connection string to the SQL Server Compact database. - - - [SECURITY CRITICAL] Invokes merge replication between the SQL Server Compact subscription and the SQL Server Publisher. - - - [SECURITY CRITICAL] Specifies the type of data validation SQL Server Compact replication performs while synchronizing. - The constant that specifies the type of data validation to perform. - - - An updateable, scrollable, and bindable cursor. - - - [SECURITY CRITICAL] Do not use. To create a , you must call the method of the . - - - - Creates a new row on the server and returns a object. - A SqlCeUpdatableRecord with the metadata of the pre-populated. - - - Deletes the current record from the data source on the server. - - - Returns the value of the column at the specified index as a Boolean value. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as a byte. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Copies a length of bytes into the buffer, starting at a specified position in the specified field. - The actual number of bytes copied to the buffer. - The ordinal position of the column from which retrieve data. - The offset (in bytes) within the field from which to start copying data. - The buffer into which to copy the data. - The offset within the buffer from which to start the copy. - The maximum number of bytes to copy. - - - Copies a length of chars into the buffer, starting at a specified position in the specified field. - The actual number of chars copied. - The ordinal position of the field from which to retrieve data. - The offset (in chars) within the field from which to start copying. - The buffer into which to copy the data. - The offset within the buffer from which to start the copy. - The maximum number of bytes to copy. - - - Returns the value of the column at the specified index as a DateTime. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as a Double. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as a Double. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns a that can be used to iterate through the rows in the data reader. - A . - - - Returns the value of the column at the specified index as a Float. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as a GUID. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as an Int16. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as an Int32. - The value of the column at the specified index. - TBD - - - Returns the value of the column at the specified index as an Int64. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns an instance of . - A object. - - - Returns the value of the column at the specified index as type SqlBinary. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlBoolean. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlByte. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlDateTime. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlDecimal. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlDouble. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlGuid. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlInt16. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlInt32. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlInt64. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the metadata information associated with the specified column. - The metadata of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlMoney. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlSingle. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type SqlString. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the column at the specified index as type String. - The value of the column at the specified index. - The ordinal position of the column from which to retrieve data. - - - Returns the value of the specified field. - The object that contains the value of the specified field. - The ordinal position of the column from which to retrieve the value. - - - Retrieves an array of all of the fields for the specified record. - The number of instances in the array. - The array of type Object in which to store the values as they are returned. - - - Inserts the specified into the underlying rowset. - The record to insert. - - - Inserts the specified into the underlying rowset and specifies how the cursor is positioned. - The record to insert. - The option to specify how the cursor is positioned after the insert. - - - Determines if the field at the specified ordinal position is null. - True if the specified field is null; otherwise, false. - The ordinal position of the column from which to retrieve the value. - - - Determines if the field at the specified ordinal position is marked to use the underlying default value. - True if the specified field is marked to use the underlying default value; otherwise, false. - The ordinal position of the column from which to retrieve the value. - - - Serves as an indexer for the . - The record at the specified index. - The position of the item in the ResultSet. - - - Serves as an indexer for the . - The record that matches the specified name. - The name of the record in the ResultSet. - - - - Moves the reader to a specific record in the ResultSet. - True if the operation succeeded; otherwise, false. - The position to which to move the reader. - - - Positions the reader at the first record in the ResultSet. - True if the operation succeeded; otherwise, false. - - - Positions the reader at the last record in the ResultSet. - True if the operation succeeded; otherwise, false. - - - Positions the reader at the record pervious to the current record. - True if the operation succeeded; otherwise, false. - - - Moves the reader the specified amount from the current position. - True if the operation succeeded; otherwise, false. - The number of positions to move the reader. - - - Used when data binding a to a control. - A . - - - Determines whether the is scrollable. - True if the is scrollable; otherwise, false. - - - Determines the sensitivity of the . - The for the . - - - Sets the value of the specified column to the passed-in Boolean value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in Byte value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Copies a length of bytes from the specified buffer to the specified column, starting at the specified location within that field. - The ordinal position of the column to set. - The location within the column to which to begin copying the data. - The buffer that contains the data to copy. - The offset within the buffer from which to copy the data. - The maximum number of bytes to copy. - - - Sets the value of the specified column to the passed-in Char value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Copies a length of chars from the specified buffer to the specified column, starting at the specified location within that field. - The ordinal position of the column to set. - The location within the column to which to begin copying the data. - The buffer that contains the data to copy. - The offset within the buffer from which to copy the data. - The maximum number of bytes to copy. - - - Sets the value of the specified column to the passed-in DateTime value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in Decimal value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the specified column to its default value. - The ordinal position of the column to set. - - - Sets the value of the specified column to the passed-in Double value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in Float value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in Guid value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in Int16 value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in Int32 value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in Int64 value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Binds an object to the column at the specified position. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlBinary value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlBoolean value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlByte value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlDateTime value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlDecimal value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlDouble value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlGuid value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlInt16 value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlInt32 value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlInt64 value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlMoney value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlSingle value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in SqlString value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in String value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets the value of the specified column to the passed-in value. - The ordinal position of the column to set. - The value to assign to the specified column. - - - Sets each of the fields in the specified record to the corresponding value in the specified array. - The number of values copied from the array. - The array that contains the values to set. - - - - - - Determines whether values within the can be modified. - True if the values in the record can be modified; otherwise, false; - - - Sends changes from the current record to the underlying row on the server. - - - Provides data for the event. - - - Initializes a new instance of the class. - The sent through an . - The executed when is called. - One of the values that specifies the type of query executed. - The sent through an . - - - Gets the executed when is called. - The executed when is called. - - - Represents the method that will handle the event of a . - The source of the event. - The that contains the event data. - - - Provides data for the event. - - - Initializes a new instance of the class. - The to . - The to execute during . - One of the values that specifies the type of query executed. - The sent through an . - - - Gets or sets the to execute when performing an . - The to execute when performing the . - - - Represents the method that handles the event of a . - The source of the event. - The that contains the event data. - - - Represents an SQL transaction to be made at a data source. This class cannot be inherited. - - - Commits the database transaction. - An error occurred while trying to commit the transaction. - The transaction has already been committed or rolled back.-or- The connection is broken. - - - Commits the database transaction using the specified . - An error occurred while trying to commit the transaction. - The transaction has already been committed or rolled back.-or- The connection is broken. - - - Gets the begin sequence number (BSN) for the transaction. - The BSN for the transaction. - - - Releases all objects associated with the transaction. - - - Specifies the for this transaction. - The for this transaction. The .NET Compact Framework Data Provider for SQL Server Compact supports the ReadCommitted, Serializable, and ReadRepeatable isolation levels. - - - Rolls back a transaction from a pending state. - An error occurred while trying to commit the transaction. - The transaction has already been committed or rolled back.-or- The connection is broken. - - - Gets or sets application-specific context information that is associated by the transaction with tracked operations on a SQL Server Compact database table. - A value that represents application-specific information. - - - The exception thrown when the underlying provider returns an error from a Microsoft SQL Server Compact data source when an operation is attempted while a transaction is in progress. - - - Constructor that helps in serialization. - The serialization information. - The streaming context. - - - [SECURITY CRITICAL] Populates a SerializationInfo with the data needed to serialize the object. - The serialization information. - The streaming context. - - - - - - Represents a row of updatable values from the data source. A object contains one or more UpdatableRecords. - - - Returns the number of fields in the specified record. - The number of fields in the record. - - - Returns the value of the specified field as bool. - The field from which to retrieve a value. - - - Returns the value of the specified field as byte. - The field from which to retrieve a value. - - - Copies a length of bytes into the buffer, starting at a specified position in the specified field. - The ordinal position of the column from which to retrieve data. - The offset (in bytes) within the field from which to start copying data. - The buffer into which to copy the data. - The offset within the buffer from which to start the copy. - The maximum number of bytes to copy. - - - Returns the value of the specified field as char. - The field from which to retrieve a value. - - - Copies a length of chars into the buffer, starting at a specified position in the specified field. - The ordinal position of the field from which to retrieve data. - The offset (in chars) within the field from which to start copying. - The buffer into which to copy the data. - The offset within the buffer from which to start the copy. - The maximum number of bytes to copy. - - - Returns a positioned on the current record. - The field from which to retrieve a value. - - - Returns the datatype name for the specified field. - The field from which to retrieve a value. - - - Returns the value of the specified field as DateTime. - The field from which to retrieve a value. - - - Returns the value of the specified field as decimal. - The field from which to retrieve a value. - - - Returns the value of the specified field as double. - The field from which to retrieve a value. - - - Returns the CLR datatype for the specified field. - The CLR datatype for the field. - The field from which to retrieve a value. - - - Returns the value of the specified field as float. - The field from which to retrieve a value. - - - Returns the value of the specified field as a GUID. - The field from which to retrieve a value. - - - Returns the value of the specified field as int16. - The field from which to retrieve a value. - - - Returns the value of the specified field as int32. - The field from which to retrieve a value. - - - Returns the value of the specified field as int64. - The field from which to retrieve a value. - - - Returns the name of the specified field. - The field from which to retrieve a value. - - - Returns the ordinal for the field specified in the passed-in name. - The name of the field from which to determine the ordinal. - - - Returns the value of the specified field as SqlBinary. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlBoolean. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlByte. - The field from which to retrieve a value. - - - Returns a reference to the SqlBytes instance that contains the value of the specified field. - A reference to a SqlBytes instance. - The field from which to retrieve a value. - - - Returns a reference to the SqlChars instance that contains the value of the specified field. - A reference to a SqlChars instance. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlDateTime. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlDecimal. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlDouble. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlGuid. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlInt16. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlInt32. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlInt64. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlMetaData. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlMoney. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlSingle. - The field from which to retrieve a value. - - - Returns the value of the specified field as SqlString. - The field from which to retrieve a value. - - - Returns the value of the specified field as string. - The field from which to retrieve a value. - - - Returns the value of the specified record. - The field from which to retrieve a value. - - - Returns the values for all of the fields in a record. - The array in which to store the returned values. - - - Returns the number of hidden fields in the record. In SQL Server Compact, this property always returns 0. - Always returns a value of 0. - - - Determines if the specified field is NULL. - True if the field is NULL; otherwise, false. - The field to check. - - - Determines if the specified field is marked to use the underlying default value. - True if the field is marked to use the default value; otherwise, false. - The field to check. - - - Serves as an indexer to a specific field within the record. - The ordinal of the field (column) within the record. - - - Serves as an indexer to a specific field within the record. - The name of the field (column) in the record. - - - Sets the column at the specified index to the passed-in bool value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in byte value. - The field in which to set the value. - The value to set. - - - Copies a length of bytes from the specified buffer to the specified column, starting at the specified location within that field. - The ordinal position of the column to set. - The location within the column to which to begin copying the data. - The buffer that contains the data to copy. - The offset within the buffer from which to copy the data. - The maximum number of bytes to copy. - - - Sets the column at the specified index to the passed-in char value. - The field in which to set the value. - The value to set. - - - Copies a length of chars from the specified buffer to the specified field, starting at the specified location within that field. - The ordinal position of the column to set. - The location within the column to which to begin copying the data. - The buffer that contains the data to copy. - The offset within the buffer from which to copy the data. - The maximum number of bytes to copy. - - - Sets the column at the specified index to the passed-in DateTime value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in decimal value. - The field in which to set the value. - The value to set. - - - Sets the default value for the specified field. - The field to set. - - - Sets the column at the specified index to the passed-in double value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in float value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in GUID value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in int16 value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in int32 value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in int64 value. - The field in which to set the value. - The value to set. - - - Sets the value of the specified field by reference rather than by-value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlBinary value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlBool value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlByte value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlDateTime value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlDecimal value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlDouble value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlGuid value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlInt16 value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlInt32 value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlInt64 value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlMoney value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlSingle value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in SqlString value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in string value. - The field in which to set the value. - The value to set. - - - Sets the column at the specified index to the passed-in value. - The field in which to set the value. - The value to set. - - - Sets each of the fields in the record to the corresponding value in the passed-in array. - The values to set, in the order in which the fields appear in the record. - - - Specifies whether the field is updatable. - True if the field is updatable; otherwise, false. - - - Specifies and retrieves metadata information from parameters and columns retrieved from a database. This class cannot be inherited. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Specifies the type of key used to identify tracking data. - - - This value is reserved for use by the tracking infrastructure. Do not use it in your code. - - - Uniquely identifies rows by using the primary key defined on the table. - - - Uniquely identifies rows by using the global unique identifier column defined on the table. This is a column of uniqueidentifier data type that is defined with the ROWGUIDCOL attribute. - - - This value is reserved for use by the tracking infrastructure. Do not use it in your code. - - - Specifies which operations on a table are tracked. - - - This value is reserved for use by the tracking infrastructure. Do not use it in your code. - - - Track only inserts. - - - Track only updates. - - - Track only deletes. - - - Track all operations. - - - This value is reserved for use by the tracking infrastructure. Do not use it in your code. - - - Specifies the type of data validation to perform. - - - Specifies that validation will not be performed. This is the default setting. - - - Specifies that a row count comparison will be performed on the published data. - - - These options determine the level of database verification to use. - - - Recalculates the checksums for each page in the database and compares the new checksums to the expected values. - - - Performs the same checks as the Default option and verifies index integrity. Checks that each index entry exists in the table and that each table entry exists in the index. This option is slower and more thorough than the Default option. - - - \ No newline at end of file diff --git a/src/UmbracoIdentity.Web/bin/System.Data.SqlServerCe.Entity/System.Data.SqlServerCe.Entity.dll b/src/UmbracoIdentity.Web/bin/System.Data.SqlServerCe.Entity/System.Data.SqlServerCe.Entity.dll deleted file mode 100644 index 2579399e23737dc4b042cd5721e3482857ca2c72..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 240352 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

!?i_`st{jD>Hl_3?Gv>-U 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