Skip to content

rajivghandi767/portfolio-website

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

My Portfolio Website

Screen Shot 2024-08-22 at 16 22 01

🚀 Overview

This repository contains the source code for my portfolio website, which showcases my skills, projects, and experience as a self-taught Software Engineer as well as my personal interests of travel & collecting credit card points.

The website is built with a Django REST backend and a React.js frontend, and is hosted locally on my Raspberry Pi4B using Docker and Jenkins for continuous integration and delivery.

🌟 Features

  • Django REST API: Backend API built with Django REST Framework for serving dynamic content.
  • React Frontend: A modern React.js frontend that interacts with the Django backend.
  • Dockerized Environment: Both the frontend and backend are containerized using Docker for easy setup and consistency across environments.
  • Jenkins CI/CD: Jenkins is used to automate the build, test, and deployment processes.
  • Responsive Design: Adapts to various screen sizes, from mobile to desktop.
  • Dynamic Content: Projects, Blog and Card data are served from the backend API.
  • Dark Mode: Includes support for dark mode.

🔧 Technologies Used

  • Backend:
    • Python
    • Django
    • Django REST Framework
  • Frontend:
  • Containerization:
    • Docker
  • CI/CD:
    • Jenkins
  • Database:
    • SQLite

📂 Project Structure

.
└── 📁portfolio-website
    └── 📁backend
        └── 📁blog                # Django app with models, views, and serializers
        └── 📁info                # Django app with models, views, and serializers
        └── 📁portfolio_website   # Django project settings and URLs
        └── 📁projects            # Django app with models, views, and serializers
        └── 📁wallet              # Django app with models, views, and serializers
        └── db.sqlite3
        └── Dockerfile            # Dockerfile for backend
        └── manage.py             # Django management script
        └── requirements.txt      # Python dependencies
    └── 📁frontend
        └── 📁src
            └── 📁components      # Reusable React components
                └── Banner.jsx
                └── Bio.jsx
                └── Blog.jsx
                └── Contact.jsx
                └── Footer.jsx
                └── NavBar.jsx
                └── Projects.jsx
                └── Wallet.jsx
            └── App.jsx           # Main React app component
            └── index.css         # Entry point for the React app
            └── main.jsx
        └── Dockerfile            # Dockerfile for frontend
        └── index.html            # Main HTML file
        └── package.json          # Frontend dependencies and scripts
    └── docker-compose.yaml       # Docker Compose configuration
    └── Jenkinsfile               # Jenkins pipeline configuration
    └── LICENSE                   # License file
    └── README.md                 # This file

🚀 Getting Started

Prerequisites

Ensure you have Docker & Docker Compose installed on your machine. Jenkins installation is optional.

Installation

  1. Clone the repository:

    git clone https://github.com/rajivghandi767/portfolio-website.git
  2. Docker Setup:

    Navigate to the project directory:

    cd portfolio-website

    Build and start the containers using Docker Compose:

    docker compose up -d

    This command will set up both the Django backend and the React frontend.

  3. Jenkins Setup:

    • Add a new pipeline project in Jenkins.
    • Configure the pipeline to use the Jenkinsfile from this repository.
    • The pipeline will automate the process of building, testing, and deploying the application.

Accessing the Application

  • Django Backend: http://localhost:8000
  • React Frontend: http://localhost:4000

Stopping the Application

To stop the application, run:

docker compose down

🚀 Deployment

This project is designed to be hosted locally using Docker and Jenkins. The Docker containers ensure that the environment is consistent, while Jenkins automates the CI/CD pipeline.

📄 License

This project is licensed under the MIT License. See the LICENSE file for more details.

👤 Author

Rajiv Wallace
LinkedInEmail