Skip to content

Latest commit

 

History

History
executable file
·
123 lines (91 loc) · 4.13 KB

README.md

File metadata and controls

executable file
·
123 lines (91 loc) · 4.13 KB

your-celebrity-match

The application uses IBM Watson User Modeling and Twitter to find the celebrities that are similar to your personality. Twitter is being use to get the tweets for a given handler, the text from those tweets is send to User Modeling, who analyze the text and reply with a personality profile. That profile is compared to celebrity profiles to find the most similar.

The application is running in Bluemix.

Live demo: http://your-celebrity-match.mybluemix.net/

Getting Started

This instructions will help you install the celebrities app in your local environment.

  1. Get the code by downloading this file or cloning the git repository with:

    $ git clone [email protected]:watson-developer-cloud/yourcelebritymatch.git
  2. Install node (use v0.10.31)

  3. Install mongodb

  4. Install the npm modules:

    $ npm install

    Note: Make sure you are in the project directory, the package.json file should be visible.

  5. Start mongodb

    $ mongod

    (Run this in a separate terminal window)

  6. Update the Twitter and User Modeling credentials in config/config.js

    {
      user_modeling: {
        url:      '<url>',
        username: '<username>',
        password: '<password>'
      },
    
      twitter: {
        consumer_key:       '<consumer_key>',
        consumer_secret:    '<consumer_secret>',
        access_token_key:   '<access_token_key>',
        access_token_secret:'<access_token_secret>'
      }
    }

    Instructions on how to create an app and get User Modeling credentials here.

    Instructions on how to create an app and get Twitter credentials here.

  7. Start the app

    $ node app.js
  8. Update the database with the celebrities by going to:

    http://localhost:3000/celebrities/syncdb

User Modeling Credentials

The credentials for the services are stored in the [VCAP_SERVICES][vcap_environment] environment variable. In order to get them you need to first create and bind the service to your application.

There are two ways to get the credentials, you can use Bluemix to access your app and view the VCAP_SERVICES there or you can run:

$ cf env <application-name>

Example output:

  System-Provided:
  {
  "VCAP_SERVICES": {
    "user_modeling": [{
        "credentials": {
          "password": "<password>",
          "url": "<url>",
          "username": "<username>"
        },
      "label": "user_modeling",
      "name": "um-service",
      "plan": "user_modeling_free_plan"
   }]
  }
  }

You need to copy username, password.

Celebrities

The application comes with two profiles: @germanatt and @nfriedly. If you want to add more profiles you will have to:

  1. Choose a person to include as 'celebrity'. You need at least 100 different words writted by that person, blog posts, tweets, text messages, emails will work.
  2. Get the profile by using the User Modeling service with the text you have and save the json profile in the profiles folder. Make sure the file has the .json extension as in the examples provided.
  3. Start the app and go to: http://localhost:3000/celebrities/syncdb. It will repopulate the application database and add the new profile.

License

This sample code is licensed under Apache 2.0. Full license text is available in LICENSE.

Contributing

See CONTRIBUTING.

Open Source @ IBM

Find more open source projects on the IBM Github Page