diff --git a/Gemfile b/Gemfile
index 37e070584e47dd9f39a88014f8928e76cc949338..7a7f64807ef4bf2ae8c2b80efd1726a3e3d43aa2 100644
--- a/Gemfile
+++ b/Gemfile
@@ -100,6 +100,11 @@ group :development, :test do
   gem 'spring'
 
   gem 'sqlite3'
+
+  #JavaScript runtime
+  gem 'execjs'
+  gem 'therubyracer'
+  
 end
 
 group :test do
diff --git a/Gemfile.lock b/Gemfile.lock
new file mode 100644
index 0000000000000000000000000000000000000000..5581e23b9f1dd5365b99fcc3dfda6bf81f5982e1
--- /dev/null
+++ b/Gemfile.lock
@@ -0,0 +1,349 @@
+GEM
+  remote: https://rubygems.org/
+  specs:
+    abstract_type (0.0.7)
+    actionmailer (4.2.0)
+      actionpack (= 4.2.0)
+      actionview (= 4.2.0)
+      activejob (= 4.2.0)
+      mail (~> 2.5, >= 2.5.4)
+      rails-dom-testing (~> 1.0, >= 1.0.5)
+    actionpack (4.2.0)
+      actionview (= 4.2.0)
+      activesupport (= 4.2.0)
+      rack (~> 1.6.0)
+      rack-test (~> 0.6.2)
+      rails-dom-testing (~> 1.0, >= 1.0.5)
+      rails-html-sanitizer (~> 1.0, >= 1.0.1)
+    actionview (4.2.0)
+      activesupport (= 4.2.0)
+      builder (~> 3.1)
+      erubis (~> 2.7.0)
+      rails-dom-testing (~> 1.0, >= 1.0.5)
+      rails-html-sanitizer (~> 1.0, >= 1.0.1)
+    activejob (4.2.0)
+      activesupport (= 4.2.0)
+      globalid (>= 0.3.0)
+    activemodel (4.2.0)
+      activesupport (= 4.2.0)
+      builder (~> 3.1)
+    activerecord (4.2.0)
+      activemodel (= 4.2.0)
+      activesupport (= 4.2.0)
+      arel (~> 6.0)
+    activesupport (4.2.0)
+      i18n (~> 0.7)
+      json (~> 1.7, >= 1.7.7)
+      minitest (~> 5.1)
+      thread_safe (~> 0.3, >= 0.3.4)
+      tzinfo (~> 1.1)
+    adamantium (0.2.0)
+      ice_nine (~> 0.11.0)
+      memoizable (~> 0.4.0)
+    arel (6.0.3)
+    ast (2.1.0)
+    autoprefixer-rails (6.0.2)
+      execjs
+      json
+    axiom-types (0.1.1)
+      descendants_tracker (~> 0.0.4)
+      ice_nine (~> 0.11.0)
+      thread_safe (~> 0.3, >= 0.3.1)
+    bcrypt (3.1.10)
+    better_errors (2.1.1)
+      coderay (>= 1.0.0)
+      erubis (>= 2.6.6)
+      rack (>= 0.9.0)
+    binding_of_caller (0.7.2)
+      debug_inspector (>= 0.0.1)
+    bootstrap-sass (3.3.5.1)
+      autoprefixer-rails (>= 5.0.0.1)
+      sass (>= 3.3.0)
+    builder (3.2.2)
+    bullet (4.14.7)
+      activesupport (>= 3.0.0)
+      uniform_notifier (~> 1.9.0)
+    byebug (6.0.2)
+    chart-js-rails (0.0.9)
+      railties (> 3.1)
+    chronic (0.10.2)
+    climate_control (0.0.3)
+      activesupport (>= 3.0)
+    cocaine (0.5.7)
+      climate_control (>= 0.0.3, < 1.0)
+    coderay (1.1.0)
+    coercible (1.0.0)
+      descendants_tracker (~> 0.0.1)
+    coffee-rails (4.1.0)
+      coffee-script (>= 2.2.0)
+      railties (>= 4.0.0, < 5.0)
+    coffee-script (2.4.1)
+      coffee-script-source
+      execjs
+    coffee-script-source (1.9.1.1)
+    concord (0.1.5)
+      adamantium (~> 0.2.0)
+      equalizer (~> 0.0.9)
+    curb (0.8.8)
+    debug_inspector (0.0.2)
+    descendants_tracker (0.0.4)
+      thread_safe (~> 0.3, >= 0.3.1)
+    devise (3.5.1)
+      bcrypt (~> 3.0)
+      orm_adapter (~> 0.1)
+      railties (>= 3.2.6, < 5)
+      responders
+      thread_safe (~> 0.1)
+      warden (~> 1.2.3)
+    devise_token_auth (0.1.34)
+      devise (= 3.5.1)
+      rails (~> 4.2)
+    diff-lcs (1.2.5)
+    domain_name (0.5.24)
+      unf (>= 0.0.5, < 1.0.0)
+    dspace_rest_client (1.1.2)
+      curb (~> 0.8.6)
+      rest-client (>= 1.7, < 2)
+    equalizer (0.0.11)
+    erubis (2.7.0)
+    execjs (2.6.0)
+    fast_stack (0.1.0)
+      rake
+      rake-compiler
+    flamegraph (0.1.0)
+      fast_stack
+    flay (2.4.0)
+      ruby_parser (~> 3.0)
+      sexp_processor (~> 4.0)
+    flog (4.2.1)
+      ruby_parser (~> 3.1, > 3.1.0)
+      sexp_processor (~> 4.4)
+    globalid (0.3.6)
+      activesupport (>= 4.1.0)
+    gruff (0.6.0)
+      rmagick (>= 2.13.4)
+    http-cookie (1.0.2)
+      domain_name (~> 0.5)
+    i18n (0.7.0)
+    ice_nine (0.11.1)
+    jbuilder (2.3.1)
+      activesupport (>= 3.0.0, < 5)
+      multi_json (~> 1.2)
+    jquery-rails (4.0.5)
+      rails-dom-testing (~> 1.0)
+      railties (>= 4.2.0)
+      thor (>= 0.14, < 2.0)
+    jquery-turbolinks (2.1.0)
+      railties (>= 3.1.0)
+      turbolinks
+    json (1.8.3)
+    libv8 (3.16.14.7)
+    locastyle (0.0.1)
+    loofah (2.0.3)
+      nokogiri (>= 1.5.9)
+    mail (2.6.3)
+      mime-types (>= 1.16, < 3)
+    memoizable (0.4.2)
+      thread_safe (~> 0.3, >= 0.3.1)
+    mime-types (2.6.2)
+    mimemagic (0.3.0)
+    mina (0.3.7)
+      open4 (~> 1.3.4)
+      rake
+    mini_portile (0.6.2)
+    minitest (5.8.0)
+    multi_json (1.11.2)
+    netrc (0.10.3)
+    nokogiri (1.6.6.2)
+      mini_portile (~> 0.6.0)
+    open4 (1.3.4)
+    orientdb4r (0.5.1)
+      rest-client (~> 1.7)
+    orm_adapter (0.5.0)
+    paperclip (4.3.1)
+      activemodel (>= 3.2.0)
+      activesupport (>= 3.2.0)
+      cocaine (~> 0.5.5)
+      mime-types
+      mimemagic (= 0.3.0)
+    parser (2.2.2.6)
+      ast (>= 1.1, < 3.0)
+    pg (0.18.3)
+    procto (0.0.2)
+    puma (2.13.4)
+    rack (1.6.4)
+    rack-cors (0.4.0)
+    rack-mini-profiler (0.9.7)
+      rack (>= 1.1.3)
+    rack-test (0.6.3)
+      rack (>= 1.0)
+    rails (4.2.0)
+      actionmailer (= 4.2.0)
+      actionpack (= 4.2.0)
+      actionview (= 4.2.0)
+      activejob (= 4.2.0)
+      activemodel (= 4.2.0)
+      activerecord (= 4.2.0)
+      activesupport (= 4.2.0)
+      bundler (>= 1.3.0, < 2.0)
+      railties (= 4.2.0)
+      sprockets-rails
+    rails-deprecated_sanitizer (1.0.3)
+      activesupport (>= 4.2.0.alpha)
+    rails-dom-testing (1.0.7)
+      activesupport (>= 4.2.0.beta, < 5.0)
+      nokogiri (~> 1.6.0)
+      rails-deprecated_sanitizer (>= 1.0.1)
+    rails-html-sanitizer (1.0.2)
+      loofah (~> 2.0)
+    railties (4.2.0)
+      actionpack (= 4.2.0)
+      activesupport (= 4.2.0)
+      rake (>= 0.8.7)
+      thor (>= 0.18.1, < 2.0)
+    rainbow (2.0.0)
+    rake (10.4.2)
+    rake-compiler (0.9.5)
+      rake
+    rdoc (4.2.0)
+    reek (1.6.5)
+      parser (~> 2.2.0.pre.7)
+      rainbow (>= 1.99, < 3.0)
+      unparser (~> 0.2.2)
+    ref (1.0.5)
+    responders (2.1.0)
+      railties (>= 4.2.0, < 5)
+    rest-client (1.8.0)
+      http-cookie (>= 1.0.2, < 2.0)
+      mime-types (>= 1.16, < 3.0)
+      netrc (~> 0.7)
+    rmagick (2.15.4)
+    rsolr (1.0.12)
+      builder (>= 2.1.2)
+    ruby_parser (3.7.1)
+      sexp_processor (~> 4.1)
+    rubycritic (1.4.0)
+      flay (= 2.4.0)
+      flog (= 4.2.1)
+      parser (>= 2.2.0, < 3.0)
+      reek (= 1.6.5)
+      virtus (~> 1.0)
+    sass (3.4.18)
+    sass-rails (5.0.4)
+      railties (>= 4.0.0, < 5.0)
+      sass (~> 3.1)
+      sprockets (>= 2.8, < 4.0)
+      sprockets-rails (>= 2.0, < 4.0)
+      tilt (>= 1.1, < 3)
+    sdoc (0.4.1)
+      json (~> 1.7, >= 1.7.7)
+      rdoc (~> 4.0)
+    select2-rails (4.0.0)
+      thor (~> 0.14)
+    sexp_processor (4.6.0)
+    shoulda (3.5.0)
+      shoulda-context (~> 1.0, >= 1.0.1)
+      shoulda-matchers (>= 1.4.1, < 3.0)
+    shoulda-callback-matchers (1.1.3)
+      activesupport (>= 3)
+    shoulda-context (1.2.1)
+    shoulda-matchers (2.8.0)
+      activesupport (>= 3.0.0)
+    spring (1.4.0)
+    sprockets (3.3.4)
+      rack (~> 1.0)
+    sprockets-rails (2.3.3)
+      actionpack (>= 3.0)
+      activesupport (>= 3.0)
+      sprockets (>= 2.8, < 4.0)
+    sqlite3 (1.3.10)
+    therubyracer (0.12.2)
+      libv8 (~> 3.16.14.0)
+      ref
+    thor (0.19.1)
+    thread_safe (0.3.5)
+    tilt (2.0.1)
+    turbolinks (2.5.3)
+      coffee-rails
+    tzinfo (1.2.2)
+      thread_safe (~> 0.1)
+    uglifier (2.7.2)
+      execjs (>= 0.3.0)
+      json (>= 1.8.0)
+    unf (0.1.4)
+      unf_ext
+    unf_ext (0.0.7.1)
+    uniform_notifier (1.9.0)
+    unparser (0.2.4)
+      abstract_type (~> 0.0.7)
+      adamantium (~> 0.2.0)
+      concord (~> 0.1.5)
+      diff-lcs (~> 1.2.5)
+      equalizer (~> 0.0.9)
+      parser (~> 2.2.2)
+      procto (~> 0.0.2)
+    virtus (1.0.5)
+      axiom-types (~> 0.1)
+      coercible (~> 1.0)
+      descendants_tracker (~> 0.0, >= 0.0.3)
+      equalizer (~> 0.0, >= 0.0.9)
+    warden (1.2.3)
+      rack (>= 1.0)
+    web-console (2.2.1)
+      activemodel (>= 4.0)
+      binding_of_caller (>= 0.7.2)
+      railties (>= 4.0)
+      sprockets-rails (>= 2.0, < 4.0)
+    whenever (0.9.4)
+      chronic (>= 0.6.3)
+    will_paginate (3.0.7)
+
+PLATFORMS
+  ruby
+
+DEPENDENCIES
+  bcrypt (~> 3.1.7)
+  better_errors
+  bootstrap-sass
+  bullet
+  byebug
+  chart-js-rails
+  coffee-rails (~> 4.1.0)
+  devise
+  devise_token_auth
+  dspace_rest_client (~> 1.1.0)
+  execjs
+  flamegraph
+  gruff
+  jbuilder (~> 2.0)
+  jquery-rails
+  jquery-turbolinks
+  locastyle
+  mina
+  orientdb4r
+  paperclip
+  pg
+  puma
+  rack-cors
+  rack-mini-profiler
+  rails (= 4.2.0)
+  rdoc
+  rmagick
+  rsolr (~> 1.0.12)
+  rubycritic
+  sass-rails (~> 5.0)
+  sdoc (~> 0.4.0)
+  select2-rails
+  shoulda
+  shoulda-callback-matchers (~> 1.1.1)
+  spring
+  sqlite3
+  therubyracer
+  turbolinks
+  uglifier (>= 1.3.0)
+  web-console (~> 2.0)
+  whenever
+  will_paginate (~> 3.0.5)
+
+BUNDLED WITH
+   1.10.6
diff --git a/app/controllers/collections_controller.rb b/app/controllers/collections_controller.rb
index 6edf2387280c0305d5a85cd77af40cb30647e494..0579097790de7c0b49400ad9676537504614a638 100644
--- a/app/controllers/collections_controller.rb
+++ b/app/controllers/collections_controller.rb
@@ -4,7 +4,7 @@ class CollectionsController < ApplicationController
   # GET /collections
   # GET /collections.json
   def index
