DEV Community

Pranjal Jain
Pranjal Jain

Posted on • Edited on

atlashackathon22 Hiring Application

What I built

An application for applying for jobs, The portal is for both employers and job applicants. In my portal there can be be status updates on jobs. Where applicants upload all the details like education, experience & certifications. And also employers will be able to check all the applicant details, change status of the applications and much more. There is also a chat feature available which I have used with third party service.

Category Submission

  • Choose Your Own Adventure
  • Think Outside the JS Box

App Link

Github Repo

Screenshots

Image description
Image description
Image description
Image description
Image description
Apart from the screenshot, here is a link to the demo video.
Demo Video

Description

This application is build on Flutter as a native mobile for both android and IOS, the backend for the app is made in ExpressJS with multiple libraries to debug APIs. The UI of the application is very basic as it’s not not prioritised at the moment. And then I created comphrensive APIs for doing multiple database operations.

In express JS, mondodb Package is used, where I am running mongoDB queries like this

login (Auth.js)

MongoClient.connect(uri, {
    useNewUrlParser: true,
    useUnifiedTopology: true,
})
    .then((client) => {
        client
            .db('Hirect')
            .collection('Users')
            .find({ email: email, password: password })
            .toArray((err, results) => {
                err && res.status(400).json({ error: err, status: 0 });
                if (results.length != 1)
                    res.status(401).json({ status: 0, message: 'User not found' });
                else res.status(200).json(results);
            });
        return client;
    })
    .catch((error) => {
        res.status(500).json({ status: 'ERROR', err: error });
        console.error(error);
    });
Enter fullscreen mode Exit fullscreen mode

SignUp (Auth.js)

MongoClient.connect(uri, {
    useNewUrlParser: true,
    useUnifiedTopology: true,
})
    .then((client) => {
        client
            .db('Hirect')
            .collection('Users')
            .find({ email: email })
            .toArray((err, results) => {
                if (results.length === 1) {
                    res.status(100).json({ status: 0, message: 'Email already found' });
                } else {
                    client
                        .db('Hirect')
                        .collection('Users')
                        .insertOne(data)
                        .then((e) => {
                            res.status(200).json({
                                status: 1,
                                message: 'User Registered',
                                res: { ...e, ...data },
                            });
                        });
                }
            });

        return client;
    })
    .catch((error) => {
        res.status(500).json({ status: 'ERROR', err: error });
        console.error(error);
    });
Enter fullscreen mode Exit fullscreen mode

Here you can see, As I dont want multiple users I first check for user then I move forward with creating one, And here the user is being created with initial fields which are required so that the application does not break.

To update I am using addToSet feature of MongoDB

  • I learned a lot about CRUD operations of mongoDB and the ton of features I am provided with it.

Updating Jobs (jobs.js)

client
    .db('Hirect')
    .collection('Users')
    .updateOne({ email }, { $addToSet: { jobPosts: { ...jobDetails, jobID } } })
    .then((e) => {
        res
            .status(200)
            .json({ status: 'SUCCESS', res: e, email, jobDetails, jobID });
    });
Enter fullscreen mode Exit fullscreen mode

Link to Source Code

Github Repo

Permissive License

MIT

Background

As I am pursuing masters in computer science, I found that the current portals miss few things, which I tried to incorporate in the application like status update on applications, job posting rating and reviews and few other features. The app has a lot of features which are hard to document is such short time. I would suggest to explore the app and find out for yourself. The best thing about it is There is no need for a previous database. You can just run the backend server. and then run the app and the data will be created then and there. MongoDB Rocks!

How I built it

As it was a very comphrensive application. I created APIs using ExpressJS. There I have used a modular approach where I divided endpoints in multiple modules which had there own multiple function which were in turn performing mongoDB operations.

Top comments (0)