π A platform for creating and sharing stories.
- Introduction
- Features
- Installation
- Usage
- Routes
- Views
- Configuration
- Contributing
- License
- Video Introduction
Welcome to Storybooks, a platform that lets you create, read, and share stories. Whether you're a writer or a reader, Storybooks offers a space to explore and share creative narratives.
π Key features of Storybooks:
- π Create Stories: Writers can draft and publish stories with rich text and multimedia.
- π Read Stories: Readers can immerse themselves in a diverse collection of stories.
- π Collaboration: Collaborate with other writers and co-create stories.
- π Personal Library: Save and organize your favorite stories in your library.
- π User Profiles: Create a unique profile to showcase your stories and writing style.
π οΈ Get started with Storybooks:
- Clone this repository:
git clone https://github.com/your-username/storybooks.git
- Navigate to the project directory:
cd storybooks
- Install dependencies:
npm install
- Configure environment variables: Refer to
config/
directory.
π Explore stories on Storybooks:
- Start the server:
npm start
- Open your browser and go to
http://localhost:3000
- Browse through the available stories.
- Writers can log in and create new stories.
π Explore the routes available in Storybooks:
/
: Home page with a curated list of featured stories./stories
: Browse and search for stories./stories/:id
: View a specific story./dashboard
: Writer's dashboard to manage created stories.
ποΈβπ¨οΈ Understand the different views in Storybooks:
dashboard.hbs
: Writer's dashboard UI.error/404.hbs
: Custom 404 page.error/500.hbs
: Custom error page.layouts/login.hbs
: Login layout.layouts/main.hbs
: Main layout for other pages.login.hbs
: Login page.partials/_add_btn.hbs
: Add button UI.partials/_header.hbs
: Header UI.stories/add.hbs
: UI for adding new stories.stories/edit.hbs
: UI for editing existing stories.stories/index.hbs
: UI for listing stories.stories/show.hbs
: UI for viewing a single story.
βοΈ Configure your Storybooks environment:
config/config.env
: Set up environment variables for your project.config/db.js
: Database configuration.config/passport.js
: Passport authentication setup.
π€ We welcome your contributions! Here's how you can contribute:
- Fork this repository.
- Create a new branch:
git checkout -b feature/your-feature
- Make changes and commit:
git commit -m "Add your message"
- Push to the branch:
git push origin feature/your-feature
- Open a pull request.
Securely authenticate users with Google OAuth2:
-
Implementation of Google OAuth2: Integrate Google authentication using OAuth2 to enable users to log in to your Storybooks platform using their Google accounts.
-
Route for Initiating Authentication (
/auth/google
): This route is responsible for initiating the Google OAuth2 authentication process. When users click on the "Login with Google" button, they are directed to this route to begin the authentication flow. -
Callback Route for Handling OAuth2 Response (
/auth/google/callback
): After users grant permission to your application, Google redirects them back to this route with an authorization code. This route handles the callback from Google and exchanges the code for an access token. -
Passport.js Middleware: Utilize the power of Passport.js middleware to handle authentication and session management seamlessly. Passport's
passport-google-oauth20
strategy is employed to streamline the Google OAuth2 authentication process.
-
Create Google Developer Project:
- Access the Google Developers Console.
- Set up a new project and activate the Google+ API.
- Generate OAuth2 credentials (client ID and client secret) to allow secure communication between your application and Google services.
-
Configure Credentials:
- Safely store your Google OAuth2 credentials in the
config/config.env
file of your project. These credentials will be used to identify and authenticate your application with Google services.
- Safely store your Google OAuth2 credentials in the
-
Install Required Packages:
- Install the necessary packages for Google OAuth2 integration using the command:
npm install passport passport-google-oauth20 express-session
.
- Install the necessary packages for Google OAuth2 integration using the command:
-
Passport.js Setup:
- In your main application file (e.g.,
app.js
), initialize Passport.js usingpassport.initialize()
andpassport.session()
middleware functions.
- In your main application file (e.g.,
-
Configure Google Strategy:
- Configure the Google OAuth2 strategy using
passport-google-oauth20
. Set the client ID, client secret, and callback URL.
- Configure the Google OAuth2 strategy using
-
Route and Controller Implementation:
- Create routes within your
routes/auth.js
file to handle Google authentication. Implement corresponding controller functions to initiate the authentication process and manage the callback.
- Create routes within your
-
Update Views:
- Enhance your relevant views (e.g., login page) by adding a "Login with Google" button that directs users to the
/auth/google
route to start the authentication flow.
- Enhance your relevant views (e.g., login page) by adding a "Login with Google" button that directs users to the
By integrating Google OAuth2 into your Storybooks project, you provide users with a convenient and secure method of logging in, further enhancing their experience on the platform.