m-elewa / freelancers-market

Laravel Project to help freelance websites clients and freelancers to find each other.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Freelancers Market

Freelancers Market is a platform works like a broker between the clients and the freelancers while the actual work and pay done on the freelance website that both the freelancer and the client are using. How it works? clients can link their jobs on the platform to let freelancers apply on their jobs. Then the client can invite the best suited freelancer(s) to apply on his job on The freelance website.

Basic Features

  • Real-time notifications on self hosted laravel echo server.
  • Full-text search with Laravel Scout and TNTSearch.
  • Shipped with testing units to test the application using PHPUnit.
  • Clean, high quality and easy to understand code.
  • Compatible with PHP 7.4 and Laravel 7.
  • Dockerized developing environment to speed up the installation process.
  • Ability to seed fake data in the database.
  • Utilize Redis for broadcasting, caching, queues and sessions.
  • Ability to debug and track the development environment with Laravel Telescope and Horizon.
  • And more...

Requirements

In order to use Freelancers Market, you will need:

Installation

  1. Install the project
git clone --recurse-submodules https://github.com/m-elewa/freelancers-market.git \
    && cd freelancers-market \
    && git submodule update --remote \
    && cd laradock \
    && cp env-example .env
  1. Change HOST_DOMAIN and ACME_EMAIL in .env file to your website domain and email
  2. Run Docker Containers with make up command from the root directory or from laradock directory run
docker-compose up -d --build --scale nginx=3
  1. Setup the application by running make setup from the root directory or from laradock directory run
docker-compose exec --user=laradock workspace composer setup

You can now login with admin@example.com and password as password

Tips

  • run make test-database to create test database for tests
  • run make test to test the application
  • run make seed to drop all tables then migrate and seed the database
  • for Laravel Telescope go to https//{YOURDOMAIN.COM}/telescope
  • for Laravel Horizon go to https//{YOURDOMAIN.COM}/horizon
  • for Portainer go to {YOURDOMAIN.COM}:9010
  • for phpMyAdmin go to {YOURDOMAIN.COM}:8080
  • to enter the Workspace container run make bash or
docker-compose exec --user=laradock workspace bash
  • change the freelance website name and domain in .env file
FREELANCE_WEBSITE_NAME="Freelance Website"
FREELANCE_WEBSITE_DOMAIN="example.com/"
  • to index the existing jobs run make scout-import
  • If you need to flush the jobs index run make scout-flush

Great open-source projects used to help build Freelancers Market

To Do

  • use ElasticSearch as the search engine
  • use AJAX and Vue.js for the search page
  • create admin control panel
  • add realtime messaging system
  • add more search filters
  • add more tests

Issues

If you come across any issues please report them here.

Contributing

Contributing to the Freelancers Market project are welcome, please feel free to make any pull requests, or email me a feature request you would like to see in the future to Mahmoud Elewa at mahmoud.elewa.999@gmail.com.

Security Vulnerabilities

If you discover a security vulnerability within Freelancers Market, please send an email to Mahmoud Elewa at mahmoud.elewa.999@gmail.com, or create a pull request if possible.

Disclaimer

Before using this project with any freelance website you have to make sure first that this website allow it and it does not violate any of their Terms of Service.

License

The Freelancers Market is open-sourced software licensed under the MIT license.

About

Laravel Project to help freelance websites clients and freelancers to find each other.

License:MIT License


Languages

Language:PHP 68.8%Language:HTML 30.4%Language:Makefile 0.6%Language:Vue 0.2%