Practikal.Base
0.1.1
The owner has unlisted this package.
This could mean that the package is deprecated, has security vulnerabilities or shouldn't be used anymore.
dotnet add package Practikal.Base --version 0.1.1
NuGet\Install-Package Practikal.Base -Version 0.1.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="Practikal.Base" Version="0.1.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Practikal.Base --version 0.1.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Practikal.Base, 0.1.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.
// Install Practikal.Base as a Cake Addin
#addin nuget:?package=Practikal.Base&version=0.1.1
// Install Practikal.Base as a Cake Tool
#tool nuget:?package=Practikal.Base&version=0.1.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Practikal.Base
Functional library which contains a useful set of functions for building small-size/mid-size web applications.
Goals
The library is built targeting some goals:
- provide essential functions for building modern web applications.
- 0 dependencies - 3rd party framework and library agnostic excepting Newtonsoft.Json.
- functions are written following functional programming principles (immutability - immutable states, purity - pure functions, composability - partial-applications, high-order functions).
- each module is completely independent and does not refer any other library module (excepting migrations).
- functions should be as simple as possible.
- FP on/off OOP.
Description
The library contains functions for:
- exceptions handling.
- serializing data.
- validating data.
- files handling.
- identities handling.
- migrations handling.
Install
dotnet add package Practikal.Base
Exceptions handling
Functions for:
- getting user message.
- getting technical message.
Simple logging calls:
open System
open Practikal
getUserMessage(new Exception('user:message')) // output: message
getUserMessage(new Exception('message')) // output: System failure.
getTechnicalMessage(new Exception('message')) // output: message
getTechnicalMessage(new Exception('user:message')) // output: user:message
Serialization
Functions for:
- serializing data.
- deserializing data;
open Practikal
type Record = {
Field1: string;
Field2: int;
}
Some { Field1 = "abc"; Field2 = 123 }
|> serialize
|> deserialize<Record>
// output: Some { Field1 = "abc"; Field2 = 123; }
Validation
Functions for:
- validating data.
open Practikal
open System.ComponentModel.DataAnnotations
type Validation = {
[<Required>] Field1: string;
[<Required>] Field2: string;
}
validate { Field1 = input1; Field2 = input2 }
// output: Success { Field1 = input1; Field2 = input2; }
validate { Field1 = null; Field2 = input2 }
// output: Failure "user:The Field1 field is required."
Files
Functions for:
- reading files from folder.
- reading files from assembly (embedded files).
- finding folder files.
- finding embedded assembly files.
open System.Reflection
open System.IO
open Practikal
open Practikal.Files
let pattern = "File\S*(1|2).txt""
pattern |> findEmbeddedFiles (Assembly.GetExecutingAssembly())
pattern |> findFolderFiles (Directory.GetCurrentDirectory())
pattern |> readEmbeddedFiles (Assembly.GetExecutingAssembly())
pattern |> readFolderFiles (Directory.GetCurrentDirectory())
Identity
Functions for:
- set current principal.
- get current principal.
- set user id, user name, full name, role, authentication type for principal.
- get user id, user name, full name, is in role, is authenticated for current principal.
open Practikal
{ UserId = 0; UserName = ""; FullName = ""; Role = ""; AuthenticationType = "" }
|> setUserId 123
|> setUserName "username"
|> setFullName "fullname"
|> setRole "role"
|> setAuthenticationType "authtype"
|> setCurrentPrincipal
getUserId() // output: 123
getUserName() // output: "username"
getFullName() // output: "fullname"
isInRole "role" // output: true
isAuthenticated() // output: true
Migrations
Functions for:
- apply migrations from folder.
- apply migrations from assembly.
- ensure database.
- change connection string.
Implement a very basic Entity Framework Core migrations capabilities.
open Practikal
open Practikal.Migrations
open Practikal.Files
// ensure database
let execSqlFiles (files: ReadFile list) = Success true
MigrationAssembly (Assembly.GetExecutingAssembly())
|> ensureDatabase execSqlFiles <| "CreateDatabase.sql"
|> ignore
// apply migrations
let execSql (content: string) = ignore()
let noFilter x = true
MigrationAssembly (Assembly.GetExecutingAssembly())
|> applyMigrations execSql noFilter <| "Migration.*.sql"
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
.NETStandard 2.0
- FSharp.Core (>= 4.5.2)
- Newtonsoft.Json (>= 11.0.2)
- System.ComponentModel.Annotations (>= 4.5.0)
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 |
---|