Programming Tips πŸ’‘
51.7K subscribers
67 photos
10 videos
30 files
354 links
Programming & AI:
Tips πŸ’‘
Articles πŸ“•
Resources πŸ‘Ύ
Design Patterns πŸ’Ž
Software Principles βœ…

πŸ‡³πŸ‡± Contact: @MoienTajik

🎯 Buy ads: https://telega.io/c/ProgrammingTip
Download Telegram
Why I am in love with ES6❓

ES6 brings many new features to vanilla javascript making the language do more with less syntax. πŸ”₯

New features like let and fat arrows let us manage scope very easily too. πŸ™‡πŸ»

Some of ES6 new features πŸ’Ž :
β€’ Fat arrows
β€’ Rest/Spread Operators
β€’ Object Deconstruction
β€’ Default Parameters
β€’ import & export keywords

https://t.me/pgimg/76

[ Article ] : http://bit.do/es6

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #ES6
@ProgrammingTip
Writing middleware for use in Express.js apps πŸ”₯

Overview πŸ”Ž
Middleware functions are functions that have access to the request object (req), the response object (res), and the next function in the application’s request-response cycle.

The next function is a function in the Express router which, when invoked, executes the middleware succeeding the current middleware. ⏭

Middleware can perform πŸ’Ž
β€’ Execute any code.
β€’ Make changes to the request and the response objects.
β€’ End the request-response cycle.
β€’ Call the next middleware in the stack.

πŸ”ΈπŸ”ΉπŸ”ΈπŸ”Ή

Configurable middleware πŸ“₯
If you need your middleware to be configurable, export a function which accepts an options object or other parameters, which, then returns the middleware implementation based on the input parameters.

in my-middleware.js


module.exports = function(options) {
return function(req, res, next) {
// Implement the middleware function
next();
}
}


πŸ”ΈπŸ”ΉπŸ”ΈπŸ”Ή

Usage Middleware πŸ“€
The middleware can now be used as shown below.

const mddleware = require('./my-middleware.js')
app.use(mddleware({ option1: '1', option2: '2' }))


https://t.me/pgimg/77

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #Express #Middleware
@ProgrammingTip
Fluent Validation ⚠️

A small validation library for .NET that uses a fluent interface and lambda expressions for building validation rules. 🚫

NuGet Packages :
Install-Package FluentValidation


For ASP.NET MVC integration :
Install-Package FluentValidation.MVC5


For ASP.NET Core :
Install-Package FluentValidation.AspNetCore


πŸ”ΉπŸ”ΈπŸ”ΉπŸ”Έ

Example :

public class PersonValidator : AbstractValidator<Person>
{
public PersonValidator()
{
RuleFor(x => x.ID).NotEmpty();

RuleFor(x => x.FirstName)
.NotEmpty()
.WithMessage("{PropertyName} is required !")
.MinimumLength(5)
.WithMessage("Minimum length for {PropertyName} is {MinLength} !");

RuleFor(x => x.LastName)
.NotEmpty()
.WithMessage("{PropertyName} is required !")
.MinimumLength(5)
.WithMessage("Minimum length for {PropertyName} is {MinLength} !");

RuleFor(x => x.Email)
.NotEmpty()
.WithMessage("{PropertyName} is required !")
.EmailAddress()
.WithMessage("{PropertyName} is not valid !");
}
}


πŸ”ΉπŸ”ΈπŸ”ΉπŸ”Έ

https://t.me/pgimg/78

[ Github ] : http://bit.do/flval

γ€°γ€°γ€°γ€°γ€°γ€°
#CSharp #AspMvc #Validation
@ProgrammingTip
Polly πŸ•Š

Polly is a .NET resilience and transient-fault-handling library that allows developers to express policies such as Retry, Circuit Breaker, Timeout, Bulkhead Isolation, and Fallback in a fluent and thread-safe manner. ♻️


Installing via NuGet πŸ—ƒ :
Install-Package Polly


Usage :
public class Mailer
{
public static bool SendEmail()
{
Console.WriteLine("Sending Mail ...");

// simulate error
Random rnd = new Random();
var rndNumber = rnd.Next(1, 10);
if (rndNumber != 3)
throw new SmtpFailedRecipientException();

Console.WriteLine("Mail Sent successfully");
return true;
}
}


We retry to send the email 3 times if something failed ❌ :

var policy = Policy.Handle<SmtpFailedRecipientException>().Retry(3);
policy.Execute(Mailer.SendEmail);