-    @collections = collection_repository.all
+    @collections = collection_repository.find_all
   end
 
   # GET /collections/1
@@ -56,7 +56,7 @@ class CollectionsController < ApplicationController
   private
 
   def set_collection
-    @collection = collection_repository.find params[:id]
+    @collection = collection_repository.find_by_id params[:id]
   end
 
   def collection_repository
diff --git a/app/controllers/institutions_controller.rb b/app/controllers/institutions_controller.rb
index 96c21aa17d468af0acb632a45c2cbc9eb9de3bfc..0eb2ca291f822c645e854198ba8bfc22330a4d07 100644
--- a/app/controllers/institutions_controller.rb
+++ b/app/controllers/institutions_controller.rb
@@ -4,7 +4,7 @@ class InstitutionsController < ApplicationController
   # GET /institutions
   # GET /institutions.json
   def index
-    @institutions = institution_repository.all
+    @institutions = institution_repository.find_all
   end
 
   # GET /institutions/1
@@ -62,7 +62,7 @@ class InstitutionsController < ApplicationController
   private
 
   def set_institution
-    @institution = institution_repository.find("##{params[:id]}")
+    @institution = institution_repository.find_by_id("##{params[:id]}")
   end
 
   def institution_repository
diff --git a/app/controllers/learning_objects_controller.rb b/app/controllers/learning_objects_controller.rb
index 3ded253c23cd10465b3624db636413ac3bf7b848..c61bdb7186eec207c7a93fa77e28c051bf627df5 100644
--- a/app/controllers/learning_objects_controller.rb
+++ b/app/controllers/learning_objects_controller.rb
@@ -6,7 +6,7 @@ class LearningObjectsController < ApplicationController
   # GET /learning_objects
   # GET /learning_objects.json
   def index
