定制 nakipelo/tourism-api 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

nakipelo/tourism-api

最新稳定版本:v1.0.0

Composer 安装命令:

composer require nakipelo/tourism-api

包简介

A Laravel 12 package for working with Russian Tourism API (tourism.fsa.gov.ru)

README 文档

README

A Laravel package for integrating with the Russian Tourism API (tourism.fsa.gov.ru) to access hotels, resorts, and destinations data.

Features

  • 🏨 Hotels API - Access hotel data from Russian Tourism API

  • 🏖️ Resorts API - Get resort information and details

  • 🗺️ Destinations API - Retrieve destination data

  • 🔄 Retry Logic - Automatic retry on API failures

  • Performance - Optimized HTTP requests with timeout handling

  • 🛡️ Error Handling - Comprehensive error handling and logging

Requirements

  • PHP 8.2+
  • Laravel 12.0+

Installation

Via Composer

composer require nakipelo/tourism-api

Manual Installation

  1. Clone the repository:
git clone https://github.com/nakipelo/tourism-api.git
  1. Install dependencies:
composer install
  1. Publish the configuration:
php artisan vendor:publish --tag=tourism-api

Configuration

The package configuration file will be published to config/tourism-api.php. You can modify the following settings:

return [
    'base_url' => env('TOURISM_API_BASE_URL', 'https://tourism.fsa.gov.ru'),
    'api_version' => env('TOURISM_API_VERSION', 'v1'),
    'timeout' => env('TOURISM_API_TIMEOUT', 30),
    'retry_attempts' => env('TOURISM_API_RETRY_ATTEMPTS', 3),
    
    'user_agent' => env('TOURISM_API_USER_AGENT', 'Nakipelo-Tourism-API/1.0'),
    'endpoints' => [
        'hotels' => '/ru/resorts/showcase/hotels',
        'resorts' => '/ru/resorts',
        'destinations' => '/ru/destinations',
    ],
];

Usage

API Integration

The package integrates with the following Russian Tourism API endpoints:

  • Hotels Showcase: /api/v1/resorts/hotels/showcase - Get paginated list of hotels
  • Hotel Main Info: /api/v1/resorts/hotels/{id}/main - Get detailed hotel information
  • Hotel Additional Info: /api/v1/resorts/common/{id}/additional-info - Get additional hotel details
  • Hotel Drawer: /api/v1/resorts/hotels/{id}/drawer - Get hotel drawer information

Reference Data

  • Regions: /api/v1/nsi/regions/get - Get regions list
  • Hotel Statuses: /api/v1/nsi/hotelStatus/get - Get hotel status types
  • Hotel Types: /api/v1/nsi/hotelTypes/get - Get hotel type categories
  • Room Categories: /api/v1/nsi/roomCategory/get - Get room category types
  • Hotel Services: /api/v1/resorts/filter/services/hotelServices - Get available hotel services

Service Usage

use Nakipelo\TourismApi\Services\TourismApiService;

// Get hotels showcase with pagination
$hotels = app(TourismApiService::class)->getHotelsShowcase([
    'page' => 0,
    'limit' => 20
]);

// Get specific hotel details
$hotel = app(TourismApiService::class)->getHotelMain('c02d00bf-c607-11ef-92da-8ba33c42ca02');

// Get hotel additional info
$additionalInfo = app(TourismApiService::class)->getHotelAdditionalInfo('c02d00bf-c607-11ef-92da-8ba33c42ca02');

// Get reference data
$regions = app(TourismApiService::class)->getRegions();
$hotelTypes = app(TourismApiService::class)->getHotelTypes();
$roomCategories = app(TourismApiService::class)->getRoomCategories();

Testing

Run the test suite:

composer test

Contributing

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Commit your changes (git commit -m 'Add some amazing feature')
  4. Push to the branch (git push origin feature/amazing-feature)
  5. Open a Pull Request

License

This package is open-sourced software licensed under the MIT license.

Support

If you encounter any issues or have questions, please open an issue on GitHub.

Changelog

Please see CHANGELOG for more information on what has changed recently.

统计信息

  • 总下载量: 4
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 6
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-08-20

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固