πŸ”ΉπŸ”ΈπŸ”ΉπŸ”Έ

https://t.me/pgimg/79

[ Github ] : http://bit.do/pollyc

γ€°γ€°γ€°γ€°γ€°γ€°
#CSharp #RetryPattern
@ProgrammingTip
Keyv πŸ—‚

Keyv provides a consistent interface for key-value storage across multiple backends via storage adapters. ⚑️

It supports TTL based expiry, making it suitable as a cache or a persistent key-value store. ⏰

By default everything is stored in memory, you can optionally also install a storage adapter. πŸ—„

Supported Storage Adapters βœ… :
β€’ Redis
β€’ Mongo
β€’ SQLite
β€’ Postgres
β€’ MySQL

https://t.me/pgimg/80

[ Website ] : http://bit.do/keyv

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #KeyValue #Storage
@ProgrammingTip
JavaScript - Map vs. ForEach πŸ—Ί

What’s the difference between Map and ForEach in JavaScript❓

Let’s first take a look at the definitions on MDN πŸŒ€ :
β€’ forEach() βž– executes a provided function once for each array element.

β€’ map() βž– creates a new array with the results of calling a provided function on every element in the calling array.

What exactly does this mean❔

https://t.me/pgimg/81

[ Article ] : http://bit.do/mapjs

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #ForEach #Map
@ProgrammingTip
dbForge Event Profiler ⚑️

dbForge Event Profiler for SQL Server is a FREE tool that allows you to capture and analyze SQL Server events. ☁️

The events and data columns are stored in a physical trace file for later examination. πŸ“‹

You can use this information to identify and troubleshoot many SQL Server-related problems. 🐞

https://t.me/pgimg/83

[ Download ] : https://t.me/pgimg/84
[ Website ] : http://bit.do/dbfor

γ€°γ€°γ€°γ€°γ€°γ€°
#SQLServer #Profiler #DbForge
@ProgrammingTip
Passport.Js ⚑️

Passport is authentication middleware for Node.js.

Extremely flexible and modular, Passport can be unobtrusively dropped in to any Express-based web application. πŸ”₯

A comprehensive set of strategies support authentication using a username and password, Facebook, Twitter, and more. 🐦

https://t.me/pgimg/85

[ Website ] : passportjs.org

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #NodeJs #Authentication
@ProgrammingTip
Writing CV πŸ˜‚
γ€°γ€°γ€°γ€°γ€°γ€°
#Fun #NoSQL
@ProgrammingTip
Xamarin VS Ionic VS React Native πŸ”₯

Traditionally, Android applications are developed in Java, and iOS ones are written in Swift and Objective-C. βš›οΈ

Nevertheless, there exist plenty of other alternate tools that can be used instead. πŸ‘¨πŸ»β€πŸ’»

Xamarin, React Native and Ionic are popular examples of such tools. πŸ’Ž

What is their purpose❓
What makes them different❓
Which of them is the best❓

We’ll try to answer these questions in the article below. ⬇️

https://t.me/pgimg/86

[ Article ] : http://bit.do/cpfo

γ€°γ€°γ€°γ€°γ€°γ€°
#Xamarin #ReactNative #Ionic
@ProgrammingTip
Quick Tip: How to pass visual alerts with an HTMLHelper⚠️

It will display a Bootstrap alert if there is a message passed through the ViewModel. πŸ’₯

This message can be a success, error, warning, or informational message. 🌈

The nice thing about the ViewMessage HtmlHelper is that if we don't pass it into our views, it won't display anything. πŸŽ›

https://t.me/pgimg/87

[ Article ] : http://bit.do/alhl

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #CleanCode
@ProgrammingTip
Send ETag headers in ASP.NET Core ✨

ASP.NET Core doesn’t add an ETag header automatically to HTTP responses from MVC action methods or Razor Pages. ❌

We have to implement that ourselves to provide the users with true Conditional GET support that honors the If-None-Match request header. βœ…

Wouldn’t it be nice if all we had to do was to register it using app.UseETagger() like this❓

https://t.me/pgimg/88

[ Article ] : http://bit.do/etags

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #AspCore #ETag
@ProgrammingTip
Automatic ModelState Validation in ASP.NET MVC πŸ”₯

How many times have you seen or written code like this ♻️ :

[HttpPost]
public ActionResult Index(SomeModel model)
{
if (ModelState.IsValid)
{
return View();
}

// do something
return RedirectToAction("index");
}