-    @learning_objects = learning_object_repository.all
+    @learning_objects = learning_object_repository.find_all
   end
 
   # GET /learning_objects/1
@@ -73,7 +73,7 @@ class LearningObjectsController < ApplicationController
 
   # Use callbacks to share common setup or constraints between actions.
   def set_learning_object
-    @learning_object = learning_object_repository.find params[:id]
+    @learning_object = learning_object_repository.find_by_id params[:id]
   end
 
   # Never trust parameters from the scary internet, only allow the white list through.
diff --git a/app/controllers/management/users_controller.rb b/app/controllers/management/users_controller.rb
index 4c6de9d93bc5e37daaf181fa63076625b43d02ae..59cb720fc36173eda9ba0768332ff15b055cc60d 100644
--- a/app/controllers/management/users_controller.rb
+++ b/app/controllers/management/users_controller.rb
@@ -3,7 +3,7 @@ class Management::UsersController < ManagementController
   before_action :set_roles, only: [:new, :edit]
 
   def index
-    @users = user_repository.all
+    @users = user_repository.find_all
   end
 
   # GET /users/1
@@ -61,7 +61,7 @@ class Management::UsersController < ManagementController
 
   # Use callbacks to share common setup or constraints between actions.
   def set_user
-    @user = user_repository.find params[:id]
+    @user = user_repository.find_by_id params[:id]
   end
 
   # Never trust parameters from the scary internet, only allow the white list through.
