Your RhoConnect source adapter model can use any of these methods to interact with your backend service. Refer to the source adapter sample for a complete example.
Login to your backend service (optional).
def login MyWebService.login(current_user.login) end
Logoff from your backend service (optional).
def logoff MyWebService.logoff(current_user.login) end
Query your backend service and build a hash of hashes (required).
This method must assign
@result
to a hash of hashes. If @result is nil
or {}
, the master document will be erased from redis.
def query parsed = JSON.parse(RestClient.get("#{@base}.json").body) @result = {} parsed.each do |item| @result[item["product"]["id"].to_s] = item["product"] end if parsed end
Search your backend based on params and build a hash of hashes (optional). Similar to query, however the master document accumulates the data in @result
instead of replacing when it runs.
def search(params) parsed = JSON.parse(RestClient.get("#{@base}.json").body) @result = {} parsed.each do |item| if item["product"]["name"].downcase == params['name'].downcase @result[item["product"]["id"].to_s] = item["product"] end end if parsed end
Next, you will need to add search to your Rhodes application. For details, see the Rhodes search section.
Create a new record in the backend (optional).
RhoConnect can establish a ‘link’ between the local record id provided by the client and the new record id provided by the backend service. To enable this link, return the new record id as a string.
def create(create_hash) res = MyWebService.create(create_hash) # return new product id so we establish a client link res.new_id end
Update an existing record in the backend (optional).
def update(update_hash) end
Delete an existing record in the backend (optional).
def delete(delete_hash) MyWebService.delete(delete_hash['id']) end
Returns the current user which called the adapter. For example, you could filter results for a specific user in your query method:
def query @result = MyWebService.get_records_for_user(current_user.login) end
Saves the current state of @result
to redis and assigns it to nil
. Typically this is used when your adapter has to paginate through backend service data.
def query @result = {} ('a'..'z').each_with_index do |letter,i| @result ||= {} @result.merge!( DictionaryService.get_records_for(letter) ) stash_result if i % 2 == 0 end end
If your Rhodes application sends blobs as a part of the create/update operation - you must implement this method inside of your Source Adapter Model and do not use default implementation where blob is stored in the tempfile provided by Rack, because RhoConnect processing is asynchronous and there is no guarantee that the temporary file will exist at the actual time when create
is called.
The following example stores the file permanently and keeps its :filename
argument as another object attribute.
def store_blob(obj,field_name,blob) # ... custom code to store the blob file ... my_stored_filename = do_custom_store[blob[:filename]] obj['filename'] = my_stored_filename end
Sometimes, different groups of users share the common source data. To leverage this, you can implement the following method in your Source Adapter Model to provide custom partition names for the users with shared data. In this case, RhoConnect will store the data for MD of the grouped users using your custom partition name, which will reduce the memory footprint in Redis. From this standpoint, app
partition is the edge-case of the custom user partitioning where all users share the same data for the particular source.
To use the custom user partitioning, implement the following class method in your Source Adapter’s model:
class Product < Rhoconnect::Model::Base # group users by the first letter def self.partition_name(user_id) return user_id[0] end end
You can access your model’s document data by with get_data
method. By default, when called without arguments - it returns the Master Document (:md).
# some custom controller's method that has access to model def my_custom_method my_model_md = @model.get_data end