Stop repeating ModelState checks in your ASP.NET MVC controller actions. ❌

Wouldn’t it be nice if all we had to do was like this ? ⚑️

[HttpPost]
[ValidateModelState]
public ActionResult Index(SomeModel model)
{
// if we get here, ModelState is valid
// save to db etc.
return RedirectToAction("index");
}


https://t.me/pgimg/89

[ Article ] : http://bit.do/msta

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #CleanCode
@ProgrammingTip
The state of JavaScript in 2017 πŸ”₯

A few years back, a JavaScript survey would've been a simple matter.

Question 1 :
Are you using jQuery❓

Question 2 :
Any comments❓Boom, done❗️

But as we all know, things have changed. ✨

The JavaScript ecosystem is richer than ever, and even the most experienced developer can start to hesitate when considering the multitude of options available at every stage.

There's data from over 20,000 developers, asking them questions on topics ranging from front-end frameworks and state management, to build tools and testing libraries. βœ…

https://t.me/pgimg/90

[ Website ] : https://stateofjs.com

γ€°γ€°γ€°γ€°γ€°γ€°
#JavaScript #Analytics
@ProgrammingTip
How we do MVC – View models πŸ‘€

The ViewModel is a central aspect of our MVC architecture. 🌞

One of the first dilemmas facing MVC developers is to decide what the β€œM” in MVC means in ASP.NET MVC. πŸ€”

In Rails, this is fairly clear, the M is ActiveRecord (by default). 🌍

But in ASP.NET MVC, the β€œM” is silent❗️

Its out-of-the-box architecture offers no guidelines nor advice on what the M should be. βš™οΈ

Should it be an entity❓
Data access object❔
DTO❓
Something else❔

https://t.me/pgimg/91

[ Website ] : http://bit.do/mvvm

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #CleanCode #BestPractices
@ProgrammingTip
Working With Zip Files In ASP.NET MVC πŸ—‚

Since ASP.NET 4.5, zipping and unzipping files can be done with classes from within the .NET framework. πŸ“‚

Despite that, nearly all examples that illustrate working with zip files in ASP.NET applications feature third party open source compression libraries. πŸ‘Ύ

This short article attempts to correct that by demonstrating the use of the System.IO.Compression classes in an ASP.NET MVC application to βœ… :
1️⃣ Unpack an uploaded zip file
2️⃣ Create one for download

https://t.me/pgimg/92

[ Article ] : http://bit.do/aspzip

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Compression
@ProgrammingTip
ASP.NET MVC Best Practices and Guidelines βœ…

While most developers were used to WebForms and Microsoft's stock controls, when developers moved to ASP.NET MVC, a number of developers were shocked because there wasn't enough meat for this to be a full-featured release. πŸ€“

Some of the guidelines list below are based on my own experiences over the years since 2008. πŸ“†

https://t.me/pgimg/93

[ Website ] : http://bit.do/aspbst

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #CleanCode #BestPractices
@ProgrammingTip
Auth0: Introduction and Initial ASP.NET MVC Project Setup πŸš€

The big selling points for Auth0, and other services like it, are that it removes you from having to worry about Auth/User Management and get to the part of your applications that bring value to your customers. πŸ‘₯

As with Identity Server, Auth0 can use OpenID Connect (as well as a lot of other protocols), single sign-on and API Access Control. βœ…

https://t.me/pgimg/94

[ Article ] : http://bit.do/auas

γ€°γ€°γ€°γ€°γ€°γ€°
#AspMvc #Auth0 #Authentication
@ProgrammingTip
Google it πŸ˜‚πŸ€¦β€β™‚οΈ

γ€°γ€°γ€°γ€°γ€°γ€°
#Fun
@ProgrammingTip
Architecting Services with Design Patterns πŸ’Ž

As the number of your services expands you're going to need to start thinking about how to organize them. πŸ—‚

Applying these two design patterns can help, provided you understand all their variations. βœ…

With the current set of tools that come with the Microsoft .NET Framework, it's easy to create a service. βš™οΈ

But it's also easy to create what both Nayaki Nayyar and Benjamin Moreland described as a "junk drawer of services." πŸ‘Ύ

If you're going to avoid that as the number of services in your organization increases, then you need to think about your architecture. πŸ€”

https://t.me/pgimg/95

[ Article ] : http://bit.do/asdp

γ€°γ€°γ€°γ€°γ€°γ€°
#CleanCode #DesignPatterns
@ProgrammingTip