diff --git a/app/controllers/welcome_controller.rb b/app/controllers/welcome_controller.rb
index c3353d960229b8a8882d717ab44145b7996c6ea7..459c4f54a1d0b7fa82b9c72c612d96a69de2af38 100644
--- a/app/controllers/welcome_controller.rb
+++ b/app/controllers/welcome_controller.rb
@@ -10,17 +10,17 @@ class WelcomeController < ApplicationController
     end
 
     @General = mainPage["highlights"].collect do |id|
-      repository.for(:learning_object).find(id)
+      repository.for(:learning_object).find_by_id(id)
     end
 
     @Subjects = repository.for(:subject).find_all.take(8)
     @Subjects.delete_if do |subject|
-      if subject['highlights'].nil? || subject['highlights'].empty?
+      if subject.highlights.nil? || subject.highlights.empty?
         true
       end
     end
     @Subjects.each do |subject|
-      object = repository.for(:learning_object).find(subject['highlights'].first)
+      object = repository.for(:learning_object).find_by_id(subject.highlights.first)
       subject['first_highlight'] = object
     end
 
diff --git a/app/models/attribute.rb b/app/models/attribute.rb
new file mode 100644
index 0000000000000000000000000000000000000000..af0710be3bf389b3fec994e82629afaccbc4e199
--- /dev/null
+++ b/app/models/attribute.rb
@@ -0,0 +1,6 @@
+class Attribute
+  include ActiveModel::Model
+
+  attr_accessor :id, :key, :value
+  
+end
\ No newline at end of file
diff --git a/app/models/learning_object.rb b/app/models/learning_object.rb
index ea388a9a040c6343d088c54d39b2527623b59c50..a81ad0253324282f7cf6adc5396c8763e399616c 100644
--- a/app/models/learning_object.rb
+++ b/app/models/learning_object.rb
@@ -2,7 +2,8 @@ class LearningObject
   include ActiveModel::Model
   attr_accessor :id, :id_dspace, :rid, :name, :description,
                 :thumbnail, :date_creation, :last_modified,
-                :type, :bitstreams, :metadata, :likes, :views, :downloads
+                :type, :bitstreams, :metadata, :likes, :views, 
+                :downloads, :subjects, :attributes
 
   validates_presence_of :name, :date_creation, :type, :likes, :views, :downloads
   validates_numericality_of :likes, greater_than_or_equal_to: 0
@@ -17,17 +18,26 @@ class LearningObject
     @subjects ||= learning_object_repository.get_subjects(self)
   end
 
+  def attributes
+    @attributes ||= learning_object_repository.get_attributes(self)
+  end
+
   def categories
     get_metadata_value_of 'dc.subject.category'
   end
 
   def get_metadata_value_of key
-    values = @metadata.select { |v| v["key"] == key }
-    unless values.empty?
-      return values.first["value"]
-    end
+    get_metadata_values_of(key).first
   end
 
+  def get_metadata_values_of key
+    values = []
+    @metadata.each do |m|
+      values << m["value"] if m["key"] == key
+    end
+    values
+  end
+  
   private
 
   def defaults
diff --git a/app/models/subject.rb b/app/models/subject.rb
index 58e25fa4d60b98f24147ccee7839f0dee1e01bc7..a76b5da86bb24b66ca55e7cb654bd8e0a38dacb8 100644
--- a/app/models/subject.rb
+++ b/app/models/subject.rb
@@ -1,5 +1,15 @@
 class Subject
   include ActiveModel::Model
 
-  attr_accessor :id, :dateCreation, :description, :highlights, :name
+  attr_accessor :id, :date_creation, :description, :highlights, :name,
+                :learning_objects
+
+  def learning_objects
+    @learning_objects ||= subject_repository.get_learning_objects(self)
+  end
+  
+  def subject_repository
+    Portalmec::Application.repository.for :subject
+  end
+
 end
\ No newline at end of file
diff --git a/app/repositories/orient_db/attribute_repository.rb b/app/repositories/orient_db/attribute_repository.rb
new file mode 100644
index 0000000000000000000000000000000000000000..4c5373180e4f1aac39f80384dd3c8f78288ff5ba
--- /dev/null
+++ b/app/repositories/orient_db/attribute_repository.rb
@@ -0,0 +1,30 @@
+module OrientDb
+  class AttributeRepository < Base
+    
+    def find_by_key_and_value(key, value)
+        result = connection.query sprintf("SELECT FROM %s WHERE key = '%s' AND value = '%s'", odb_class, key, value)
+        build_objects(result)
+    end
+
+    def build_object(args={})
+      subject = nil
+      unless args.nil?
+        subject = Attribute.new(:id => args["@rid"])
+        args.each do |var, val|
+          var_name = "@"+var
+          if subject.respond_to?(var)
+            subject.instance_variable_set(var_name, val)
+          end
+        end
+      end
+      subject
+    end
+    
+    private
+
+    def odb_class
+        "Attribute"
+    end
+
+  end
+end
\ No newline at end of file
diff --git a/app/repositories/orient_db/base.rb b/app/repositories/orient_db/base.rb
index 53599f9125b196ed8d4d04a645719a3419ad04c8..349ff82fd3f7c1c418682e5bb6b620d7280fc57e 100644
--- a/app/repositories/orient_db/base.rb
+++ b/app/repositories/orient_db/base.rb
@@ -1,12 +1,67 @@
 class OrientDb::Base
+  include OrientDb::Methods::GenericMethods
 
   def initialize(orientdb_connection)
     @connection = orientdb_connection
   end
 
-
   def connection
     @connection
   end
 
