Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sagnikrivud/open-api-turism-web-application
Open Source API Collection for Tourism Application applicable at mobile end or any front end (React, Angular, Vue) projects & Admin Panel added feature.
https://github.com/sagnikrivud/open-api-turism-web-application
codeigniter cron mysql rest-api shell-script travel
Last synced: about 1 month ago
JSON representation
Open Source API Collection for Tourism Application applicable at mobile end or any front end (React, Angular, Vue) projects & Admin Panel added feature.
- Host: GitHub
- URL: https://github.com/sagnikrivud/open-api-turism-web-application
- Owner: sagnikrivud
- License: mit
- Created: 2024-02-20T05:59:49.000Z (11 months ago)
- Default Branch: master
- Last Pushed: 2024-03-31T08:40:07.000Z (9 months ago)
- Last Synced: 2024-11-28T00:06:52.699Z (about 1 month ago)
- Topics: codeigniter, cron, mysql, rest-api, shell-script, travel
- Language: PHP
- Homepage:
- Size: 243 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# OPEN API For Travel Agency application
![Logo](https://logowik.com/content/uploads/images/651_codeigniter.jpg)__Information Access__
Destination Details: Tourism sites provide comprehensive information about various destinations, including attractions, accommodations, activities, and local culture. This helps travelers make informed decisions about where to go and what to do.
Trip Planning:Itinerary Creation:
Users can plan their entire trip, from choosing destinations and activities to creating detailed itineraries. Tourism sites often offer tools to organize and customize travel plans.__Application features__
- Ready to deploy at server and start business.
- Logo, Site Name and Banner can be set according to business.
- Admin Panel for adding/editing trips, manage Customers, Track bookings and activities.
- Ready made API Collection for Frontend web or Mobile APP.
- Contents can be provided by API.
- Razorpay Payment Gateway for husslefree payment processing.
- Contents available for About Us, Announcements, Privacy Policy, Travel blogs, Contact us page etc.
- No save card policy and secure payment guarantee.
- SEO Friendly support from backend.
# Grow your tourism
![Tourism](https://i.pinimg.com/736x/2f/a2/32/2fa2321cb1703d6eef32410774156fed.jpg)## Payment Gateway
![Razorpay](https://cdn.iconscout.com/icon/free/png-512/free-razorpay-1649771-1399875.png?f=webp&w=256)## Git Install at server (Linux instance)
```sh
$ sudo apt update
```
```sh
$ sudo apt install git
```
```sh
$ git config --global user.email "[email protected]"
```
```sh
$ git config --global user.name "Your git user Name"
```
## Installation & updates (Directly at Server)
```sh
$ git clone https://github.com/sagnikcapital/Open-Api-Travel-Application.git
```
```sh
$ cp .env.example .env
```
```sh
$ composer install
```
```sh
$ chmod +x Permission.sh
```
```sh
$ chmod +x Deploy.sh
```
```sh
$ crontab -e
```
> Write the execution details at cron tab:```sh
0 2 * * * /path/to/your/script/Permission.sh
```
```sh
0 2 * * * /path/to/your/script/Deploy.sh
```
> Write the .htaccess
```sh
$ cp public/.htaccess .
```
> Create SSH Authentication
```sh
$ ssh-keygen -t rsa -b 2048 -C "[email protected]"
```
```sh
$ eval "$(ssh-agent -s)"
```
```sh
$ ssh-add ~/.ssh/id_rsa
```
>The SSH key pair (public and private keys) will be generated. You'll see output similar to:
- Your identification has been saved in /path/to/your/home/.ssh/id_rsa.> Set TimeZone for APP at .env,
- Refer: https://www.php.net/manual/en/timezones.php
```env
APP_TIMEZONE=''
```> Setup .env configuration for Database connect
```env
HOST=''
DB_USER=''
DB_PASSWORD=''
DB_NAME=''
PORT=3306
```
> Set the Value of CI_ENVIRONMENT
```env
CI_ENVIRONMENT='production'
```> Run migrations
```sh
$ php spark migrate
```
> Seed the Admin details and Content to Database
```sh
$ php spark db:seed AdminSeeder
```
```sh
$ php spark db:seed ContentsSeeder
```> Setup Twilio details at .env for Messaging
```env
TWILIO_SID=''
TWILIO_AUTH_TOKEN=''
```> Set the App Url at .env with domain like this
```env
APP_URL='http://domain.com/api/'
```
> Configure the SMTP Details at .env for Mailing, (Google, Twilio, Mailtrap, Mailchimp, Hostinger)
```env
SMTP_HOST=''
SMTPUSER=''
SMTPPASS=''
SMTP_PORT=587
SMTP_LEVEL='tls'
MAIL_FROM=''
MAIL_NAME='your name'
```
> Configure Razorpay Payment Gateway Details in .env file
```env
RAZORPAY_API_KEY=''
RAZORPAY_API_SECRET=''
RAZORPAY_CURRENCY='USD' #'INR', 'IDR', 'EUR', 'EGP', 'GHS'
```
- Refer: https://github.com/razorpay/razorpay-php> Add JWT key to .env, refer this
- URL: https://auth0.com/signup?&signUpData=%7B%22category%22%3A%22docs%22%7D
```env
JWT_SECRET_KEY=''
```> Run to confirm setup process
```sh
$ php spark setup
```## Server Maintenance Mode
> For put your application into maintenance mode you can use following
```sh
$ php spark mm:down
```
> For check status
```sh
$ php spark mm:status
```
> To Put application live again after being in maintenance mode
```sh
$ php spark mm:up
```
- Refer: https://github.com/arashsaffari/maintenancemode## Queue Jobs
> Setup Codeigniter Queue Job
```sh
$ composer require codeigniter4/queue
```
```sh
$ php spark migrate --all
```
```sh
$ php spark queue:publish
```
```sh
$ php spark queue:job ExampleJob
```
Add it to the `$jobHandlers` array in the `app\Config\Queue.php` file:
```php
use App\Jobs\Example;
//....
public array $jobHandlers = [
'my-example' => Example::class
];
```
- Add job to the queue:
```php
service('queue')->push('queueName', 'my-example', ['data' => 'array']);
```
```sh
$ php spark queue:work queueName
```
- Refer: https://github.com/codeigniter4/queue## Check System Logs
> Open http://your-domain/logs in browser
- Refer: https://github.com/SeunMatt/codeigniter-log-viewer
## Important Change with index.php`index.php` is no longer in the root of the project! It has been moved inside the *public* folder,
for better security and separation of components.This means that you should configure your web server to "point" to your project's *public* folder, and
not to the project root. A better practice would be to configure a virtual host to point there. A poor practice would be to point your web server to the project root and expect to enter *public/...*, as the rest of your logic and the
framework are exposed.## Versions and Compatibility
- [PHP 7.4 | 8.0]()
- [Apache 2]()
- [CodeIgniter 4.0]()
- [Mysql]()
- [intl](http://php.net/manual/en/intl.requirements.php)
- [mbstring](http://php.net/manual/en/mbstring.installation.php)
- [DomPDF](https://github.com/dompdf/dompdf/releases)
- [json]() (enabled by default - don't turn it off)
- [mysqlnd](http://php.net/manual/en/mysqlnd.install.php) if you plan to use MySQL
- [libcurl](http://php.net/manual/en/curl.requirements.php) if you plan to use the HTTP\CURLRequest library## Admin Access
> Username : [email protected]
> Password : password1234> URL: /admin/login
![Alt Text](blobs/login.png)## API Documentation
| API URL | Parameters | Method |
|-------------------------|---------------------|----------|
| `api/login` | `phone, otp_code` | POST |
| `api/register` | `phone, email` | POST |
| `api/otp` | `phone` | POST |
| `api/validate-otp` | `phone, otp_code` | PUT |
| `api/profile` | `email, first_name, last_name, doc_type, doc_number` | PUT |
| `api/content/headers` | NULL | GET |
| `api/content/get/{title}`| `title` | GET |
| `api/content/logo` | NULL | GET |
| `api/trips` | NULL | GET |
| `api/trip/{id}` | `id` | GET |
| `api/trip/search` | `keyword` | POST |
| `api/trip/review` | `trip_id, user_id, review{int}, comment{text}` | POST |
| `api/trip/my-trips` | `user_id` | GET |
| `api/trip/confirm` | `user_id, trip_id, date`| POST |
| `api/trip/cancel` | `booking_code, trip_id, reason {text}, invoiceNumber` | DELETE |
| `api/make/payment` | `amount, user_id, phone, trip_id` | POST |With Best regards,
### [Sagnik Dey](https://in.linkedin.com/in/sagnik-dey-483423a9)---
## 💻 Tech Stack
![CSS3](https://img.shields.io/badge/css3-%231572B6.svg?style=plastic&logo=css3&logoColor=white) ![PHP](https://img.shields.io/badge/php-%23777BB4.svg?style=plastic&logo=php&logoColor=white) ![HTML5](https://img.shields.io/badge/html5-%23E34F26.svg?style=plastic&logo=html5&logoColor=white) ![JavaScript](https://img.shields.io/badge/javascript-%23323330.svg?style=plastic&logo=javascript&logoColor=%23F7DF1E) ![AWS](https://img.shields.io/badge/AWS-%23FF9900.svg?style=plastic&logo=amazon-aws&logoColor=white) ![Vue.js](https://img.shields.io/badge/vuejs-%2335495e.svg?style=plastic&logo=vuedotjs&logoColor=%234FC08D) ![Vuetify](https://img.shields.io/badge/Vuetify-1867C0?style=plastic&logo=vuetify&logoColor=AEDDFF) ![NPM](https://img.shields.io/badge/NPM-%23000000.svg?style=plastic&logo=npm&logoColor=white) ![jQuery](https://img.shields.io/badge/jquery-%230769AD.svg?style=plastic&logo=jquery&logoColor=white) ![Express.js](https://img.shields.io/badge/express.js-%23404d59.svg?style=plastic&logo=express&logoColor=%2361DAFB) ![Laravel](https://img.shields.io/badge/laravel-%23FF2D20.svg?style=plastic&logo=laravel&logoColor=white) ![NuxtJS](https://img.shields.io/badge/Nuxt-black?style=plastic&logo=nuxt.js&logoColor=white) ![Socket.io](https://img.shields.io/badge/Socket.io-black?style=plastic&logo=socket.io&badgeColor=010101) ![Apache](https://img.shields.io/badge/apache-%23D42029.svg?style=plastic&logo=apache&logoColor=white) ![MariaDB](https://img.shields.io/badge/MariaDB-003545?style=plastic&logo=mariadb&logoColor=white) ![MongoDB](https://img.shields.io/badge/MongoDB-%234ea94b.svg?style=plastic&logo=mongodb&logoColor=white) ![MySQL](https://img.shields.io/badge/mysql-%2300f.svg?style=plastic&logo=mysql&logoColor=white) ![SQLite](https://img.shields.io/badge/sqlite-%2307405e.svg?style=plastic&logo=sqlite&logoColor=white) ![Inkscape](https://img.shields.io/badge/Inkscape-e0e0e0?style=plastic&logo=inkscape&logoColor=080A13) ![Jira](https://img.shields.io/badge/jira-%230A0FFF.svg?style=plastic&logo=jira&logoColor=white) ![Vagrant](https://img.shields.io/badge/vagrant-%231563FF.svg?style=plastic&logo=vagrant&logoColor=white)
![Shell](https://img.shields.io/badge/shell-%231563FF.svg?style=plastic&logo=shell&logoColor=white) ![Cakephp](https://img.shields.io/badge/cakephp-%23FF2D20.svg?style=plastic&logo=cakephp&logoColor=white) ![Arduino](https://img.shields.io/badge/arduino-%231563FF.svg?style=plastic&logo=arduino&logoColor=white) ![C++](https://img.shields.io/badge/c++-%231563FF.svg?style=plastic&logo=cplusplus&logoColor=white) ![MsSQLServer](https://img.shields.io/badge/mssql-%23FF2D20.svg?style=plastic&logo=microsoft-sql-server&logoColor=white) ![CodeIgniter](https://img.shields.io/badge/CodeIgniter-%23FF2D20.svg?style=plastic&logo=codeigniter&logoColor=white) ![Lumen](https://img.shields.io/badge/Lumen-%23FF2D20.svg?style=plastic&logo=lumen&logoColor=white) ![Node.js](https://img.shields.io/badge/Node.js-%2343853D.svg?style=plastic&logo=node.js&logoColor=white)