Exemplo n.º 1
0
    def mutate(root,info,input=None):

        interest=Interest(
            category_id=input.category_id,
            category_name=input.category_name
        )
        interest.save()
        return AddInterest(interest=interest)
Exemplo n.º 2
0
    def save_to_graph(self, photos):
        """
        parameters
        ----------
        photos: array - see the return of retrieve_photos_from_flickr() for the structure
        """

        self.stdout.write("* Saving photos information in the graph", ending='\r')

        # list of tags from all photos without duplicates (several photos may have the same tag)
        # used to cache the Interest objects and create the nodes if they don't exist
        # while reducing the number of queries on the database
        interests = {}

        index = 1
        for photo in photos:
            url = photo['url']

            try:
                picture = Picture(pictureURL=url)
                picture.save()
            except UniqueProperty:
                # a picture node with this url already exists in the graph
                # we will only update the interests it is RELATED_TO
                picture = Picture.nodes.get(pictureURL=url)

            for tag in photo['tags']:
                if tag == self.SEARCH_TAG:
                    # we don't add the 'couple' tag to the database because of course our app is about couples
                    continue

                # if the tag hasn't been added yet to the list of interests
                if tag not in interests:
                    try:
                        interest = Interest(label=tag)
                        interest.save()
                    except UniqueProperty:
                        # an interest node with this label already exists in the graph
                        interest = Interest.nodes.get(label=tag)

                    interests[tag] = interest
                else:
                    # the interest is already in the list, get it and avoid a useless query to the db
                    interest = interests[tag]

                picture.tags.connect(interest)

            self.stdout.write('* Photos saved: {}                         '.format(index),
                              ending='\r')

            index += 1

        self.stdout.write('')
Exemplo n.º 3
0
def bootstrap():
    """ Create database with fake data """
    db.create_all()
    os.environ['ADMIN_EMAIL'] = '*****@*****.**'
    os.environ['ADMIN_PASSWORD'] = '******'
    admin = User(email='*****@*****.**',
                 username='******',
                 password='******')
    admin.gravatar()
    db.session.commit()
    db.session.add(admin)
    User._bootstrap()
    Interest._bootstrap()
Exemplo n.º 4
0
def update_profile():
    form = UpdateAccountForm()
    # generates list of all interests and skills of the user
    present_interest = Interest.query.filter(
        Interest.users.any(username=current_user.username)).all()
    present_skill = Skill.query.filter(
        Skill.users.any(username=current_user.username)).all()
    if form.validate_on_submit():
        if form.resume.data:  # If user uploads their resume
            pic_file = save_pic(form.resume.data, 'static/resume')
            current_user.resume = pic_file
        if form.profile_picture.data:  # If user uploads their profile picture
            pic_file_ = save_pic(form.profile_picture.data,
                                 'static/profileimages')
            current_user.profile_picture = pic_file_
        current_user.username = form.username.data
        current_user.email = form.email.data
        current_user.fname = form.fname.data
        current_user.lname = form.lname.data
        current_user.phone_number = form.phone.data
        current_user.is_super_admin = form.is_admin.data
        current_user.is_actively_interviewing = form.is_actively_interviewing.data
        current_user.is_recruiter = form.is_recruiter.data
        current_user.facebook_link = form.facebook_link.data
        current_user.twitter_link = form.twitter_link.data
        current_user.linkedin_link = form.linkedin_link.data
        current_user.salary_expt = form.salary.data
        current_user.address = form.address.data
        skill = form.skills.data
        skills = {
            1: 'C++',
            2: 'Python',
            3: 'JavaScript',
            4: 'Java',
            5: 'React',
            6: 'Golang',
            7: 'Rust'
        }
        interest = form.interests.data
        interests = {
            1: 'Product Design',
            2: 'UI/UX',
            3: 'Software Development',
            4: 'Artificial Intelligence',
            5: 'Data Science',
            6: 'Game Development',
            7: 'Cyber Security'
        }
        if skill:
            for skl in present_skill:
                db.session.delete(skl)
            for choice in skill:
                current_user.skills.append(Skill(name=skills[choice]))
        if interest:
            for skl in present_interest:
                db.session.delete(skl)
            for choice in interest:
                current_user.interests.append(Interest(name=interests[choice]))
        db.session.commit()

        flash('Your account has been updated', 'success')
        return redirect(url_for('profile'))
    form.username.data = current_user.username
    form.email.data = current_user.email
    form.fname.data = current_user.fname
    form.lname.data = current_user.lname
    form.phone.data = current_user.phone_number
    if form.phone.data == None:
        form.phone.data = '+2340000000000'
    form.address.data = current_user.address
    form.is_admin.data = current_user.is_super_admin
    form.is_actively_interviewing.data = current_user.is_actively_interviewing
    form.is_recruiter.data = current_user.is_recruiter
    form.facebook_link.data = current_user.facebook_link
    form.twitter_link.data = current_user.twitter_link
    form.interests.data = present_interest
    form.skills.data = present_skill
    form.linkedin_link.data = current_user.linkedin_link
    form.salary.data = current_user.salary_expt
    return render_template('updateprofile.html',
                           title='Update Account',
                           form=form)
