Parse 5.0.1

dotnet add package Parse --version 5.0.1
                    
NuGet\Install-Package Parse -Version 5.0.1
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Parse" Version="5.0.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Parse" Version="5.0.1" />
                    
Directory.Packages.props
<PackageReference Include="Parse" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Parse --version 5.0.1
                    
#r "nuget: Parse, 5.0.1"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Parse@5.0.1
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Parse&version=5.0.1
                    
Install as a Cake Addin
#tool nuget:?package=Parse&version=5.0.1
                    
Install as a Cake Tool

parse-repository-header-sdk-dotnet


Build Status Coverage auto-release

.NET Version Nuget

Backers on Open Collective Sponsors on Open Collective Forum Twitter Chat


This library gives you access to the powerful Parse Server backend from your .NET app. For more information on Parse Platform and its features, visit parseplatform.org.


Compatibility

.NET

Parse .NET SDK is continuously tested with the most recent releases of .NET to ensure compatibility. We follow the .NET Long Term Support plan and only test against versions that are officially supported and have not reached their end-of-life date.

.NET Version End-of-Life Parse .NET SDK Version
Standard 2.0 November 2024 >=1.0.0 <4.0.0
6.0 November 2024 >=1.0.0 <5.0.0
7.0 May 2024 >=1.0.0 <5.0.0
8.0 November 2026 >=1.0.0
9.0 May 2026 >=1.0.0

We have removed support for NET Standard 2.0 with Parse .NET SDK 4.0. Xamarin developers should migrate to .NET MAUI to use the latest version of the Parse .NET SDK. Unity developers should use Parse .NET SDK <4.0 until Unity supports .NET and then migrate to the latest version of the Parse .NET SDK.

Using the Code

Make sure you are using the project's root namespace.

using Parse;

The ParseClient class has three constructors, one allowing you to specify your Application ID, Server URI, and .NET Key as well as some configuration items, one for creating clones of ParseClient.Instance if Publicize was called on an instance previously, and another, accepting an IServerConnectionData implementation instance which exposes the data needed for the SDK to connect to a Parse Server instance, like the first constructor, but with a few extra options. You can create your own IServerConnectionData implementation or use the ServerConnectionData struct. IServerConnectionData allows you to expose a value the SDK should use as the master key, as well as some extra request headers if needed.

ParseClient client = new ParseClient("Your Application ID", "The Parse Server Instance Host URI", "Your .NET Key");
ParseClient client = new ParseClient(new ServerConnectionData
{
    ApplicationID = "Your Application ID",
    ServerURI = "The Parse Server Instance Host URI",
    Key = "Your .NET Key", // This is unnecessary if a value for MasterKey is specified.
    MasterKey = "Your Master Key",
    Headers = new Dictionary<string, string>
    {
        ["X-Extra-Header"] = "Some Value"
    }
});

ServerConnectionData is available in the Parse.Infrastructure namespace.

The two non-cloning ParseClient constructors contain optional parameters for an IServiceHub implementation instance and an array of IServiceHubMutators. These should only be used when the behavior of the SDK needs to be changed.

To find full usage instructions for the latest stable release, please visit the [Parse docs website][parse-docs-link]. Please note that the latest stable release is quite old and does not reflect the work being done at the moment.

Common Definitions

  • Application ID: Your app's ApplicationId field from your Parse Server.
  • Key: Your app's .NET Key field from your Parse Server.
  • Master Key: Your app's Master Key field from your Parse Server. Using this key with the SDK will allow it to bypass any CLPs and object permissions that are set. This also should be compatible with read-only master keys as well.
  • Server URI: The full URL to your web-hosted Parse Server.

Client-Side Use

In your program's entry point, instantiate a ParseClient with all the parameters needed to connect to your target Parse Server instance, then call Publicize on it. This will light up the static ParseClient.Instance property with the newly-instantiated ParseClient, so you can perform operations with the SDK.

new ParseClient(/* Parameters */).Publicize();

Server-Side Use

The SDK can be set up in a way such that every new ParseClient instance can authenticate a different user concurrently. This is enabled by an IServiceHubMutator implementation which adds itself as an IServiceHubCloner implementation to the service hub which, making it so that consecutive calls to the cloning ParseClient constructor (the one without parameters) will clone the publicized ParseClient instance, exposed by ParseClient.Instance, replacing the IParseCurrentUserController implementation instance with a fresh one with no caching every time. This allows you to configure the original instance, and have the clones retain the general behaviour, while also allowing the differnt users to be signed into the their respective clones and execute requests concurrently, without causing race conditions. To use this feature of the SDK, the first ParseClient instance must be constructued and publicized as follows once, before any other ParseClient instantiations. Any classes that need to be registered must be done so with the original instance.

new ParseClient(/* Parameters */, default, new ConcurrentUserServiceHubCloner { }).Publicize();

Consecutive instantiations can be done via the cloning constructor for simplicity's sake.

ParseClient client = new ParseClient { };

Basic Demonstration

The following code shows how to use the Parse .NET SDK to create a new user, save and authenticate the user, deauthenticate the user, re-authenticate the user, create an object with permissions that allow only the user to modify it, save the object, update the object, delete the object, and deauthenticate the user once more.

