این متد جهت رزرو تور مورد استفاده قرار میگیرد.
این متد جهت رزرو تور مورد استفاده قرار میگیرد.
نمونه کلاس Request به زبان سی شارپ در پروژه Partners.Contracts (دانلود) در پوشه زیر موجود است:
\Tour\Booking\V3\Book\RequestModel
Username
string
نام کاربری
Password
string
رمز عبور به صورت MD5 شده
HotelLockId
number
شناسه قفل هتل که در مرحله قبلی و با فراخوانی متد Lock دریافت نموده اید.
DepartureSegment
complex type
اطلاعات مربوط به پرواز رفت که می خواهید رزرو روی آن انجام شود.
FlightNumber
string
شماره پرواز
DepartureDateTime
string
زمان پرواز با فرمت yyyy-MM-dd HH:mm به صورت میلادی.
در صورتی که ساعت پروازی ارسالی از سمت شما با ساعت پروازی سیستم یکی نباشد، درخواست شما reject خواهد شد. این موضوع در مواردی که ساعت پرواز سیستم توسط تامین کننده تغییر کرده است ولی cache شما هنوز ساعت پرواز جدید را نگرفته است کمک خواهد که اشتباها با ساعت اشتباه برای مسافر رزرو را انجام ندهید.
OriginIataCode
string
کد یاتا فرودگاه مبدا
DestinationIataCode
string
کد یاتا فرودگاه مقصد
FareName
string
نام Fare یا در واقع همان کلاس پروازی که می خواهید رزرو روی آن انجام شود.
LockId
number
ارسال این فیلد اجباری است و فقط در صورتی که قبلا متد Lock را فراخوانی کرده باشید، مقدار بدست آمده از آن را می توانید با استفاده از این فیلد ارسال کنید.
ReturningSegment
complex type
اطلاعات مربوط به پرواز برگشت که می خواهید رزرو روی آن انجام شود.
ارسال اطلاعات برای این فیلد اجباری نیست و فقط در مواردی که می خواهید رزرو دو طرفه انجام دهید باید مقدار آن را پر نمایید.
ساختار آن کاملا شبیه فیلد DepartureSegment می باشد.
RoomList
complex type
لیست اتاق ها و اطلاعات مسافران مربوط به هر اتاق
AdultGuestList
complex type
لیست میهمانان بزرگسال
Title
string
عنوان جنسیت میهمان که باید یکی از مقادیر MR یا MS باشد.
FirstName
string
نام میهمان
LastName
string
نام خانوادگی میهمان
BirthDate
string
تاریخ تولد میهمان با فرمت yyyy-MM-dd به صورت میلادی.
IranianNationalId
string
اطلاعات مربوط به کد ملی میهمان.
در حالتی که مسافر ایرانی باشد و پرواز نیز داخلی باشد، باید مقدار این فیلد را پر نمایید. در غیر این صورت باید فیلد Passport را پر نمایید. در غیر این صورت سیستم درخواست شما را reject خواهد کرد.
Passport
complex type
اطلاعات مربوط به گذرنامه میهمان.
زمانی که مسافر ایرانی باشد و پرواز خارجی باشد یا در حالتی که مسافر غیر ایرانی باشد، باید این فیلد را پر نمایید. در غیر این صورت سیستم درخواست شما را reject خواهد کرد.
Number
string
شماره گذرنامه میهمان
ExpiryDate
string
تارخ انقضا گذرنامه با فرمت yyyy-MM-dd و به صورت میلادی.
NationalityCountryCode
string
کد ISO دو حرفی یا سه حرفی ملیت میهمان
جهت مشاهده کد ISO کشور ها اینجا کلیک نمایید.
به عنوان مثال برای ایران می توانید یکی از مقدارهای IR یا IRN را وارد نمایید.
PlaceOfIssueCountryCode
string
کد ISO دو حرفی یا سه حرفی محل صدور گذرنامه میهمان
جهت مشاهده کد ISO کشور ها اینجا کلیک نمایید.
به عنوان مثال برای ایران می توانید یکی از مقدارهای IR یا IRN را وارد نمایید.
ChildGuestList
string
لیست میهمانان کودک
ساختار آن شبیه به AdultGuestList می باشد
MobileNumber
string
شماره تلفن همراه میهمان.
شماره تلفن همراه باید به صورت کامل به همراه کد کشور وارد شود. به عنوان مثال 989352283333+ صحیح می باشد.
string
آدرس ایمیل میهمان.
FlightTotalPayable
decimal
مبلغ کل پرواز
برای جلوگیری از خطاهای احتمالی ما در هنگام رزرو با دریافت این فیلد check price انجام می دهیم، بدین شکل که اگر مبلغ ارسالی از سمت شما با مبلغ سیستم یکی نباشد، درخواست شما reject خواهد شد.
HotelTotalPayable
decimal
مبلغ کل هتل
برای جلوگیری از خطاهای احتمالی ما در هنگام رزرو با دریافت این فیلد check price انجام می دهیم، بدین شکل که اگر مبلغ ارسالی از سمت شما با مبلغ سیستم یکی نباشد، درخواست شما reject خواهد شد.
این فیلد مجموع فیلد Room_NetPrice_TaxIncluded (به علاوه مجموع Extrabed_NetPrice_TaxIncluded در صورت نیاز به تخت اضافه) که در مراحل availability دریافت نموده اید می باشد.
YourLocalInventoryPnr
string
رفرنس سیستم داخلی شما.
حداکثر سایز مورد قبول برای این فیلد 38 کاراکتر می باشد. در صورتی که مقداری بیش از 38 کاراکتر ارسال نمایید سیستم اجازه رزرو به شما نخواهد داد.
ارسال اطلاعات برای این فیلد اجباری نمی باشد. اما در صورتی که مقدار آن را ارسال نمایید:
1. در پیگیری های بعدی با استفاده از رفرنس خود شما، میتوانید پیگیری های مربوط به یک رزرو را انجام دهید.
2. از خطر صدور تکراری رزرو جلوگیری خواهد شد
منحصر به فرد بودن YourLocalInventoryPnr در وب سرویس های پرواز و هتل و تور سپهر به صورت یکپارچه چک می شود. به عنوان مثال اگر شما یک رفرنس را هم به وب سرویس پرواز و هم وب سرویس هتل ارسال نمایید، سیستم تنها اجازه رزرو پرواز را خواهد داد و درخواست دوم خطا برگشت میدهد. بنابراین اگر شما با یک حساب کاربری به صورت همزمان از وب سرویس پرواز یا هتل یا تور استفاده می نمایید باید دقت نموده که YourLocalInventoryPnr که در تمام این وب سرویس ها منحصر به فرد (Unique) باشد را ارسال نمایید.
Remarks
string
ملاحظات
{
"Username": "testdev1",
"Password": "25f9e794323b453885f5181f1b624d0b",
"HotelLockId": 919,
"YourLocalInventoryPnr": "e85a54ea-6910-4490-aab5-bfd79718643a",
"Email": "your-email-address@your-domain.com",
"MobileNumber": "+989352283333",
"Remarks": "",
"DepartureSegment": {
"FlightNumber": "412",
"DepartureDateTime": "2023-10-13 18:00",
"OriginIataCode": "THR",
"DestinationIataCode": "KIH",
"FareName": "THRMHD1",
"LockId": 225087
},
"ReturningSegment": {
"FlightNumber": "413",
"DepartureDateTime": "2023-10-16 15:30",
"OriginIataCode": "KIH",
"DestinationIataCode": "THR",
"FareName": "YIKA NJF20",
"LockId": 225088
},
"RoomList": [
{
"AdultGuestList": [
{
"Title": "MR",
"FirstName": "KHALED",
"LastName": "KESHAVARZ",
"BirthDate": "1993-10-12",
"IranianNationalId": "0012327301",
"Passport": null
},
{
"Title": "MR",
"FirstName": "ZOBEIR",
"LastName": "MOFIDISHODEHI",
"BirthDate": "1993-10-12",
"IranianNationalId": "0012301371",
"Passport": null
}
],
"ChildGuestList": [
{
"Title": "MR",
"FirstName": "HELEN",
"LastName": "FALLAHZADEH",
"BirthDate": "2014-10-12",
"IranianNationalId": "0010626921",
"Passport": null
},
{
"Title": "MR",
"FirstName": "KOOSHA",
"LastName": "KHOSHROO",
"BirthDate": "2020-10-12",
"IranianNationalId": "0010391584",
"Passport": null
}
]
}
],
"FlightTotalPayable": 55209900,
"HotelTotalPayable": 6540000
}
نمونه کلاس Response به زبان سی شارپ در پروژه Partners.Contracts (دانلود) در پوشه زیر موجود است:
\Tour\Booking\V3\Book\ResponseModel
Pnr
string
رفرنس رزرو که 6 کاراکتر و ترکیبی از حروف و اعداد می باشد.
وضعیت رزرو را با یکی از دو روش زیر می توان بررسی نمود:
بدیهی است در صورت رعایت نکردن مورد فوق، هیچ گونه مسئولیتی متوجه سپهر نمی باشد.
{
"Pnr": "O47IBF"
}
در جدول زیر لیستی از خطاهایی که ممکن است بعد از فراخوانی این متد برگشت داده شود، فهرست شده است.
| ExceptionType | توضیح خطا |
|---|---|
|
Error1001-FlightNotFound |
پروازی با اطلاعات درخواستی پیدا نشد. |
|
Error1003-NoEnoughSeatAvailable |
تعداد صندلی درخواستی در پرواز موجود نمی باشد. |
|
Error1004-NoEnoughCredit |
باقی مانده اعتبار حساب برای انجام این رزرو کافی نیست. |
|
Error1005-CreditDueDateReached |
مهلت پرداخت بدهی به اتمام رسیده است و انجام رزرو امکان پذیر نمی باشد |
|
Error1006-FareNotFound |
کلاس پروازی با اسم fare درخواستی پیدا نشد. |
|
Error1007-DuplicateClientPnr |
مقداری که به عنوان YourLocalInventoryPnr ارسال شده است تکراری بوده و قبلا در سیستم ثبت شده است. |
|
Error1010-LockReleased |
قفل رزرو آزاد شده است و رزرو قابل انجام شدن نیست. این اتفاق زمانی به وقوع می پیوندد که یا زمان بین قفل کردن تا فراخوانی متد Book، بیش از اندازه طولانی شده باشد و یا اینکه قفل رزرو توسط مدیر سیستم در سایت تامین کننده آزاد شده باشد. |
|
Error1011-FlightTimeMismatch |
ساعت پرواز درخواستی شما با ساعت پروازی سیستم مطابقت ندارد |
|
Error1012-ForbiddenNationality |
زمانی که پذیرش اتباع یک کشور خاص روی مسیری ممنوع باشد، این خطا برگشت داده خواهد شد به عنوان مثال پذیرش اتباع محترم افغانستان و پاکستان در مسیر استانبول توسط هواپیمایی معراج ممنوع می باشد. |
|
Error1014-DuplicatePassengerName |
قبلا مسافری با کدملی یا شماره گذرنامه مشابه در پرواز رزرو شده است. |
|
Error1016-InvalidBirthdate |
تاریخ تولد مسافر غیر معتبر است. زمانی که تاریخ ارسال شده در بازه زمانی امروز تا 120 سال گذشته نباشد این خطا تولید می شود. |
|
Error1019-InfantAgeIsNotValid |
سن مسافر نوزاد هنگام پرواز در بازه بین 7 روز تا 2 سال نیست. اگر در رزرو دوطرفه با این خطا مواجه شدید بررسی نمایید که سن نوزاد هم در زمان پرواز رفت در بازه مجاز باشد و هم در زمان پرواز برگشت. درصورتی که نوزاد در پرواز رفت در بازه سنی مجاز باشد ولی هنگام پرواز برگشت سنش در بازه کودک قرار بگیرد، امکان انجام آن رزرو مقدور نخواهد بود. برای این منظور یا باید این مسافر را به عنوان کودک رزرو بگیرید یا اینکه برای رزرو با کارشناسان فروش تامین کننده مربوطه تماس حاصل بفرمایید. |
|
Error1020-ChildAgeIsNotValid |
سن مسافر کودک هنگام پرواز در بازه بین 2 تا 12 سال نیست. اگر در رزرو دوطرفه با این خطا مواجه شدید بررسی نمایید که سن کودک هم در زمان پرواز رفت در بازه مجاز باشد و هم در زمان پرواز برگشت. درصورتی که کودک در پرواز رفت در بازه سنی مجاز باشد ولی هنگام پرواز برگشت سنش در بازه بزرگسال قرار بگیرد، امکان انجام آن رزرو مقدور نخواهد بود. برای این منظور یا باید این مسافر را به عنوان بزرگسال رزرو بگیرید یا اینکه برای رزرو با کارشناسان فروش تامین کننده مربوطه تماس حاصل بفرمایید. |
|
Error1021-PriceMismatch |
نرخ درخواستی شما با نرخ سیستم مطابقت ندارد. |
|
Error1022-IpIsNotTrusted |
آی پی شما در سایت تامین کننده تراست نشده است. جهت تراست کردن آی پی با پشتیبانی سپهر تماس حاصل نمایید. |
|
Error1023-InvalidCredential |
نام کاربری یا رمز عبور اشتباه می باشد. |
|
Error1024-ForbiddenIp |
آی پی شما توسط تامین کننده مسدود شده است. جهت پیگیری موضوع با تامین کننده تماس بگیرید. |
|
Error1025-FlightIsClosed |
زمانی که یک پرواز وضعیت Ontime نداشته باشد (مثلا Close شده باشد) و شما اقدام به رزرو روی آن نمایید، این خطا را دریافت خواهید کرد. |
|
Error1028-HotelExtrabedExceeded |
تعداد تخت اضافه مورد نیاز برای انجام رزرو، بیش از گنجایش کلی تخت اضافه هتل می باشد. اگر دیتای availability را سمت خود cache می نمایید، برای کاهش احتمال بروز این خطا پیشنهاد می شود availability را در زمان های کوتاه تری دریافت نموده و cache خود را سریعتر بروز رسانی نمایید. |
|
Error1029-PassportExpiryDateMinimumLimit |
اعتبار تاریخ انقضای گذرنامه کمتر از حداقل مجاز آن می باشد. مثلا اگر در مسیری که حداقل اعتبار گذرنامه 6 ماهه لازم است، 5 ماه و 21 روز تا منقضی شدن گذرنامه مسافر باقی مانده باشد، سیستم این خطا را تولید خواهد کرد. در اکثر مسیرهای پروازی حداقل زمان باقی مانده معمولا 6 ماه می باشد، ولی این عدد با توجه به قوانین کشورهای مختلف ممکن است متفاوت باشد. همچنین مبنای محاسبه تاریخ، زمان پرواز می باشد و نه زمان رزرو. مثلا ممکن است مسافر در زمان رزرو 6 ماه اعتبار گذرنامه داشته باشد، ولی در روز پرواز، اعتبار گذرنامه آن کمتر از 6 ماه شده باشد که در این حالت سیستم خطا داده و اجازه رزرو نمی دهد. |
|
Error1030-PassportExpiryDateMaximumLimit |
تاریخ انقضای گذرنامه بیش از حد مجاز آن است. معمولا اکثر کشورها گذرنامه هایی با حداکثر تاریخ انقضای 10 سال صادر می کنند. البته این عدد بر اساس هر کشور ممکن است متفاوت باشد. به عنوان مثال اگر برای کشوری که گذرنامه های حداکثر 10 ساله دارد، تاریخ انقضای گذرنامه بیش از 10 سال ارسال شود، سیستم این خطا را تولید خواهد کرد. |
|
Error1031-DuplicateDocumentNumberInSameRequest |
زمانی که در یک درخواست شما کد ملی یا شماره گذرنامه تکراری وجود داشته باشد، این خطا تولید می شود. برای جلوگیری از این خطا پیشنهاد می شود قبل از ارسال کردن درخواست رزرو، بررسی بفرمایید که در درخواست شما کد ملی یا شماره گذرنامه تکراری وجود نداشته باشد. |
|
Exception |
خطای نامشخص. جهت دریافت اطلاعات بیشتر باید به ErrorMessage داخل json برگشتی مراجعه نمود. |