+  def find_by_id(id)
+    result = get_by_rid(id)
+    build_object result
+  end
+
+  # Example:
+    #   list = repository.for(:learning_objects).find_all
+    #   list.each do |learning_object|
+    #     learning_object.inspect <LearningObject model>
+    #   end
+  def find_all
+    objects_hash = connection.query "SELECT FROM #{odb_class}", :limit => -1
+    objects = build_objects(objects_hash) || []
+  end
+
+  def find_all_from_offset_to_limit(offset,limit)
+    objects_hash = connection.query "SELECT FROM #{odb_class} SKIP #{offset}", :limit => limit
+    objects = build_objects(objects_hash) || []
+  end
+
+  def create(object)
+    hash = build_hash(object)
+    result = connection.create_document(hash)
+    object.id = result["@rid"]
+    object
+  end
+
+  def build_objects(hash=[])
+    objects = []
+    hash.each do |h|
+      objects << build_object(h)
+    end
+    objects
+  end
+
+  def build_hash(object)
+    hash = {}
+    hash["@class"] = odb_class
+    object.instance_variables.each do |var|
+        var_name = var.to_s.gsub(/\A@/,"")
+        hash[var_name] = object.instance_variable_get(var)
+    end
+    hash
+  end
+
+  def build_object(args={})
+    raise NoMethodError, "You must implement this method"
+  end
+
+  private
+
+  def odb_class
+    raise NoMethodError, "You must implement this method"
+  end
+
 end
diff --git a/app/repositories/orient_db/carousel_repository.rb b/app/repositories/orient_db/carousel_repository.rb
index a8a2d8c0a0c529dba2d7a43e4d02a0adfe9f5dd5..cf39aa0748c95cf833c983d7cb2b01cc5730e4c7 100644
--- a/app/repositories/orient_db/carousel_repository.rb
+++ b/app/repositories/orient_db/carousel_repository.rb
@@ -20,5 +20,11 @@ module OrientDb
         return nil
     end
 
+    private
+
+    def odb_class
+      "Carousel"
+    end
+
   end
 end
diff --git a/app/repositories/orient_db/collection_repository.rb b/app/repositories/orient_db/collection_repository.rb
index a597b2ca3db07e288434284982510cccedbef7a6..80e6b177add29920a2b038400e8267d5baee9449 100644
--- a/app/repositories/orient_db/collection_repository.rb
+++ b/app/repositories/orient_db/collection_repository.rb
@@ -2,18 +2,6 @@ module OrientDb
   class CollectionRepository < Base
     include OrientDb::Methods::EdgeMethods
 
-    def all
-      hash = connection.query "SELECT FROM Collection"
-      collections = build_collections(hash)
-    end
-
-    # Usage:
-    #   collection = repository.for(:collections).find '#14:14'
-    def find(id)
-      result = connection.query "SELECT FROM #{id}"
-      build_collection result.first
-    end
-
     # Usage:
     #   repository.for(:collections).destroy collection
     #
@@ -21,22 +9,17 @@ module OrientDb
       connection.command sprintf("DELETE VERTEX %s", collection.id)
     end
 
-    private
-
-    def build_collection(args={})
+    def build_object(args={})
       Collection.new(
           :id => args["@rid"],
           :name => args["name"]
       )
     end
 
-    def build_collections(hash=[])
-      collections = []
-      hash.each do |h|
-        collections << build_collection(h)
-      end
+    private
 
-      collections
+    def odb_class
+      "Collection"
     end
 
   end
diff --git a/app/repositories/orient_db/institution_repository.rb b/app/repositories/orient_db/institution_repository.rb
index 6bc0e470f058a2ff7d0dce33ec002053c7472200..028e13b96f04e1747c3e2825ad6e2638be70bb41 100644
--- a/app/repositories/orient_db/institution_repository.rb
+++ b/app/repositories/orient_db/institution_repository.rb
@@ -2,24 +2,6 @@ module OrientDb
   class InstitutionRepository < Base
     include OrientDb::Methods::EdgeMethods
 
-    # Example:
-    #   list = repository.for(:institutions).all
-    #   list.each do |institution|
-    #     institution_object.inspect <LearningObject model>
-    #   end
-    def all
-      hash = connection.query "SELECT FROM Institution"
-      institutions = build_institutions(hash)
-    end
-
-    # Usage:
-    #   institution = repository.for(:institutions).get_by_dspace_id 123
-    #
-    def find(id)
-      result = connection.query "SELECT FROM #{id}"
-      build_institution result.first
-    end
-
     def create(name, url)
       connection.command sprintf("INSERT INTO Institution (name) VALUES ('%s')", name)
     end
@@ -31,21 +13,17 @@ module OrientDb
       connection.command sprintf("DELETE VERTEX %s", institution.id)
     end
 
-    private
-
-    def build_institution(args={})
+    def build_object(args={})
       return Institution.new(
         :id => args["@rid"],
         :title => args["title"],
       )
     end
 
-    def build_institutions(hash=[])
-      institutions = []
-      hash.each do |h|
-        institutions << build_institution(h)
-      end
-      return institutions
+    private
+
+    def odb_class
+      "Institution"
     end
 
   end
diff --git a/app/repositories/orient_db/learning_object_repository.rb b/app/repositories/orient_db/learning_object_repository.rb
index b15496835163b9045c69a23ef74d9d8c324583f1..689a95815eeeccde16e5b7c97ae8e90b42252f14 100644
--- a/app/repositories/orient_db/learning_object_repository.rb
+++ b/app/repositories/orient_db/learning_object_repository.rb
@@ -14,41 +14,35 @@ module OrientDb
       create_edge "Likes", user.rid, learning_object.id
     end
 