// Instantiate a ParseClient.
ParseClient client = new ParseClient(/* Parameters */);

// Create a user, save it, and authenticate with it.
await client.SignUpAsync(username: "Test", password: "Test");

// Get the authenticated user. This is can also be done with a variable that stores the ParseUser instance before the SignUp overload that accepts a ParseUser is called.
Console.WriteLine(client.GetCurrentUser().SessionToken);

// Deauthenticate the user.
await client.LogOutAsync();

// Authenticate the user.
ParseUser user = await client.LogInAsync(username: "Test", password: "Test");

// Create a new object with permessions that allow only the user to modify it.
ParseObject testObject = new ParseObject("TestClass") { ACL = new ParseACL(user) };

// Bind the ParseObject to the target ParseClient instance. This is unnecessary if Publicize is called on the client.
testObject.Bind(client);

// Set some value on the object.
testObject.Set("someValue", "This is a value.");

// See that the ObjectId of an unsaved object is null;
Console.WriteLine(testObject.ObjectId);

// Save the object to the target Parse Server instance.
await testObject.SaveAsync();

// See that the ObjectId of a saved object is non-null;
Console.WriteLine(testObject.ObjectId);

// Query the object back down from the server to check that it was actually saved.
Console.WriteLine((await client.GetQuery("TestClass").WhereEqualTo("objectId", testObject.ObjectId).FirstAsync()).Get<string>("someValue"));

// Mutate some value on the object.
testObject.Set("someValue", "This is another value.");

// Save the object again.
await testObject.SaveAsync();

// Query the object again to see that the change was made.
Console.WriteLine((await client.GetQuery("TestClass").WhereEqualTo("objectId", testObject.ObjectId).FirstAsync()).Get<string>("someValue"));

// Store the object's objectId so it can be verified that it was deleted later.
var testObjectId = testObject.ObjectId;

// Delete the object.
await testObject.DeleteAsync();

// Check that the object was deleted from the server.
Console.WriteLine(await client.GetQuery("TestClass").WhereEqualTo("objectId", testObjectId).FirstOrDefaultAsync() == null);

// Deauthenticate the user again.
await client.LogOutAsync();

Local Builds

You can build the SDK on any system with the MSBuild or .NET Core CLI installed. Results can be found under either the Release/netstandard2.0 or Debug/netstandard2.0 in the bin folder unless a non-standard build configuration is used.

.NET Core CLI

dotnet build Parse.sln
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 was computed.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • net8.0

    • No dependencies.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on Parse:

Package Downloads
DistributedNetworkTrainingStorageAPI

A wrapper around the Parse API to store and fetch the best updates in a distributed neural network training environment

Parse.AspNet.Identity

Allows you to store and manage your users using the Parse.com cloud backend and Asp.Net Identity for your web application.

Xam.Plugin.Parse

A simple Parse.com plugin for Xamarin.Forms, this allows to perform simple operations such as subscribing or unsubscribing to channels. It uses the Parse component for all three platfoms so this is just an extra layer of abstraction.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last Updated
5.0.1 1,206 3/30/2025
5.0.0 691 3/7/2025
4.0.2 823 2/2/2025
4.0.1 770 12/24/2024
4.0.0 818 12/19/2024
3.0.2 9,266 5/24/2024
3.0.1 971 5/24/2024
3.0.0 991 5/23/2024
2.0.0-develop-1 5,792 6/29/2020
1.7.0 45,638 1/8/2016
1.6.2 8,420 11/20/2015
1.6.1 7,479 10/20/2015
1.6.0 5,164 9/22/2015
1.5.5 6,020 8/19/2015
1.5.4 3,930 8/6/2015
1.5.3 3,955 7/9/2015
1.5.2 4,379 6/10/2015
1.5.1 3,076 6/5/2015
1.5.0 5,639 5/21/2015
1.4.1 6,688 4/9/2015
1.4.0 3,284 3/25/2015
1.3.5 3,270 3/11/2015
1.3.4 3,576 2/12/2015
1.3.3 6,258 1/23/2015
1.3.2 4,368 12/16/2014
1.3.1 4,444 10/16/2014
1.3.0 3,615 9/5/2014
1.2.16 5,298 7/9/2014
1.2.15 3,777 5/30/2014
1.2.14 4,842 2/7/2014
1.2.13 3,096 1/17/2014
1.2.12 2,958 1/7/2014
1.2.11 3,011 12/28/2013
1.2.10 3,372 11/15/2013
1.2.9 3,371 10/4/2013
1.2.8 3,026 9/25/2013
1.2.7 3,168 8/31/2013
1.2.6 3,307 7/31/2013
1.2.5 3,548 6/25/2013
1.2.4 3,176 5/14/2013
1.2.3 3,089 5/3/2013
1.2.2 3,052 5/2/2013
1.2.1 3,238 4/10/2013
1.0.5 4,530 3/14/2013
1.0.4 3,183 1/22/2013
1.0.3 3,436 11/21/2012
1.0.2 3,339 11/15/2012
1.0.1 3,229 11/9/2012
1.0.0 4,089 10/25/2012