Palmalytics.SqlServer
0.2.0-alpha
dotnet add package Palmalytics.SqlServer --version 0.2.0-alpha
NuGet\Install-Package Palmalytics.SqlServer -Version 0.2.0-alpha
<PackageReference Include="Palmalytics.SqlServer" Version="0.2.0-alpha" />
<PackageVersion Include="Palmalytics.SqlServer" Version="0.2.0-alpha" />
<PackageReference Include="Palmalytics.SqlServer" />
paket add Palmalytics.SqlServer --version 0.2.0-alpha
#r "nuget: Palmalytics.SqlServer, 0.2.0-alpha"
#:package Palmalytics.SqlServer@0.2.0-alpha
#addin nuget:?package=Palmalytics.SqlServer&version=0.2.0-alpha&prerelease
#tool nuget:?package=Palmalytics.SqlServer&version=0.2.0-alpha&prerelease
Palmalytics
Palmalytics is a self-hosted, first-party, server-side web analytics dashboard for ASP.NET Core applications. It can replace standard client-side web analytics tools like Google Analytics and Matomo. It tracks pageviews, sessions, referrals, locations, user agents, and more.
Why Server-Side Analytics?
Unlike client-side analytics, server-side analytics offers the following advantages:
- High Performance: Minimal impact on the server side as data is saved asynchronously, and zero impact on the client side.
- User-Friendly: No cookies, no annoying consent popups.
- Accuracy: Not blocked by adblockers and privacy-focused browsers and extensions.
- Data Ownership: You own your data, and it doesn’t leave your server.
The data can be stored in the same database your application already uses (e.g. SQL Server), which means you can also easily query it if you'd like.
Getting Started
Add the storage-specific NuGet package from the Package Manager Console:
PM> Install-Package Palmalytics.SqlServer -Pre
Register services in your
Startup.cs
and configure the SQL Server storage:public void ConfigureServices(IServiceCollection services) { services.AddPalmalytics(options => { options.UseSqlServer(new SqlServerOptions { ConnectionString = Configuration.GetConnectionString("PalmalyticsConnection"), Schema = "Palmalytics" }); }); // ...other services }
Register the middleware:
public void Configure(IApplicationBuilder app) { app.UsePalmalytics(); // ...other middleware }
Navigate to
https://<your-app>/palmalytics
to see your dashboard.
<img src="Assets/Screenshot.webp" alt="Screenshot of the Palmalytics dashboard" />
Dashboard Authorization
By default, the dashboard is only accessible by local requests. In production, you will probably want to change this. Here are some options:
Public access
If you want to allow public access to your dashboard, just remove the default authorization rule:
services.AddPalmalytics(options =>
{
options.DashboardOptions.Authorize = null;
// ... other options
}
Restricted access
You can implement your own authorization rule, for example based on ASP.NET user roles:
services.AddPalmalytics(options =>
{
options.DashboardOptions.Authorize = (context) =>
{
return context.User.IsInRole("Admin");
};
// ... other options
}
Requirements
Currently, Palmalytics requires:
- .NET 6
- SQL Server for storage
Future support is planned for older versions of .NET (including .NET Framework 4.x) as well as other data stores (Postgres, SQLite…).
Project Status
The project is currently in alpha release – use at your own risk.
Licensing
Copyright © 2024 Xavier Poinas
Palmalytics is licensed under the GNU General Public License (GPL v3), which means that if you include it in your project, you will need to release its source code to comply with the terms of the license. If you don’t want to do that, you can obtain a commercial license.
While Palmalytics is in pre-release, you can get a free early-bird lifetime commercial license by emailing licensing@palmalytics.com. This includes free upgrades to all future versions, including major versions.
Contributing
Contributions are welcome, whether they are bug reports, feature requests, or code contributions.
By submitting a pull request, you relinquish any rights or claims to the changes you submit to the project and transfer the copyright of those changes to the project owner.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. 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. |
-
net6.0
- BitFaster.Caching (>= 2.5.1)
- Dapper (>= 2.1.35)
- Dapper.SqlBuilder (>= 2.0.78)
- Microsoft.Data.SqlClient (>= 5.1.1)
- Palmalytics (>= 0.2.0-alpha)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last Updated |
---|---|---|
0.2.0-alpha | 94 | 10/12/2024 |
0.1.0-alpha | 99 | 8/25/2024 |