-    # Example:
-    #   list = repository.for(:learning_objects).all
-    #   list.each do |learning_object|
-    #     learning_object.inspect <LearningObject model>
-    #   end
-    def all
-      learning_objects_hash = connection.query "SELECT FROM LearningObject"
-      build_learning_objects(learning_objects_hash) || []
-    end
-
     # Usage:
     #   learning_object = repository.for(:learning_objects).get_by_dspace_id 123
     #
     def get_by_dspace_id(id_dspace)
-      result = connection.query "SELECT FROM LearningObject WHERE id_dspace=#{id_dspace}"
-      build_learning_object result.first
+      result = select_by_property(odb_class, "id_dspace", id_dspace)
+      build_object result.first
     end
 
-    # Usage:
-    #   learning_object = repository.for(:learning_objects).get_by_dspace_id 123
-    #
-    def find(id)
-      result = connection.query "SELECT FROM #{id}"
-      build_learning_object result.first
+    def get_subjects(learning_object)
+      result = get_edges_end("IsAbout","out",learning_object.id)
+      Portalmec::Application.repository.for(:subject).build_objects(result)
     end
 
-    def create(name, url)
-      connection.command sprintf("INSERT INTO LearningObject (name,URL) VALUES ('%s','%s')", name, url)
+    def get_attributes(learning_object)
+      result = get_edges_end("HasAttr","out",learning_object.id)
+      Portalmec::Application.repository.for(:attribute).build_objects(result)
+    end
+
+    def create_relations(learning_object)
+      edges = create_edges_from_array("IsAbout",learning_object.id,learning_object.subjects, true)
+      edges << create_edges_from_array("HasAttr",learning_object.id,learning_object.attributes, true)
+      edges.flatten
     end
 
     # Usage:
     #   repository.for(:learning_objects).destroy learning_object
     #
     def destroy(learning_object)
-      connection.command sprintf("DELETE VERTEX LearningObject where @rid = '%s'", learning_object.id)
+      connection.command sprintf("DELETE VERTEX #{odb_class} where @rid = '%s'", learning_object.id)
     end
 
     ##
@@ -66,18 +60,10 @@ module OrientDb
       learning_objects = build_learning_objects(learning_objects_hash) || []
     end
 