Exemplo n.º 5
0
def populateInterests():
    interest1 = Interest(
        Title="Science",
        ImageSource=
        ""
    )
    interest2 = Interest(
        Title="Books",
        ImageSource=
        "https://i.pinimg.com/736x/18/fc/c3/18fcc378c67c941f028dd37008df24fe--redd-foxx-funny-people.jpg"
    )
    interest3 = Interest(
        Title="Photography",
        ImageSource=
        "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQsiViwtNmqi1XuSE96XbIdHxbKG1uphIWBsk-8d-1MNTrKQSniMQ"
    )
    interest4 = Interest(
        Title="Technology",
        ImageSource="http://files.abovetopsecret.com/files/img/to56cb7f32.jpg")
    interest5 = Interest(
        Title="Education",
        ImageSource=
        ""
    )
    interest6 = Interest(
        Title="Cloud Computing",
        ImageSource=
        "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTg9empmm9j40YUfl-44iaPC7637Gv-r-5Uh8DmJy1gXfcdJcTG"
    )
    interest7 = Interest(
        Title="Movies",
        ImageSource=
        "https://images.pexels.com/photos/390089/film-movie-motion-picture-390089.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest8 = Interest(
        Title="Health",
        ImageSource=
        "https://images.pexels.com/photos/235922/pexels-photo-235922.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest9 = Interest(
        Title="Business",
        ImageSource=
        "https://images.pexels.com/photos/872957/pexels-photo-872957.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest10 = Interest(
        Title="Cooking",
        ImageSource=
        "https://images.pexels.com/photos/277253/pexels-photo-277253.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest11 = Interest(
        Title="Big Data",
        ImageSource=
        "https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcQNOE77gmOh5uxrsPxQNG3HJdQOPLXlXNb8iDYKHdrI2eA1OwGLXA"
    )
    interest12 = Interest(
        Title="Angular Js",
        ImageSource=
        ""
    )
    interest13 = Interest(
        Title="Food",
        ImageSource=
        "https://images.pexels.com/photos/5317/food-salad-restaurant-person.jpg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest14 = Interest(
        Title="Money",
        ImageSource=
        "https://images.pexels.com/photos/47344/dollar-currency-money-us-dollar-47344.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest15 = Interest(
        Title="Adventure",
        ImageSource=
        "https://images.pexels.com/photos/6758/wildernessculture-rei1440project-welltravelled-awesomeearth.jpg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest16 = Interest(
        Title="Design",
        ImageSource=
        "https://images.pexels.com/photos/5836/yellow-metal-design-decoration.jpg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    interest17 = Interest(
        Title="Sports",
        ImageSource=
        "https://images.pexels.com/photos/207710/pexels-photo-207710.jpeg?auto=compress&cs=tinysrgb&h=350"
    )
    interest18 = Interest(
        Title="Shopping",
        ImageSource=
        "https://images.pexels.com/photos/972804/pexels-photo-972804.jpeg?auto=compress&cs=tinysrgb&dpr=2&h=650&w=940"
    )
    db.session.add(interest1)
    db.session.add(interest2)
    db.session.add(interest3)
    db.session.add(interest4)
    db.session.add(interest5)
    db.session.add(interest6)
    db.session.add(interest7)
    db.session.add(interest8)
    db.session.add(interest9)
    db.session.add(interest10)
    db.session.add(interest11)
    db.session.add(interest12)
    db.session.add(interest13)
    db.session.add(interest14)
    db.session.add(interest15)
    db.session.add(interest16)
    db.session.add(interest17)
    db.session.add(interest18)
    db.session.commit()
Exemplo n.º 6
0
 def parse_interests():
     return [Interest(label=option.get('label'), category=interest.get('category'))
             for interest in interests for option in interest.get('options')]