<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های امین علیزاده</title>
        <link>https://virgool.io/feed/@aminalizadeh</link>
        <description></description>
        <language>fa</language>
        <pubDate>2026-06-17 02:20:34</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/1265377/avatar/WJL0yS.jpeg?height=120&amp;width=120</url>
            <title>امین علیزاده</title>
            <link>https://virgool.io/@aminalizadeh</link>
        </image>

                    <item>
                <title>سایت utick.ir کلاهبردار است</title>
                <link>https://virgool.io/@aminalizadeh/%D8%B3%D8%A7%DB%8C%D8%AA-utickir-%DA%A9%D9%84%D8%A7%D9%87%D8%A8%D8%B1%D8%AF%D8%A7%D8%B1-%D8%A7%D8%B3%D8%AA-zhe7luzxcntb</link>
                <description>utick.ir کلاهبردارمتاسفانه همیشه دسترسی به منابع معتبر خارجی برای ما ایرانی ها سخت بوده و خرید اکانت از سایت های معتبر خارجی تقریبا برای ما غیر ممکن است.حدود ۱۰ روز پیش تصمیم گرفتم اکانت سایت resumeworded.com را برای بهبود رزومه کاری ام خریداری کنم بعد از جستجو به سایت utick.ir رسیدم که این سایت به ظاهر با دریافت ریال حساب کاربری resume worded بنده رو خریداری میکرد. ( قیمت خرید اکانت به شدت بالاتر از قیمت واقعی سایت resumeworded بود ).طبق گفته سایت اکانت ۶ الی ۴۸ ساعت زمان میبرد تا انجام بشه اما بعد از گذشت چند روز سفارش من تکمیل نشد. از طرفی نه چت آنلاین پاسخ می دهند و نه تیکت و نه پشتیبان تلگرام. با شرکت تماس گرفتم هیچ داخلی جواب نمی داد بعد از حدود ۲۰ بار زنگ زدن بالاخره یکی جواب داد و گفت تا اخر امروز انجام میشه. اما بعد از حدود ۱۰ روز زنگ زدن هنوز انجام نشده و من هر روز در حال تماس با شرکت هستم و هیچ کس پاسخگو نیست!در رابطه با شرکت در شبکه های اجتماعی سرچ کردم و دیدم خیلی ها مشکل من رو دارند و سایت utick.ir از آنها پول گرفته و هیچ چیزی تحویل نداده است.از طرفی پرسه شکایت از سایت utick.ir انقدر برای من زمان بر و پیچیده است که تصمیم گرفتم قید پول ام رو بزنم ولی وظیفه خودم دونستم که اطلاع رسانی کنم تا کسی مثل من سرش کلاه نره‌!</description>
                <category>امین علیزاده</category>
                <author>امین علیزاده</author>
                <pubDate>Mon, 19 Feb 2024 14:08:59 +0330</pubDate>
            </item>
                    <item>
                <title>سواگر ( Swagger ) چیه؟</title>
                <link>https://virgool.io/@aminalizadeh/%D8%B3%D9%88%D8%A7%DA%AF%D8%B1-swagger-%DA%86%DB%8C%D9%87-cbhiarwyrvtl</link>
                <description>سواگر ( Swagger ) ابزاری برای مستند سازی API هاتونسلام، امین علیزاده هستم برنامه نویس تیم iFNo. امروز قراره یکم راجب Swagger و OpenAPI براتون بنویسم سعی میکنم به زبان ساده باشه و در آخر مثالی از نحوه‌ی پیاده سازی رو برای شما شرح میدم. امیدوارم مفید باشد.سواگر ( Swagger ) یک ابزار متن باز ( Open Source ) و بسیار قدرتمند ( اما خیلی ساده! ) هستش که برای طراحی و مستندسازی تا تست و آماده سازی محصول برای استفاده‌ی کاربران ( Deployment )، استفاده می‌شود. اگر شما از معماری RESTful API برای توسعه سرویس هاتون استفاده می‌کنید حتما تا آخر این مطلب همراه من باشید.چی شد که ما گفتیم آقا Swagger چیز خوبیست بیایم استفاده کنیم ازش :)پروژه ای که جدیدا استارتش رو زدیم قراره کلی سرویس به دردبخور برای کسب‌ و کارها و اپلیکیشن ها ( به خصوص استارت‌آپ ها ) ارائه بده  ( Serverless ). ما می‌خواهیم توسعه دهنگان این کسب و کارها خیلی راحت بتوانند با سرویس های ما ارتباط برقرار کنند برای همین نیاز داریم یک مستند سازی واضح و شفاف برای سرویس‌هایی که توسعه می دهیم داشته باشیم. تا توسعه دهنده خیلی گیج نشه که دقیقا چطوری باید API های ما رو Call کنه ( دقیقا مثل Documentation درگاه های پرداخت ایرانی که معلوم نیست چی نوشتن توش ? )پس نیاز داریم یک ابزار قوی برای مدیریت، مستندسازی ( Documentation APIs ) و حتی تست APIهای سرویس ها داشته باشیم برای همین Swagger رو انتخاب کردیم :)یکم Swagger رو تخصصی تر بررسی کنیمطراحی API ها با سواگر Swaggerدر حقیقت Swagger یک زبان توصیف رابط ( Interface Description Language ) هستش که توسط یک فایل JSON یا YAML طراحی و نوشته میشه یعنی به طور ساده یک واسط بین Server و Client هستش که ارتباطات بین این دو را برای شما راحت میکنه مثلا در یک تیم برنامه نویسی یکی از مشکلات کسایی که بخش بک اند رو توسعه میدن توضیح دادن APIها به فرانت اند کارهاست ? با swagger می‌تونید بیشتر زمان و تمرکزتون رو بزارید رو بیزینس لاجیکتون چون یک  Documentation خیلی کامل برای شما به صورت کاملا اتوماتیک ایجاد می‌کنه ( در اکثر زبان های برنامه نویسی ) و شما نیازی نیست وقتتون رو صرف نوشتن داکیومنت کنید.قبل از ادامه بیایید مفهموم OpenAPI Specification رو بررسی کنیم. با توجه به اینکه جهان داره میره به سمت اپلیکیشن های سرویس بیس و معماری میکروسرویس، لازم هست که برنامه نویس‌ها یک رابط استاندارد برای APIهای RESTful خودشون داشته باشند. اینجاست که مفهوم OpenAPI مطرح میشود. OpenAPI Specification یک فرمت متن باز ( Open Source ) است برای ایجاد فایل‌های رابط که قابل خواندن توسط ماشین و قابل درک برای انسان می باشد. یعنی یک استاندارد جهانی برای تولید و توصیف و بصری سازی ( visualizing ) APIهای وب سرویس های RESTful شما. این فایل ها موارد ضروری برای استفاده از APIهای وب سرویس شما را مشخص میکنند از جمله:توصیف و توضیح نحوه عملکرد APIمقادیر ارسالی ( Request ) چه چیزهایی باید باشد و نوع آنها و نحوه ارسال و ...مقادیر دریافتی ( Response ) چه مقادیری هستند و توصیف این مقادیر و ...مشخص کردن نحوه احراز هویت ( Authentication ) جهت ارسال درخواست ها و ...مواردی مانند اطلاعات تماس ، شرایط استفاده ، مجوز و موارد دیگر ...درنهایت مزیت اصلی استفاده از تعریف استاندارد این است که کاربران شخص ثالث می توانند با حداقل منطق پیاده سازی با خدمات تعامل داشته باشند و آن را درک کنند ، به شرطی که با اصول اولیه RESTful API آشنا باشند.شاید الان به این فکر کنید Swagger و OpenAPI چه فرقی باهم دارند آیا اصلا متفاوت هستند ؟!تفاوت OpenAPI و Swaggerتفاوت بین Swagger و OpenAPIاگر دقت کنید هرجا که اسم OpenAPI میاد Swagger هم مطرح میشه اما باید بدونید این دو کلا دارای مفهوم متفاوتی هستند از نظرعملکرد!همانطور که گفته شده OpenAPI Specification یک استاندارد جهانی برای تولید و توصیف و بصری سازی ( visualizing ) APIهای وب سرویس های RESTful شما می‌باشد که توسط شرکت های خیلی بزرگی مانند Microsoft, Google, Capital, Swagger و IBM ساخته شده است.از طرفی Swagger شرکتی است که مجموعه نرم افزاری بسیار قوی از جمله ابزارهای منبع باز ، رایگان و تجاری برای پیاده سازی OpenAPI Specification توسعه داده است و از انجایی که یکی از شرکت های سازنده OpenAPI Specification هم هست در نتیجه اغلب اسم این شرکت همراه با OpenAPI Specification در بسیاری جاها مطرح شده در نتیجه شما لزومی نداره حتما از Swagger برای وب‌ سرویس‌هاتون استفاده کنید می‌تونید از ابزارهای دیگر نیز استفاده کنید.نحوه پیاده سازی Swagger در فریم ورک NestJSنحوه پیاده سازی Swagger در فریم ورک NestJSنکته:قبل از اینکه شروع کنیم این نکته رو بگم که ما درفریم ورک NestJS قرار نیست فایل YAML یا JSON سواگر رو بنویسیم چون خود NestJS برای ما این فایل رو می سازه ( Generate میکنه! ). اما اگر میخواهید ساختار این فایل رو ببینید و خودتون پیاده سازی کنید می تونید به Documentation سواگر مراجعه کنید. ساختار به شدت قابل فهم برای انسان هست و به هیچ عنوان پیچیدگی خاصی نداره با یک بررسی ساده متوجه این قضیه خواهید شد.بعد از نصب NestJS برای ایجاد یک پروژه در دایرکتوری مورد نظرتون یک ترمینال باز کنید و کامند زیر را وارد کنید:ایجاد پروژه جدید در NestJSبعد از به اتمام رسیدن مراحل ایجاد فایل‌ها و ساختار کلی پروژه شما توسط NestJS شما می توانید با کامند yarn start:dev پروژه‌تون رو در حالت development اجرا کنید. بله شما یک وب سرویس HTTP ایجاد کردید! :))ساختار NestJSقرار نیست راجب NestJS صحبت کنیم فقط به صورت خلاصه یکم بررسی می‌کنیم تا درک بهتری داشته باشیم اگر میخواهید NestJS رو درک کنید بهتره به Documentation این فریم ورک مراجعه کنید. توجه داشته باشید NestJS علاقه‌ای به ما ایرانی ها نداره! خودتون می‌دونید چطوری باید نسبت به این موضوع بی اهمیت باشید?اگر به ساختار پروژه‌تون نگاه کنید شامل چند بخش اصلی هست:فایل app.module.ts ساختار اصلی اپلیکیشن و تعریف بخش های مختلف رو انجام میده.فایل main.ts که پیکربندی وب سرویس و اپلیکیشن شما رو انجام می‌ده.فایل app.service.ts شما می‌تونید سرویس های اپلیکیشن‌تون رو در کلاس AppService ( یا هر اسم دیگه ای) تعریف کنید.فایل app.controller.ts شما می‌تونید کنترلر هاتون رو در این کلاس تعریف کنید.و بخش های دیگر که خیلی مرتبط با این بحث نیست.خوب الان وقتش رسیده که Swagger رو به پروژه اضافه کنیم برای اینکار ابتدا لازم هست پکیج سواگر رو در دایرکتوری پروژه‌تون نصب کنید (راستی من برای نصب پکیج ها از yarn استفاده می‌کنم شما می‌تونید از npm یا pnpm استفاده کنید.)نصب پکیج سواگردر اصل شما دو پکیج رو نصب می‌کنید یکی nestjs/swagger@ شامل متد های سواگر هست و swagger-ui-express کار بصری سازی ( visualizing ) APIهای شما رو انجام میده.برای راه‌اندازی سواگر ( Config ) کافیه داخل فایل main.ts یک نمونه ( Instance ) از کلاس DocumentBuilder سواگر ایجاد کنید و تنظمات اصلی سواگر رو در آن راه‌اندازی و کانفیگ کنید:کانفیگ سواگر در NestJSبعد از پیاده سازی اولیه سواگر کافیه HTTP Server خودتون رو اجر کنید برای اینکار همانطور که گفته شد در دایرکتوری پروژه‌تون کافیه کامند start yarn:dev رو اجرا کنید. حالا کافیه در مرورگر وارد http://localhost:3000/api بشید.رابط کاربری سواگربرای دیدن فایل JSON سواگرتون که قبلا توضیحاتشو دادم کافیه وارد http://localhost:3000/api-json بشید.برای توصیف API هاتون وارد app.controller.ts شوید جایی که API های شما در آن تعریف می‌شود. هنگام راه اندازی NestJS برای شما یک API به صورت مثال تعریف می‌کند که درخواست ها با متد GET را دریافت می‌کند. برای توصیف این متد (که درخواست ها ( Request )شامل چه مواردی هست و پاسخ ها ( Response ) چه مقادیری هستند) دکوریشن ( Decoration ) های زیادی وجود دارد. ( برای آشنایی با مفهموم درکوریشن ها می توانید به مستندات NestJS مراجعه کنید ) که من در این مطلب چندتا از مهمترین هاشو بررسی میکنم.ApiPropertyApiTagsApiOperationApiResponseApiBodyApiQueryApiParamدکوریشن ( )ApiProperty@:برای توصیف پارامترهای ارسالی به متدهاتون DTO ( Data Transfer Object ) می‌توانید از این دکوریشن استفاده کنید. برای مثال من در این پروژه یک دایرکتوری در src به نام dto ایجاد میکنم و فایل get-hello.dto.ts رو در آن ایجاد می کنم./src/dto/get-hello.dto.tsالبته خیلی آپشن های دیگری نیز در ApiProperty وجود دارد که می‌توانید با توجه به نیازتون آن ها رو تعریف کنید. به این صورت DTO های شما در داکیومنت سواگر توصیف می شود.دکوریشن ( )ApiTags@ :اگر نیاز دارید در swagger docs تون API هاتون رو دسته بندی کنید می تونید از این دکوریشن در کنترلرتون استفاده کنید مقدار پیش فرض اگر به عکس ( رابط کاربری سواگر ) که در بالا آورده شده نگاه کنید مقدار default می باشد.دکوریشن ( )ApiOperation@برای توصیف و خلاصه‌ای از نتیجه نهایی این متد می توانید از این دکوریشن استفاده کنید. اینکه به صورت خلاصه این API در نهایت چیکار می‌کنه و توصیف بیشتر از اون. این دکوریشن رو می‌توانید در بالای متدتون تعریف کنید./src/app.controller.ts دکوریشن ( )ApiResponse@برای توصیف ساختار پاسخ ( Response ) می‌توانید از این دکوریشن در بالای متدتون استفاده کنید اینکه ریسپانس چه کد وضعیتی داره ( status )، و توصیف اون و مقادیر آن.دکوریشن های دیگر نیز به همین صورت تعریف می‌شود. اگر نیاز به توصیف param هاتون دارید از دکوریشن ApiParam اگر میخواهید بادی درخواستتون رو توصیف کنید از ApiBody و اگر می‌خواهید query هاتون رو توصیف کنید ApiQuery استفاده کنید درست مانند دکوریشن هایی که مثال زدیم.همانطور که دیدید استفاده از swagger  بسیار ساده و کاربردی هست بدیهی هست که نمیشه در این مطلب همه‌ی امکانات سواگر رو بررسی کنیم قطعا نیاز هست در حین انجام پروژه اونها رو پیدا کنید و ازشون استفاده کنید.و در نهایت swagger docs شما به این صورت خواهد شد:در کل ممنونم که تا اینجا همراه من بودید همانطور که مشاهده کردید برای طراحی یک Open API استاندارد شما نیاز به این ابزار دارید اگر این مطلب براتون مفید بود با دوستانتون به اشتراک بزارید یا اگر جایی از اون گنگ بود برام کامنت بزارید.The World Standard for RESTful APIs</description>
                <category>امین علیزاده</category>
                <author>امین علیزاده</author>
                <pubDate>Sat, 23 Oct 2021 10:12:23 +0330</pubDate>
            </item>
            </channel>
</rss>