-    private
-
-    def count_likes(learning_object)
-      get_in_edges_count "Likes", learning_object.id
-    end
-
-    def count_views(learning_object)
-      get_in_edges_count "Views", learning_object.id
-    end
-
-    def build_learning_object(args={})
-      lo = LearningObject.new(:id => args["@rid"],
+    def build_object(args={})
+      lo = nil
+      unless args.nil?
+        lo = LearningObject.new(:id => args["@rid"],
                               :name => args["name"],
                               :description => args["description"],
                               :thumbnail => args["thumbnail"],
@@ -87,28 +73,44 @@ module OrientDb
                               :bitstreams => args["bitstreams"],
                               :metadata => args["metadata"],
                               :last_modified => args["last_modified"])
-
-      unless args["in_Likes"].nil?
-        lo.likes = args["in_Likes"].count
-      else
-        lo.likes = 0
+        lo.likes = args.has_key?("in_Likes") ? args["in_Likes"].size : 0
+        lo.views = args.has_key?("in_Views") ? args["in_Views"].size : 0
       end
+      lo
+    end
+
+    def build_hash
+      hash = super
+      hash.delete("likes")
+      hash.delete("views")
+      hash.delete("downloads")
+      hash.delete("subjects")
+      hash.delete("attributes")
+      hash
+    end
+
+    private
 
-      unless args["in_Views"].nil?
-        lo.views = args["in_Views"].count
-      else
-        lo.views = 0
+    def create_edges_from_array(edge_class, id, array, unique=false)
+      edges = []
+      array.each do |o|
+        unless unique && edge_exists?(edge_class, id, o.id)
+          edges << create_edge(edge_class, id, o.id)
+        end
       end
+      edges
+    end
 
-      lo
+    def odb_class
+      "LearningObject"
     end
 
-    def build_learning_objects(hash=[])
-      learning_objects = []
-      hash.each do |h|
-        learning_objects << build_learning_object(h)
-      end
-      learning_objects
+    def count_likes(learning_object)
+      get_in_edges_count "Likes", learning_object.id
+    end
+
+    def count_views(learning_object)
+      get_in_edges_count "Views", learning_object.id
     end
 
   end
diff --git a/app/repositories/orient_db/main_page_repository.rb b/app/repositories/orient_db/main_page_repository.rb
index 3b27e083e1bd9a4aa921ededa4827a67321d2a79..3663b56d481e6f1a0af7d6460d4fb228709af896 100644
--- a/app/repositories/orient_db/main_page_repository.rb
+++ b/app/repositories/orient_db/main_page_repository.rb
@@ -25,5 +25,11 @@ module OrientDb
       connection.command "update #{id} #{operation} #{atributte} = #{new}"
     end
 
+    private
+
+    def odb_class
+      "MainPage"
+    end
+
   end
 end
diff --git a/app/repositories/orient_db/subject_repository.rb b/app/repositories/orient_db/subject_repository.rb
index b7889fc55699145ad441d9729a9e7ebde0d12b8b..f61ce039052400071af43deae864f31520fbb861 100644
--- a/app/repositories/orient_db/subject_repository.rb
+++ b/app/repositories/orient_db/subject_repository.rb
@@ -1,27 +1,51 @@
 module OrientDb
   class SubjectRepository < Base
+    include OrientDb::Methods::EdgeMethods
 
-    def find_all
-      connection.query "SELECT FROM Subject", limit: -1
+    def find_by_name(name)
+      result = select_by_property(odb_class, "name", name)
+      build_object(result.first)
     end
 
-    def find_by_id(id)
-      connection.query "SELECT FROM Subject where @rid = '#{id}'"
+    def destroy_data(id)
+        connection.command "DELETE VERTEX Subject where @rid = '#{id}'"
     end
 
-    def destroy_data(id)
-        return @connection.command "DELETE VERTEX Subject where @rid = '#{id}'"
-      rescue
-        return nil
+    def update(id,operation,atributte,new_value)
+      puts "update #{id} #{operation} #{atributte} = #{new_value}"
+      connection.command "update #{id} #{operation} #{atributte} = #{new_value}"
+    end
+
+    def get_learning_objects(subject)
+      result = get_edges_end("IsAbout","in",subject.id)
+      Portalmec::Application.repository.for(:learning_object).build_objects(result)
     end
 
-    def get_objects(id)
-      connection.query "select expand(in('IsAbout')) from #{id}"
+    def build_hash
+      hash = super
+      hash.delete("learning_objects")
+      hash
     end
 
-    def update(id,operation,atributte,new)
-      puts "update #{id} #{operation} #{atributte} = #{new}"
-      return @connection.command "update #{id} #{operation} #{atributte} = #{new}"
+    def build_object(args={})
+      subject = nil
+      unless args.nil?
+        subject = Subject.new(:id => args["@rid"])
+        args.each do |var, val|
+          var_name = "@"+var
+          if subject.respond_to?(var)
+            subject.instance_variable_set(var_name, val)
+          end
+        end
+      end
+      subject
     end
+
+    private
+
+    def odb_class
+      "Subject"
+    end
+
   end
 end
diff --git a/app/repositories/orient_db/user_repository.rb b/app/repositories/orient_db/user_repository.rb
index 28d930e8fe63de55ae83da66a0adc94188e25555..8068a3f257520146b9ee68607ad1773452c4dca3 100644
--- a/app/repositories/orient_db/user_repository.rb
+++ b/app/repositories/orient_db/user_repository.rb
@@ -24,5 +24,11 @@ module OrientDb
       (result.count > 0)
     end
 
+    private
+
+    def odb_class
+      "User"
+    end
+
   end
 end
diff --git a/config/initializers/repositories/dspace.rb b/config/initializers/repositories/dspace.rb
index f2a71dbd217f0bff4b7c836afa4107a2859cbd94..48a75aab0f7308207fba630d98dd22130408b31c 100644
--- a/config/initializers/repositories/dspace.rb
+++ b/config/initializers/repositories/dspace.rb
@@ -15,4 +15,4 @@ else
   config = dspace_configs.fetch(Rails.env)
 
   set_dspace_config config['host'], config['port'], config['rest_webapp_name'], config['solr_webapp_name']
-end
+end
\ No newline at end of file
diff --git a/config/initializers/repositories/repositories.rb b/config/initializers/repositories/repositories.rb
index caebcb6b5995c78904a92585f573b3f540cd2990..bc014e7c0215152ef0799b463f60a7531a847f6c 100644
--- a/config/initializers/repositories/repositories.rb
+++ b/config/initializers/repositories/repositories.rb
@@ -26,6 +26,8 @@ Repository::Environments.create :development do |repository|
   repository.register :user, UserRepositoryProxy.new(OrientDb::UserRepository.new(OrientDb::Client.instance))
   repository.register :subject, OrientDb::SubjectRepository.new(OrientDb::Client.instance)
   repository.register :institution, OrientDb::InstitutionRepository.new(OrientDb::Client.instance)
+  repository.register :subject, OrientDb::SubjectRepository.new(OrientDb::Client.instance)
+  repository.register :attribute, OrientDb::AttributeRepository.new(OrientDb::Client.instance)
   repository.register :collection, OrientDb::CollectionRepository.new(OrientDb::Client.instance)
 end
 
@@ -35,6 +37,7 @@ Repository::Environments.create :test do |repository|
   repository.register :webLink, OrientDb::WeblinkRepository.new(OrientDb::Client.instance)
   repository.register :user, UserRepositoryProxy.new(OrientDb::UserRepository.new(OrientDb::Client.instance))
   repository.register :subject, OrientDb::SubjectRepository.new(OrientDb::Client.instance)
+  repository.register :attribute, OrientDb::AttributeRepository.new(OrientDb::Client.instance)
   repository.register :collection, OrientDb::CollectionRepository.new(OrientDb::Client.instance)
 end
 
@@ -44,5 +47,6 @@ Repository::Environments.create :production do |repository|
   repository.register :webLink, OrientDb::WeblinkRepository.new(OrientDb::Client.instance)
   repository.register :user, UserRepositoryProxy.new(OrientDb::UserRepository.new(OrientDb::Client.instance))
   repository.register :subject, OrientDb::SubjectRepository.new(OrientDb::Client.instance)
+  repository.register :attribute, OrientDb::AttributeRepository.new(OrientDb::Client.instance)
   repository.register :collection, OrientDb::CollectionRepository.new(OrientDb::Client.instance)
 end
diff --git a/config/orientdb.yml b/config/orientdb.yml
index 33d7dae7cccd737915522aaa7ff9abc3ac34f4fb..07945002eacbdb755ce3058bf6ff217959fc76e8 100644
--- a/config/orientdb.yml
+++ b/config/orientdb.yml
@@ -1,6 +1,6 @@
 development: &development
   host: localhost
-  database: portalmec
+  database: PortalMEC
   username: admin
   password: admin
   port: 2480
diff --git a/lib/orient_db/methods/edge_methods.rb b/lib/orient_db/methods/edge_methods.rb
index 0784e472dcadd44dd8f858ef478248aed7319e7c..0e5c8c448fe1059c3b09917ae569dd2c3d340731 100644
--- a/lib/orient_db/methods/edge_methods.rb
+++ b/lib/orient_db/methods/edge_methods.rb
@@ -13,6 +13,15 @@ module OrientDb
         connection.command "CREATE EDGE #{edge_class} FROM #{from_id} TO #{to_id}"
       end
 
+      def get_edges_end(edge_class, type, vertex_id)
+        connection.query sprintf("SELECT expand(%s('%s')) FROM %s", type, edge_class, vertex_id)
+      end
+
+      def edge_exists?(edge_class, from_id, to_id)
+        edge = connection.query sprintf("SELECT outE('%s') FROM %s WHERE out('%s') CONTAINS %s", edge_class, from_id, edge_class, to_id)
+        !edge.empty?
+      end
+
     end
   end
 end
diff --git a/lib/orient_db/methods/generic_methods.rb b/lib/orient_db/methods/generic_methods.rb
new file mode 100644
index 0000000000000000000000000000000000000000..fe39c0f59a86e6f4bd672ef4186c2dfc632feee6
--- /dev/null
+++ b/lib/orient_db/methods/generic_methods.rb
@@ -0,0 +1,15 @@
+module OrientDb
+  module Methods
+    module GenericMethods
+
+      def get_by_rid(rid)
+        connection.get_document(rid)
+      end
+
+      def select_by_property(from, prop_name, prop_value)
+        connection.query sprintf("SELECT FROM %s WHERE %s = '%s'", from, prop_name, prop_value)
+      end
+
+    end
+  end
+end
\ No newline at end of file
diff --git a/lib/tasks/mainPage.rake b/lib/tasks/mainPage.rake
index 3f2ca563b1a1ba69ad6b3a6dfd63da927295759e..69f84cb36e8a8dace047d8321cbfec20366bcf3b 100644
--- a/lib/tasks/mainPage.rake
+++ b/lib/tasks/mainPage.rake
@@ -7,12 +7,10 @@ namespace :mainPage do
     subjects = repository.for(:subject).find_all
     subjects.each do |subject|
       # select all the learning objects about that subject
-      objects = repository.for(:subject).get_objects(subject['@rid'])
+      objects = subject.learning_objects
       # transform the objects to RankingItem
       objects = objects.collect do |object|
-        downloads = 0
-        object = repository.for(:learning_object).find(object['@rid'])
-        Ranking::Item.new(object.id,object.views.first["COUNT"],downloads,object.likes.first["COUNT"])
+        Ranking::Item.new(object.id,object.views,object.downloads,object.likes)
       end
       # rank them
       rater = Ranking::Rater.new(Ranking::Strategies::BasicRater.new(0,1,100))
@@ -21,10 +19,10 @@ namespace :mainPage do
       (general_highlights << objects.take(5)).flatten!
 
       # add the object to the subject highlight
-      puts subject['name']
-      repository.for(:subject).update(subject['@rid'],'set','highlights','[]')
+      puts subject.name
+      repository.for(:subject).update(subject.id,'set','highlights','[]')
       objects.each do |object|
-        repository.for(:subject).update(subject['@rid'],'add','highlights',object.name)
+        repository.for(:subject).update(subject.id,'add','highlights',object.name)
       end
     end
     puts 'Generating the main page highlights'
diff --git a/lib/tasks/orientdb.rake b/lib/tasks/orientdb.rake
index 504aa1f120363f4c7d471ca017e70808a053ad6f..3568b65a4c4833f8a5555ec49943557811480bc1 100644
--- a/lib/tasks/orientdb.rake
+++ b/lib/tasks/orientdb.rake
@@ -8,4 +8,78 @@ namespace :orientdb do
     migrations.run
   end
 
+  task create_learning_object_relations: :environment do
+    desc "Create LearningObject relations based on its metadata"
+
+    lo_repo = Portalmec::Application.repository.for(:learning_object)
+    subject_repo = Portalmec::Application.repository.for(:subject)
+    attr_repo = Portalmec::Application.repository.for(:attribute)
+
+    # Quantity of LearningObjects fetched on each iteration
+    limit = 1000
+    # Starting point from where LearningObjects will be fetched
+    offset = 0
+
+    loop do
+      p " --> importing LearningObjects from #{offset} to #{offset+limit}"
+
+      begin
+        # Get LearningObjects from OrientDB (from offset to offset+limit)
+        learning_objects = lo_repo.find_all_from_offset_to_limit(offset,limit)
+      rescue
+        # Sleeps for a while to wait database's recovery
+        sleep(30.seconds)
+        # Goes to next iteration to retry
+        next
+      else
+        # Terminate loop if there are no more LearningObjects
+        break if learning_objects.empty?
+
+        learning_objects.each do |lo|
+          metadata = get_unique_matadata_keys(lo)
+          subjects = metadata["dc.subject.category"]
+          subjects ||= []
+          metadata.delete("dc.subject.category")
+          lo.subjects=[]
+          lo.attributes=[]
+
+          subjects.each do |subject_name|
+            subject = subject_repo.find_by_name(subject_name)
+            if subject.nil?
+              subject = Subject.new(:name => subject_name)
+              subject_repo.create(subject)
+            end
+            lo.subjects << subject
+          end
+
+          metadata.each do |key, value|
+            value.each do |v|
+              attribute = attr_repo.find_by_key_and_value(key,v).first
+              if attribute.nil?
+                attribute = Attribute.new(:key => key, :value => v)
+                attr_repo.create(attribute)
+              end
+              lo.attributes << attribute
+            end
+          end
+            
+          p lo_repo.create_relations(lo)
+        end
+        
+        offset += limit
+      end
+    end
+
+  end
+
+  def get_unique_matadata_keys(lo)
+    hash = {}
+    lo.metadata.each do |m|
+      unless hash.has_key?(m['key'])
+        hash[m['key']] = lo.get_metadata_values_of(m['key'])
+      end
+    end
+    hash
+  end
+
 end
\ No newline at end of file