π Challenge: Create a compact Maze Game in C# under 2KB without .NET Runtime, Small enough to fit in a QR Code π€
π¨βπ» Process:
β’ Self-Contained: Includes all necessary components to run on any OS.βοΈ
β’ Game Type: A graphical maze, utilizing Win32 APIs, avoiding WinForms.βοΈ
β’ Size Reduction Steps:
1- Initial Size: 64MB (with CoreCLR)
2- Post-Compression: 35.2MB
3- IL Trimming Applied: 10MB
4- Native AOT Compilation: 1.13MB
5- Removing Unused Features: 923KB
6- Using bflat Compiler: 882KB
7- bflat with Zerolib: 9KB
8- Direct PInvoke: 8KB
9- Eliminating Debugging and Relocations: 7KB
10- Targeting x86 Architecture: 6.5KB
11- Final Step with Crinkler Linker: 1,936 Bytes
π Outcome: Achieved a C# game small enough to fit in a QR code!
[ Full Article π ] : https://migeel.sk/blog/2024/01/02/building-a-self-contained-game-in-csharp-under-2-kilobytes
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#CSharp #DotNet #Optimization #LowLevel
@ProgrammingTip
β’ Self-Contained: Includes all necessary components to run on any OS.
β’ Game Type: A graphical maze, utilizing Win32 APIs, avoiding WinForms.
β’ Size Reduction Steps:
1- Initial Size: 64MB (with CoreCLR)
2- Post-Compression: 35.2MB
3- IL Trimming Applied: 10MB
4- Native AOT Compilation: 1.13MB
5- Removing Unused Features: 923KB
6- Using bflat Compiler: 882KB
7- bflat with Zerolib: 9KB
8- Direct PInvoke: 8KB
9- Eliminating Debugging and Relocations: 7KB
10- Targeting x86 Architecture: 6.5KB
11- Final Step with Crinkler Linker: 1,936 Bytes
π Outcome: Achieved a C# game small enough to fit in a QR code!
[ Full Article π ] : https://migeel.sk/blog/2024/01/02/building-a-self-contained-game-in-csharp-under-2-kilobytes
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#CSharp #DotNet #Optimization #LowLevel
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
This media is not supported in your browser
VIEW IN TELEGRAM
MeiliSearch: The Fast, Open-Source Search Engine ππ
MeiliSearch is a powerful, open-source search engine written in Rust. Designed for speed and ease of use, it's the perfect choice for developers looking to implement search capabilities in their applications. π
Key Features:
β’ Lightning-fast search responses β‘οΈ
β’ Typo-tolerance for better user experience βοΈ
β’ Simple to set up and integrate π
β’ Customizable ranking rules for tailored search results π§
β’ Open-source and fully documented π
[ GitHub ] : https://github.com/meilisearch/meilisearch
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#MeiliSearch #SearchEngine
@ProgrammingTip
MeiliSearch is a powerful, open-source search engine written in Rust. Designed for speed and ease of use, it's the perfect choice for developers looking to implement search capabilities in their applications. π
Key Features:
β’ Lightning-fast search responses β‘οΈ
β’ Typo-tolerance for better user experience βοΈ
β’ Simple to set up and integrate π
β’ Customizable ranking rules for tailored search results π§
β’ Open-source and fully documented π
[ GitHub ] : https://github.com/meilisearch/meilisearch
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#MeiliSearch #SearchEngine
@ProgrammingTip
Spotube πΈ
Open source Spotify client that doesn't require Premium nor uses Electron! Available for both desktop & mobile! π§
FeaturesβοΈ :
β’ π« No ads
β’ β¬οΈ Downloadable tracks
β’ π₯ π± Cross-platform support
β’ πͺΆ Small size & less data usage
β’ π΅οΈ Anonymous/guest login
β’ π Time synced lyrics
β’ β No telemetry, diagnostics or user data collection
β’ π Native performance
β’ π Open source/libre software
β’ π Playback control is done locally, not on the server
[ GitHub ] : https://github.com/KRTirtho/spotube
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#OpenSource #Spotify
@ProgrammingTip
Open source Spotify client that doesn't require Premium nor uses Electron! Available for both desktop & mobile! π§
Features
β’ π« No ads
β’ β¬οΈ Downloadable tracks
β’ π₯ π± Cross-platform support
β’ πͺΆ Small size & less data usage
β’ π΅οΈ Anonymous/guest login
β’ π Time synced lyrics
β’ β No telemetry, diagnostics or user data collection
β’ π Native performance
β’ π Open source/libre software
β’ π Playback control is done locally, not on the server
[ GitHub ] : https://github.com/KRTirtho/spotube
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#OpenSource #Spotify
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
The ultimate guide for making the best career choices in Tech π§π»βπ»
Denilson Nastacio shares a structured framework for career success, likening it to Maslow's Hierarchy of Needs. He highlights the importance of aligning one's career with personal values and market demands, offering insights into the tech industry's evolving landscape.βοΈ
Key Takeawaysπ :
β’ Employability is foundational, emphasizing education, skills, and market relevance.
β’ Compensation & Stability ensure job adequacy and a supportive environment.
β’ Growth & Development demand continuous learning and skill enhancement.
β’ Work-Life Balance & Well-Being focus on mental and physical health.
β’ Purpose & Meaning represent the pinnacle, aligning personal values with professional careers.
[ Article ] : https://medium.com/@dnastacio/c18768d32598
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Tech #CareerPath #Growth
@ProgrammingTip
Denilson Nastacio shares a structured framework for career success, likening it to Maslow's Hierarchy of Needs. He highlights the importance of aligning one's career with personal values and market demands, offering insights into the tech industry's evolving landscape.
Key Takeaways
β’ Employability is foundational, emphasizing education, skills, and market relevance.
β’ Compensation & Stability ensure job adequacy and a supportive environment.
β’ Growth & Development demand continuous learning and skill enhancement.
β’ Work-Life Balance & Well-Being focus on mental and physical health.
β’ Purpose & Meaning represent the pinnacle, aligning personal values with professional careers.
[ Article ] : https://medium.com/@dnastacio/c18768d32598
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Tech #CareerPath #Growth
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
Browserless | Headless browser automation, without the hosting headaches π
Browserless allows remote clients to connect and execute headless work, all inside of docker. It supports the standard, unforked Puppeteer and Playwright libraries, as well offering REST-based APIs for common actions like data collection, PDF generation and more.β
Sample π:
[ GitHub ] : https://github.com/browserless/browserless
[ Website ] : https://www.browserless.io
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#E2E #Testing #Browserless #Docker
@ProgrammingTip
Browserless allows remote clients to connect and execute headless work, all inside of docker. It supports the standard, unforked Puppeteer and Playwright libraries, as well offering REST-based APIs for common actions like data collection, PDF generation and more.
Sample π:
import puppeteer from "puppeteer";
// Try changing this! π
const URL = "https://t.me/s/ProgrammingTip";
const main = async () => {
const browser = await puppeteer.connect({
browserWSEndpoint: `wss://chrome.browserless.io`,
});
const page = await browser.newPage();
await page.goto(URL);
return page.screenshot();
}
[ GitHub ] : https://github.com/browserless/browserless
[ Website ] : https://www.browserless.io
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#E2E #Testing #Browserless #Docker
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
Vuestic Admin 3.0 π
Vuestic Admin is an open-source admin template based on Vue 3, Vite, Pinia, and Tailwind CSS, developed and supported by the Epicmax Team. Itβs no longer just a collection of components; now, itβs packed with engaging, interactive pages designed to enhance your projects. π
What pages do developers most often need? Dashboard, Settings Page, Profile, User and Project List, Login, Billing, Pricing Plans β they are all already in Vuestic Admin.βοΈ
Features π§:
β’ Vue 3, Vite, Pinia, and Tailwind CSS - Fast and efficient development
β’ Dark Theme - Modern and eye-catching
β’ Global Configuration - Effortless customization
β’ Accessibility - Inclusive and user-friendly
β’ i18n Integration - Easy localization for global reach
β’ Educational Resource - Ideal for learning and improving skills
β’ Responsive Design - Adapts seamlessly to all devices
β’ Professional Support - Reliable help from the experts
β’ Highly Customizable - Tailor to your projectβs style
[ Live Demo ] : https://admin.vuestic.dev
[ GitHub ] : https://github.com/epicmaxco/vuestic-admin
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Vue #Vuestic #AdminPanel #Dashboard
@ProgrammingTip
Vuestic Admin is an open-source admin template based on Vue 3, Vite, Pinia, and Tailwind CSS, developed and supported by the Epicmax Team. Itβs no longer just a collection of components; now, itβs packed with engaging, interactive pages designed to enhance your projects. π
What pages do developers most often need? Dashboard, Settings Page, Profile, User and Project List, Login, Billing, Pricing Plans β they are all already in Vuestic Admin.
Features π§:
β’ Vue 3, Vite, Pinia, and Tailwind CSS - Fast and efficient development
β’ Dark Theme - Modern and eye-catching
β’ Global Configuration - Effortless customization
β’ Accessibility - Inclusive and user-friendly
β’ i18n Integration - Easy localization for global reach
β’ Educational Resource - Ideal for learning and improving skills
β’ Responsive Design - Adapts seamlessly to all devices
β’ Professional Support - Reliable help from the experts
β’ Highly Customizable - Tailor to your projectβs style
[ Live Demo ] : https://admin.vuestic.dev
[ GitHub ] : https://github.com/epicmaxco/vuestic-admin
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Vue #Vuestic #AdminPanel #Dashboard
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
Bloom Filters π
Imagine ensuring web safety by identifying malicious links without storing massive data. Traditional methods involve keeping a huge list of bad links, consuming substantial storage and bandwidth. Enter Bloom Filters - a genius method allowing us to significantly reduce storage needs (up to 82% smaller) with a minimal error rate. πΎ
For instance, instead of a 20MB list for 1,000,000 links, a Bloom Filter achieves this with just 3.59MB, accepting a tiny error chance (0.0001%). Even more impressive, with a 0.1% error tolerance, the size shrinks to 1.8MB. This technique was even utilized by Google Chrome until 2012.βοΈ
Bloom Filters offer a balance between efficiency and accuracy. For critical checks, it pairs with a database API for zero false positives. A practical, space-saving solution for modern web browsers!β‘οΈ
[ Article ] : https://samwho.dev/bloom-filters
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Algorithm #BloomFilters
@ProgrammingTip
Imagine ensuring web safety by identifying malicious links without storing massive data. Traditional methods involve keeping a huge list of bad links, consuming substantial storage and bandwidth. Enter Bloom Filters - a genius method allowing us to significantly reduce storage needs (up to 82% smaller) with a minimal error rate. πΎ
For instance, instead of a 20MB list for 1,000,000 links, a Bloom Filter achieves this with just 3.59MB, accepting a tiny error chance (0.0001%). Even more impressive, with a 0.1% error tolerance, the size shrinks to 1.8MB. This technique was even utilized by Google Chrome until 2012.
Bloom Filters offer a balance between efficiency and accuracy. For critical checks, it pairs with a database API for zero false positives. A practical, space-saving solution for modern web browsers!
[ Article ] : https://samwho.dev/bloom-filters
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Algorithm #BloomFilters
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
Amazon Interview Questions: The Ultimate Preparation Guide π
Getting an interview at Amazon is a major accomplishment. With thousands of applicants every year and intense competition, securing an interview slot is an achievement in itself. Now you need to put in the work to make sure you ace the interview process.βοΈ
In this comprehensive guide, we will cover everything you need to know to crush your Amazon interviews.β‘οΈ
[ Article ] : https://www.designgurus.io/blog/amazon-interview-questions-guide
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Interview #Amazon
@ProgrammingTip
Getting an interview at Amazon is a major accomplishment. With thousands of applicants every year and intense competition, securing an interview slot is an achievement in itself. Now you need to put in the work to make sure you ace the interview process.
In this comprehensive guide, we will cover everything you need to know to crush your Amazon interviews.
[ Article ] : https://www.designgurus.io/blog/amazon-interview-questions-guide
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Interview #Amazon
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
Introducing WireMock.NET: Master HTTP API Testing π
WireMock.NET simulates HTTP API behaviors, enabling seamless integration and testing for developers.
π Ideal Use Cases:
β’ HTTP Dependencies Not Ready: Leap over the hurdle of incomplete HTTP APIs in microservice architectures by mimicking their behavior with WireMock.Net.
β’ Unit Testing HTTP-Dependent Classes: Test classes that rely on HTTP APIs as a cohesive unit, ensuring your code communicates effectively with the actual APIs.
β’ Integration/End-to-End Tests: Overcome the challenges of testing with external HTTP APIsβlike variable data, slow responses, and network restrictionsβby employing WireMock.Net for consistent and swift testing.
[ GitHub ] : https://github.com/WireMock-Net/WireMock.Net
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#DotNet #WireMock #IntegrationTest
@ProgrammingTip
WireMock.NET simulates HTTP API behaviors, enabling seamless integration and testing for developers.
π Ideal Use Cases:
β’ HTTP Dependencies Not Ready: Leap over the hurdle of incomplete HTTP APIs in microservice architectures by mimicking their behavior with WireMock.Net.
β’ Unit Testing HTTP-Dependent Classes: Test classes that rely on HTTP APIs as a cohesive unit, ensuring your code communicates effectively with the actual APIs.
β’ Integration/End-to-End Tests: Overcome the challenges of testing with external HTTP APIsβlike variable data, slow responses, and network restrictionsβby employing WireMock.Net for consistent and swift testing.
public class ExternalService(HttpClient httpClient)
{
public async Task<string> GetAsync()
{
var response = await httpClient.GetAsync("/ping");
response.EnsureSuccessStatusCode();
return await response.Content.ReadAsStringAsync();
}
}
public class ExternalServiceTests
{
[Fact]
public async Task GetAsync_WhenCalled_ReturnsString()
{
// Arrange
var fakeServer = WireMockServer.Start();
fakeServer
.Given(Request.Create().WithPath("/ping").UsingGet())
.RespondWith(Response.Create()
.WithStatusCode(200)
.WithBody("pong")
);
var fakeClient = fakeServer.CreateClient();
var externalService = new ExternalService(fakeClient);
// Act
var response = await externalService.GetAsync();
// Assert
response.Should().Be("pong");
}
}
[ GitHub ] : https://github.com/WireMock-Net/WireMock.Net
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#DotNet #WireMock #IntegrationTest
@ProgrammingTip
Telegram
Programming Tips Resources
Embarking on Your Cloud Certification Journey in 2024: A Guide to Azure Certifications π π₯
β’ An overview of the certification options available.
β’ Introduction to the new open-book policy.
β’ Recommendations for courses based on firsthand experience with these exams.
β’ Essential tips for the exam day and the preparation leading up to it.
[ YouTube ] : https://www.youtube.com/watch?v=d59nAwmdoLk
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Azure #CareerDevelopment #MicrosoftAzure #CloudCertification
@ProgrammingTip
β’ An overview of the certification options available.
β’ Introduction to the new open-book policy.
β’ Recommendations for courses based on firsthand experience with these exams.
β’ Essential tips for the exam day and the preparation leading up to it.
[ YouTube ] : https://www.youtube.com/watch?v=d59nAwmdoLk
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Azure #CareerDevelopment #MicrosoftAzure #CloudCertification
@ProgrammingTip
YouTube
How To Pass ANY Azure Certification in 2024 | Complete Guide
As 2023 winds to a close, you may want to consider 2024 to be the year that you get your first Cloud certification or add another certification to your resume.
And while Azure is not quite as popular as AWS, itβs right behind it and is used by many companiesβ¦
And while Azure is not quite as popular as AWS, itβs right behind it and is used by many companiesβ¦
πReady to Track Your Application with Metrics? π
Looking to keep a close eye on your ASP.NET Core applications? With the latest update in .NET 8, you can now easily track various aspects of your application's performance and health through built-in metrics.
Here's why it's exciting:
β’ HTTP Request Insights: Get a detailed view of your HTTP requests, including counts, durations, and more.
β’ Real-time Alerts: Set up alerts to notify you if your app's performance exceeds predefined thresholds.
β’ Error Handling Diagnostics: Pinpoint and address issues faster with detailed error handling diagnostics.
β’User-friendly .NET Aspire Dashboards: Access a user-friendly dashboard through .NET Aspire, making it easy to visualize and understand your app's metrics.
β’ Customizable Grafana Dashboards: Dive deep into your app's performance with customizable Grafana dashboards, tailored specifically for ASP.NET Core metrics
Excited to learn more? Dive into the details and revolutionize your app monitoring experience! π»π‘
[ Article ] : https://devblogs.microsoft.com/dotnet/introducing-aspnetcore-metrics-and-grafana-dashboards-in-dotnet-8/
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#DotNet #Metrics #Grafana #Dotnet_Aspire #Monitoring
@ProgrammingTip
Looking to keep a close eye on your ASP.NET Core applications? With the latest update in .NET 8, you can now easily track various aspects of your application's performance and health through built-in metrics.
Here's why it's exciting:
β’ HTTP Request Insights: Get a detailed view of your HTTP requests, including counts, durations, and more.
β’ Real-time Alerts: Set up alerts to notify you if your app's performance exceeds predefined thresholds.
β’ Error Handling Diagnostics: Pinpoint and address issues faster with detailed error handling diagnostics.
β’User-friendly .NET Aspire Dashboards: Access a user-friendly dashboard through .NET Aspire, making it easy to visualize and understand your app's metrics.
β’ Customizable Grafana Dashboards: Dive deep into your app's performance with customizable Grafana dashboards, tailored specifically for ASP.NET Core metrics
Excited to learn more? Dive into the details and revolutionize your app monitoring experience! π»π‘
[ Article ] : https://devblogs.microsoft.com/dotnet/introducing-aspnetcore-metrics-and-grafana-dashboards-in-dotnet-8/
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#DotNet #Metrics #Grafana #Dotnet_Aspire #Monitoring
@ProgrammingTip
Telegram
Programming Tips Resources
Algorithm Series ππ
Name: Bubble Sort
Type: Comparison sort
Best For: Small datasets
Complexity: O(nΒ²) average and worst-case
How It Works: Repeatedly steps through the list, compares adjacent elements, and swaps them if they are in the wrong order. The pass through the list is repeated until the list is sorted.
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Algorithm #BubbleSort
@ProgrammingTip
Name: Bubble Sort
Type: Comparison sort
Best For: Small datasets
Complexity: O(nΒ²) average and worst-case
How It Works: Repeatedly steps through the list, compares adjacent elements, and swaps them if they are in the wrong order. The pass through the list is repeated until the list is sorted.
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Algorithm #BubbleSort
@ProgrammingTip
Telegram
Programming Tips Resources
The guide to Git I never had π―
Understanding Git is crucial for any developer. Often overlooked in CVs, mastering Git's capabilities enhances your coding proficiency significantly. This guide covers everything from basic commands to advanced techniques, ensuring you can manage and track your code effectively. βοΈ
In this comprehensive guide, we delve into branches, commits, merging, rebasing, and more to help you master this essential tool. β‘οΈ
[ Article ]: https://medium.com/@jake.page91/the-guide-to-git-i-never-had-a89048d4703a
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Git #VersionControl
@ProgrammingTip
Understanding Git is crucial for any developer. Often overlooked in CVs, mastering Git's capabilities enhances your coding proficiency significantly. This guide covers everything from basic commands to advanced techniques, ensuring you can manage and track your code effectively. βοΈ
In this comprehensive guide, we delve into branches, commits, merging, rebasing, and more to help you master this essential tool. β‘οΈ
[ Article ]: https://medium.com/@jake.page91/the-guide-to-git-i-never-had-a89048d4703a
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Git #VersionControl
@ProgrammingTip
Telegram
Programming Tips Resources
5 Rules for Writing Better and Cleaner DTOs π§Ή
Crafting clean and maintainable DTOs is essential for keeping your codebase healthy and scalable. But let's face it, sometimes DTOs can morph into these complex beasts that leave you scratching your head. β
Fear not, fellow developers!
This article (or the accompanying video!) dives into 5 key principles to help you write simpler, more understandable DTOs.
You'll learn about:
β’ Keeping things clear and concise
β’ Utilizing properties effectively β¨
β’ Crafting descriptive names that make sense
And also other tips to transform your DTOs from chaotic to crystal clear! By following these principles, you'll be well on your way to writing cleaner, more maintainable DTOs that make your code easier to understand for you and your team.
Ready to up your DTO game? Check out the full article or watch the video for examples and take your codebase to the next level!
[ Article ] : https://ardalis.com/5-rules-dtos
[ YouTube ] : https://www.youtube.com/watch?v=W4n9x_qGpT4
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Dto #Dotnet #csharp #programming
@ProgrammingTip
Crafting clean and maintainable DTOs is essential for keeping your codebase healthy and scalable. But let's face it, sometimes DTOs can morph into these complex beasts that leave you scratching your head. β
Fear not, fellow developers!
This article (or the accompanying video!) dives into 5 key principles to help you write simpler, more understandable DTOs.
You'll learn about:
β’ Keeping things clear and concise
β’ Utilizing properties effectively β¨
β’ Crafting descriptive names that make sense
And also other tips to transform your DTOs from chaotic to crystal clear! By following these principles, you'll be well on your way to writing cleaner, more maintainable DTOs that make your code easier to understand for you and your team.
Ready to up your DTO game? Check out the full article or watch the video for examples and take your codebase to the next level!
[ Article ] : https://ardalis.com/5-rules-dtos
[ YouTube ] : https://www.youtube.com/watch?v=W4n9x_qGpT4
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#Dto #Dotnet #csharp #programming
@ProgrammingTip
https://ardalis.com
5 Rules for DTOs
These are 5 rules for writing better DTOs.
π Explore URL Shorteners: A Deep Dive
Curious about URL shorteners like TinyURL or Bitly? Dive into the fascinating world of system design with this comprehensive breakdown:
π― Scope & Requirements: Understand the functional and non-functional demands, from creating short URLs to ensuring low latency and high availability.
π’ Estimation & Scaling: Learn how to calculate the ideal URL length and anticipate storage needs for projected growth.
ποΈ Architecture Overview: Explore key components of a robust URL shortener system, from load balancers to database layers.
π§ API Design: Uncover essentials of designing a REST API, including endpoints for creating short URLs and seamless redirection.
πΎ Database Management: Discover best practices for storing and retrieving shortened URLs efficiently.
Eager to deepen your understanding? Read the full article below.
[ Article ] : https://levelup.gitconnected.com/system-design-interview-question-design-url-shortener-c3278a99fc35
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#SystemDesign #URLShortener
@ProgrammingTip
Curious about URL shorteners like TinyURL or Bitly? Dive into the fascinating world of system design with this comprehensive breakdown:
π― Scope & Requirements: Understand the functional and non-functional demands, from creating short URLs to ensuring low latency and high availability.
π’ Estimation & Scaling: Learn how to calculate the ideal URL length and anticipate storage needs for projected growth.
ποΈ Architecture Overview: Explore key components of a robust URL shortener system, from load balancers to database layers.
π§ API Design: Uncover essentials of designing a REST API, including endpoints for creating short URLs and seamless redirection.
πΎ Database Management: Discover best practices for storing and retrieving shortened URLs efficiently.
Eager to deepen your understanding? Read the full article below.
[ Article ] : https://levelup.gitconnected.com/system-design-interview-question-design-url-shortener-c3278a99fc35
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#SystemDesign #URLShortener
@ProgrammingTip
Telegram
Programming Tips Resources
OpenAI .NET πΎ
The OpenAI .NET library provides convenient access to the OpenAI REST API from .NET applications.βοΈ
The full API of this library can be found in the api.md file, and there are many code examples to help. For instance, the following snippet illustrates the basic use of the chat completions API:
The library is organized into several namespaces corresponding to OpenAI feature areas. Each namespace contains a corresponding client class:
β’ AssistantClient
β’ AudioClient
β’ BatchClient
β’ ChatClient
β’ EmbeddingClient
β’ FineTuningClient
β’ FileClient
β’ ImageClient
β’ ModelClient
β’ ModerationClient
β’ VectorStoreClient
[ GitHub ] : https://github.com/openai/openai-dotnet
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#AI #OpenAI #DotNet #CSharp
@ProgrammingTip
The OpenAI .NET library provides convenient access to the OpenAI REST API from .NET applications.
The full API of this library can be found in the api.md file, and there are many code examples to help. For instance, the following snippet illustrates the basic use of the chat completions API:
ChatClient client = new(model: "gpt-4o", "OPENAI_API_KEY");
ChatCompletion completion = client.CompleteChat("Say 'this is a test.'");
Console.WriteLine($"[ASSISTANT]: {completion}");
The library is organized into several namespaces corresponding to OpenAI feature areas. Each namespace contains a corresponding client class:
β’ AssistantClient
β’ AudioClient
β’ BatchClient
β’ ChatClient
β’ EmbeddingClient
β’ FineTuningClient
β’ FileClient
β’ ImageClient
β’ ModelClient
β’ ModerationClient
β’ VectorStoreClient
[ GitHub ] : https://github.com/openai/openai-dotnet
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#AI #OpenAI #DotNet #CSharp
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Designing APIs for humans: Object IDs π§π»βπ»
Ever wondered why Stripe uses foloowing format to generate unique IDs? Letβs dive in and break down how and why Stripe IDs are structured the way they are:
pi_3LKQhvGUcADgqoEM3bh6pslE
ββββββββββββββββ
ββ Prefix ββ Randomly generated characters
You might have noticed that all Stripe Objects have a prefix at the beginning of the ID. The reason for this is quite simple: adding a prefix makes the ID human readable.βοΈ
Without knowing anything else about the ID we can immediately confirm that weβre talking about a PaymentIntent object here, thanks to the pi_ prefix. This helps Stripe employees internally just as much as it helps developers integrating with Stripe.
The above snippet is trying to retrieve a PaymentIntent from a connected account, however without even looking at the code you can immediately spot the error: a Customer ID (cus_) is being used instead of an Account ID (acct_).π
Without prefixes this would be much harder to debug; if Stripe used UUIDs instead then weβd have to look up the ID to find out what kind of object it is and if itβs even valid.π¨βπ»
[ Read More ] : https://dev.to/stripe/designing-apis-for-humans-object-ids-3o5a
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#UUID #Stripe
@ProgrammingTip
Ever wondered why Stripe uses foloowing format to generate unique IDs? Letβs dive in and break down how and why Stripe IDs are structured the way they are:
pi_3LKQhvGUcADgqoEM3bh6pslE
ββββββββββββββββ
ββ Prefix ββ Randomly generated characters
You might have noticed that all Stripe Objects have a prefix at the beginning of the ID. The reason for this is quite simple: adding a prefix makes the ID human readable.
Without knowing anything else about the ID we can immediately confirm that weβre talking about a PaymentIntent object here, thanks to the pi_ prefix. This helps Stripe employees internally just as much as it helps developers integrating with Stripe.
$pi = $stripe->paymentIntents->retrieve(
$id,
[],
['stripe_account' => 'cus_1KrJdMGUcADgqoEM']
);
The above snippet is trying to retrieve a PaymentIntent from a connected account, however without even looking at the code you can immediately spot the error: a Customer ID (cus_) is being used instead of an Account ID (acct_).
Without prefixes this would be much harder to debug; if Stripe used UUIDs instead then weβd have to look up the ID to find out what kind of object it is and if itβs even valid.
[ Read More ] : https://dev.to/stripe/designing-apis-for-humans-object-ids-3o5a
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#UUID #Stripe
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
NetPad π₯
A cross-platform C# editor and playground.
NetPad is a C# playground that lets you run C# code instantly, without the hassle of creating and managing projects. Open NetPad, start coding, hit Run, and see your output immediately. It's that simple.βοΈ
β’ Prototyping and Testing: Quickly prototype and test code snippets before incorporating them into your projects.
β’ Data Visualization: Visualize data interactively for better insights and analysis.
β’ Database Queries: Query databases using LINQ or SQL effortlessly.
β’ Learn and Experiment: Experiment with new C# features or start learning C# in an intuitive and accessible environment.
β’ Utility Scripts: Create and save your own utility or administration scripts for repeated use.
[ GitHub ] : https://github.com/tareqimbasher/NetPad
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#NetPad #Linqpad #CSharp #DotNet
@ProgrammingTip
A cross-platform C# editor and playground.
NetPad is a C# playground that lets you run C# code instantly, without the hassle of creating and managing projects. Open NetPad, start coding, hit Run, and see your output immediately. It's that simple.
β’ Prototyping and Testing: Quickly prototype and test code snippets before incorporating them into your projects.
β’ Data Visualization: Visualize data interactively for better insights and analysis.
β’ Database Queries: Query databases using LINQ or SQL effortlessly.
β’ Learn and Experiment: Experiment with new C# features or start learning C# in an intuitive and accessible environment.
β’ Utility Scripts: Create and save your own utility or administration scripts for repeated use.
[ GitHub ] : https://github.com/tareqimbasher/NetPad
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#NetPad #Linqpad #CSharp #DotNet
@ProgrammingTip
Please open Telegram to view this post
VIEW IN TELEGRAM
Telegram
Programming Tips Resources
In recent years, there is a lot of interest in the techlead role in software development. There are many discussions about what the role is and what it is not. Some articles explain it as CTO, some see it as a lead software developer, and some consider as a fully separate role in the team. While there is no clear agreement on techlead definition in the industry, one thing is certain: being a techlead requires strong technical skills and deep expertise with a good mix of leadership and other soft skills.
The only way to effectively grow in this area is continuous learning in system design, architecture, engineering practices and self-imrpovement in communication and presentation skills, leadership, conflict resolution.
If you're a techlead or thinking about becoming one, you should definitely check out the @techleadbits channel. They break down useful articles, books, videos, and share personal experience from a techlead's life. It's full of insights and tips that can really help you grow in this role.
The only way to effectively grow in this area is continuous learning in system design, architecture, engineering practices and self-imrpovement in communication and presentation skills, leadership, conflict resolution.
If you're a techlead or thinking about becoming one, you should definitely check out the @techleadbits channel. They break down useful articles, books, videos, and share personal experience from a techlead's life. It's full of insights and tips that can really help you grow in this role.
Today we launched MenuDish π
The idea came from a problem weβve all faced: When traveling abroad or moving to a new country, reading restaurant menus can be a challenge. You might not understand the language or recognize the dishes, and searching for every item on Google gets frustrating. π€·π»ββοΈ
We wanted to make this easier. With MenuDish, you just take a photo of the menu, and it creates a digital version with images of the dishes. Itβs quick, simple, and saves time.
We built this app because weβve been in those situations, and we hope it helps you too! π
Download for iOS: https://apps.apple.com/us/app/menudish/id6621264757
Download for Android: https://play.google.com/store/apps/details?id=ai.menupix&hl=en
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#MenuPix
@ProgrammingTip
The idea came from a problem weβve all faced: When traveling abroad or moving to a new country, reading restaurant menus can be a challenge. You might not understand the language or recognize the dishes, and searching for every item on Google gets frustrating. π€·π»ββοΈ
We wanted to make this easier. With MenuDish, you just take a photo of the menu, and it creates a digital version with images of the dishes. Itβs quick, simple, and saves time.
We built this app because weβve been in those situations, and we hope it helps you too! π
Download for iOS: https://apps.apple.com/us/app/menudish/id6621264757
Download for Android: https://play.google.com/store/apps/details?id=ai.menupix&hl=en
γ°οΈγ°οΈγ°οΈγ°οΈγ°οΈγ°οΈ
#MenuPix
@ProgrammingTip
Telegram
Programming Tips Resources