rhoconnect 3.4.5 → 4.0.0.beta.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/CHANGELOG.md +57 -3
- data/Gemfile +9 -7
- data/Gemfile.lock +37 -37
- data/Rakefile +18 -7
- data/bench/benchapp/Gemfile +1 -1
- data/bench/benchapp/config.ru +0 -3
- data/bench/benchapp/controllers/ruby/application.rb +17 -0
- data/bench/benchapp/controllers/ruby/application_controller.rb +17 -0
- data/bench/benchapp/controllers/ruby/mock_adapter_controller.rb +8 -0
- data/bench/benchapp/controllers/ruby/queue_mock_adapter_controller.rb +8 -0
- data/bench/benchapp/{sources → models/ruby}/mock_adapter.rb +1 -1
- data/bench/benchapp/{sources → models/ruby}/queue_mock_adapter.rb +0 -0
- data/bench/benchapp/spec/{sources → models/ruby}/mock_adapter_spec.rb +1 -1
- data/bench/benchapp/spec/{sources → models/ruby}/queue_mock_adapter_spec.rb +1 -1
- data/bench/benchapp/spec/spec_helper.rb +2 -2
- data/bench/blobapp/Gemfile +1 -1
- data/bench/blobapp/config.ru +0 -3
- data/bench/blobapp/controllers/ruby/application_controller.rb +17 -0
- data/bench/blobapp/controllers/ruby/blob_adapter_controller.rb +8 -0
- data/bench/blobapp/{sources → models/ruby}/blob_adapter.rb +9 -2
- data/bench/blobapp/spec/{sources → models/ruby}/blob_adapter_spec.rb +1 -1
- data/bench/blobapp/spec/spec_helper.rb +1 -1
- data/bench/lib/bench/cli.rb +1 -1
- data/bench/scripts/blob_cud_script.rb +1 -1
- data/bench/scripts/query_md_script.rb +1 -1
- data/bench/scripts/query_only_script.rb +1 -1
- data/bench/scripts/query_script.rb +1 -1
- data/bench/scripts/test_query_script.rb +7 -1
- data/bench/spec/mock_adapter_spec.rb +1 -1
- data/bench/spec/result_spec.rb +3 -3
- data/bin/rhoconnect +5 -3
- data/commands/dtach/dtach_install.rb +2 -2
- data/commands/execute.rb +8 -3
- data/commands/generators/app.rb +3 -3
- data/commands/generators/controller.rb +6 -0
- data/commands/generators/model.rb +6 -0
- data/commands/generators/source.rb +3 -3
- data/commands/generators/update.rb +1 -1
- data/commands/redis/redis_about.rb +2 -2
- data/commands/redis/redis_download.rb +1 -1
- data/commands/redis/redis_install.rb +4 -3
- data/commands/redis/redis_restart.rb +4 -4
- data/commands/redis/redis_start.rb +5 -4
- data/commands/redis/redis_startbg.rb +5 -4
- data/commands/redis/redis_status.rb +13 -0
- data/commands/redis/redis_stop.rb +3 -3
- data/commands/rhoconnect/config.rb +28 -16
- data/commands/rhoconnect/flushdb.rb +1 -2
- data/commands/rhoconnect/get_token.rb +15 -11
- data/commands/rhoconnect/restart.rb +13 -5
- data/commands/rhoconnect/set_admin_password.rb +8 -8
- data/commands/rhoconnect/start.rb +74 -16
- data/commands/rhoconnect/startbg.rb +1 -1
- data/commands/rhoconnect/startdebug.rb +1 -1
- data/commands/rhoconnect/stop.rb +13 -1
- data/commands/rhoconnect/web.rb +5 -5
- data/commands/rhoconnect_console/console.rb +7 -5
- data/commands/{rhoconnect → rhoconnect_spec}/spec.rb +0 -0
- data/commands/rhoconnect_war/war.rb +9 -9
- data/commands/utilities/blank_app.ru +56 -0
- data/commands/utilities/redis_runner.rb +54 -19
- data/doc/authentication.txt +80 -6
- data/doc/blob-sync.txt +104 -97
- data/doc/bulk-sync.txt +1 -1
- data/doc/client-java.txt +3 -3
- data/doc/client-objc.txt +2 -2
- data/doc/client.txt +4 -4
- data/doc/command-line.txt +105 -200
- data/doc/data-partitioning.txt +40 -0
- data/doc/deploying.txt +249 -77
- data/doc/extending-rhoconnect-server.txt +40 -57
- data/doc/heroku-addon.txt +2 -0
- data/doc/install.txt +45 -95
- data/doc/introduction.txt +1 -1
- data/doc/java-plugin.txt +365 -190
- data/doc/metadata.txt +1 -1
- data/doc/migration.txt +108 -142
- data/doc/preparing-production.txt +1 -1
- data/doc/push-backend-setup.txt +2 -0
- data/doc/push-client-setup-android.txt +78 -0
- data/doc/push-client-setup-bb.txt +81 -0
- data/doc/push-client-setup-ios.txt +70 -0
- data/doc/push-client-setup-rps.txt +200 -0
- data/doc/push-client-setup.txt +63 -66
- data/doc/push-server-setup.txt +67 -40
- data/doc/push-testing.txt +29 -0
- data/doc/push.txt +21 -6
- data/doc/rest-api.txt +128 -55
- data/doc/rhoconnect-redis-stack.txt +120 -0
- data/doc/settings.txt +4 -12
- data/doc/source-adapters-intro.txt +28 -0
- data/doc/source-adapters.txt +235 -272
- data/doc/stats-middleware.txt +9 -29
- data/doc/supported-platforms.txt +21 -30
- data/doc/testing.txt +40 -42
- data/doc/tutorial.txt +72 -57
- data/examples/simple/Gemfile +1 -1
- data/examples/simple/application.rb +4 -5
- data/examples/simple/my_server.rb +2 -2
- data/examples/simple/settings/settings.yml +1 -1
- data/generators/rhoconnect.rb +151 -50
- data/generators/templates/application/Gemfile +1 -1
- data/generators/templates/application/Rakefile +3 -3
- data/generators/templates/application/config.ru +1 -4
- data/generators/templates/application/controllers/application_controller.rb +17 -0
- data/generators/templates/application/controllers/js/application_controller.js +14 -0
- data/generators/templates/application/controllers/ruby/application_controller.rb +17 -0
- data/generators/templates/application/package.json +8 -0
- data/generators/templates/application/rcgemfile +2 -5
- data/generators/templates/application/settings/settings.yml +3 -3
- data/generators/templates/application/spec/application_controller_spec.rb +23 -0
- data/generators/templates/application/spec/js_spec.rb +25 -0
- data/generators/templates/application/spec/spec_helper.rb +21 -7
- data/generators/templates/source/controllers/js/controller.js +7 -0
- data/generators/templates/source/controllers/ruby/controller.rb +8 -0
- data/generators/templates/source/controllers/ruby/controller_spec.rb +27 -0
- data/generators/templates/source/models/js/model.js +46 -0
- data/generators/templates/source/{source_adapter.rb → models/ruby/model.rb} +15 -10
- data/generators/templates/source/{source_spec.rb → models/ruby/model_spec.rb} +1 -1
- data/install.sh +5 -5
- data/installer/unix-like/create_texts.rb +2 -2
- data/installer/unix-like/rho_connect_install_constants.rb +2 -2
- data/installer/unix-like/rho_connect_install_utilities.rb +1 -1
- data/installer/utils/constants.rb +4 -4
- data/js-adapters/ballroom.js +216 -0
- data/js-adapters/node.rb +52 -0
- data/js-adapters/node_channel.rb +181 -0
- data/js-adapters/request.js +27 -0
- data/js-adapters/response.js +57 -0
- data/js-adapters/rhoconnect_helpers.js +60 -0
- data/js-adapters/router.js +60 -0
- data/js-adapters/server.js +5 -0
- data/lib/rhoconnect/api/app/ans_login.rb +3 -3
- data/lib/rhoconnect/api/app/bulk_data.rb +10 -10
- data/lib/rhoconnect/api/app/fast_delete.rb +11 -10
- data/lib/rhoconnect/api/app/fast_insert.rb +11 -10
- data/lib/rhoconnect/api/app/fast_update.rb +11 -10
- data/lib/rhoconnect/api/app/login.rb +5 -5
- data/lib/rhoconnect/api/app/push_deletes.rb +12 -11
- data/lib/rhoconnect/api/app/push_objects.rb +12 -11
- data/lib/rhoconnect/api/app/query.rb +8 -7
- data/lib/rhoconnect/api/app/queue_updates.rb +98 -94
- data/lib/rhoconnect/api/app/search.rb +8 -7
- data/lib/rhoconnect/api/client/client_get_db_doc.rb +5 -5
- data/lib/rhoconnect/api/client/client_set_db_doc.rb +8 -8
- data/lib/rhoconnect/api/client/create.rb +7 -7
- data/lib/rhoconnect/api/client/get_client_params.rb +4 -4
- data/lib/rhoconnect/api/client/list_client_docs.rb +17 -17
- data/lib/rhoconnect/api/client/register.rb +12 -12
- data/lib/rhoconnect/api/client/reset.rb +5 -5
- data/lib/rhoconnect/api/readstate/set_refresh_time.rb +9 -9
- data/lib/rhoconnect/api/source/get_source_params.rb +4 -4
- data/lib/rhoconnect/api/source/list_sources.rb +16 -16
- data/lib/rhoconnect/api/source/update_source_params.rb +6 -6
- data/lib/rhoconnect/api/store/get_db_doc.rb +4 -4
- data/lib/rhoconnect/api/store/set_db_doc.rb +7 -7
- data/lib/rhoconnect/api/system/get_adapter.rb +4 -4
- data/lib/rhoconnect/api/system/get_license_info.rb +8 -8
- data/lib/rhoconnect/api/system/login.rb +15 -15
- data/lib/rhoconnect/api/system/reset.rb +11 -11
- data/lib/rhoconnect/api/system/save_adapter.rb +4 -4
- data/lib/rhoconnect/api/system/stats.rb +22 -22
- data/lib/rhoconnect/api/user/create_user.rb +7 -7
- data/lib/rhoconnect/api/user/delete_client.rb +6 -6
- data/lib/rhoconnect/api/user/delete_user.rb +11 -10
- data/lib/rhoconnect/api/user/list_clients.rb +4 -4
- data/lib/rhoconnect/api/user/list_source_docs.rb +10 -10
- data/lib/rhoconnect/api/user/list_users.rb +3 -3
- data/lib/rhoconnect/api/user/ping.rb +3 -3
- data/lib/rhoconnect/api/user/show_user.rb +3 -3
- data/lib/rhoconnect/api/user/update_user.rb +5 -5
- data/lib/rhoconnect/api/user/user_get_db_doc.rb +5 -5
- data/lib/rhoconnect/api/user/user_set_db_doc.rb +10 -10
- data/lib/rhoconnect/api_token.rb +5 -6
- data/lib/rhoconnect/app.rb +6 -46
- data/lib/rhoconnect/application/init.rb +5 -2
- data/lib/rhoconnect/async.rb +76 -39
- data/lib/rhoconnect/bulk_data/bulk_data.rb +6 -4
- data/lib/rhoconnect/client.rb +59 -9
- data/lib/rhoconnect/condition/admin_required.rb +27 -0
- data/lib/rhoconnect/condition/client_required.rb +50 -0
- data/lib/rhoconnect/condition/login_required.rb +22 -0
- data/lib/rhoconnect/condition/source_required.rb +49 -0
- data/lib/rhoconnect/condition/verbs.rb +17 -0
- data/lib/rhoconnect/condition/verify_success.rb +19 -0
- data/lib/rhoconnect/controller/app_base.rb +74 -0
- data/lib/rhoconnect/controller/base.rb +68 -0
- data/lib/rhoconnect/controller/clients_controller.rb +79 -0
- data/lib/rhoconnect/controller/dynamic_adapter_controller.rb +93 -0
- data/lib/rhoconnect/controller/js_base.rb +124 -0
- data/lib/rhoconnect/controller/read_state_controller.rb +22 -0
- data/lib/rhoconnect/controller/source_adapter_base.rb +14 -0
- data/lib/rhoconnect/controller/sources_controller.rb +44 -0
- data/lib/rhoconnect/controller/store_controller.rb +25 -0
- data/lib/rhoconnect/controller/system_controller.rb +67 -0
- data/lib/rhoconnect/controller/users_controller.rb +99 -0
- data/lib/rhoconnect/db_adapter.rb +1 -3
- data/lib/rhoconnect/document.rb +159 -50
- data/lib/rhoconnect/handler/authenticate/execute_methods.rb +77 -0
- data/lib/rhoconnect/handler/authenticate/runner.rb +49 -0
- data/lib/rhoconnect/handler/authenticate.rb +3 -0
- data/lib/rhoconnect/handler/bulk_data.rb +28 -0
- data/lib/rhoconnect/handler/changes/engine.rb +271 -0
- data/lib/rhoconnect/handler/changes/execute_methods.rb +88 -0
- data/lib/rhoconnect/handler/changes/pass_through_runner.rb +11 -0
- data/lib/rhoconnect/handler/changes/runner.rb +53 -0
- data/lib/rhoconnect/handler/changes.rb +31 -0
- data/lib/rhoconnect/handler/helpers/auth_method.rb +29 -0
- data/lib/rhoconnect/handler/helpers/binding.rb +18 -0
- data/lib/rhoconnect/handler/helpers/bulk_data.rb +53 -0
- data/lib/rhoconnect/handler/helpers/source_job.rb +14 -0
- data/lib/rhoconnect/handler/helpers.rb +4 -0
- data/lib/rhoconnect/handler/plugin_callbacks/execute_methods.rb +99 -0
- data/lib/rhoconnect/handler/plugin_callbacks/runner.rb +28 -0
- data/lib/rhoconnect/handler/plugin_callbacks.rb +67 -0
- data/lib/rhoconnect/handler/query/engine.rb +93 -0
- data/lib/rhoconnect/handler/query/execute_methods.rb +21 -0
- data/lib/rhoconnect/handler/query/pass_through_runner.rb +35 -0
- data/lib/rhoconnect/handler/query/runner.rb +270 -0
- data/lib/rhoconnect/handler/query.rb +19 -0
- data/lib/rhoconnect/handler/search/engine.rb +60 -0
- data/lib/rhoconnect/handler/search/execute_methods.rb +32 -0
- data/lib/rhoconnect/handler/search/pass_through_runner.rb +18 -0
- data/lib/rhoconnect/handler/search/runner.rb +104 -0
- data/lib/rhoconnect/handler/search.rb +26 -0
- data/lib/rhoconnect/handler/sync.rb +29 -0
- data/lib/rhoconnect/jobs/source_job.rb +13 -4
- data/lib/rhoconnect/js_adapter.rb +79 -0
- data/lib/rhoconnect/license.rb +10 -2
- data/lib/rhoconnect/middleware/current_user.rb +14 -1
- data/lib/rhoconnect/middleware/helpers.rb +10 -93
- data/lib/rhoconnect/middleware/x_domain_session_wrapper.rb +1 -1
- data/lib/rhoconnect/model/base.rb +229 -0
- data/lib/rhoconnect/model/dynamic_adapter_model.rb +90 -0
- data/lib/rhoconnect/model/js_base.rb +121 -0
- data/lib/rhoconnect/ping/android.rb +1 -1
- data/lib/rhoconnect/predefined_adapters/bench_adapter.rb +7 -4
- data/lib/rhoconnect/read_state.rb +3 -3
- data/lib/rhoconnect/server.rb +159 -190
- data/lib/rhoconnect/source.rb +100 -11
- data/lib/rhoconnect/stats/record.rb +10 -10
- data/lib/rhoconnect/store.rb +905 -591
- data/lib/rhoconnect/{model.rb → store_orm.rb} +53 -115
- data/lib/rhoconnect/tasks.rb +18 -4
- data/lib/rhoconnect/test_methods.rb +30 -17
- data/lib/rhoconnect/user.rb +35 -17
- data/lib/rhoconnect/utilities.rb +1 -1
- data/lib/rhoconnect/version.rb +2 -2
- data/lib/rhoconnect/web-console/server.rb +29 -14
- data/lib/rhoconnect/web-console/views/home.js +10 -10
- data/lib/rhoconnect/web-console/views/new_ping.js +1 -1
- data/lib/rhoconnect.rb +120 -51
- data/rhoconnect.gemspec +4 -3
- data/spec/api/api_helper.rb +1 -6
- data/spec/api/app/fast_delete_spec.rb +4 -4
- data/spec/api/app/fast_insert_spec.rb +4 -4
- data/spec/api/app/fast_update_spec.rb +8 -8
- data/spec/api/app/push_deletes_spec.rb +2 -2
- data/spec/api/app/push_objects_spec.rb +5 -5
- data/spec/api/client/client_get_db_doc_spec.rb +6 -4
- data/spec/api/client/client_set_db_doc_spec.rb +3 -2
- data/spec/api/client/get_client_params_spec.rb +14 -0
- data/spec/api/client/list_client_docs_spec.rb +30 -20
- data/spec/api/client/reset_spec.rb +36 -0
- data/spec/api/source/get_source_params_spec.rb +23 -17
- data/spec/api/system/get_license_info_spec.rb +0 -20
- data/spec/api/system/login_spec.rb +8 -0
- data/spec/api/system/reset_spec.rb +0 -1
- data/spec/api/system/stats_spec.rb +5 -5
- data/spec/api/user/create_user_spec.rb +14 -6
- data/spec/api/user/delete_user_spec.rb +20 -18
- data/spec/api/user/list_users_spec.rb +5 -6
- data/spec/api/user/update_user_spec.rb +5 -4
- data/spec/apps/rhotestapp/config.ru +16 -1
- data/spec/apps/rhotestapp/controllers/js/js_sample_controller.js +23 -0
- data/spec/apps/rhotestapp/controllers/js/sample2_controller.js +32 -0
- data/spec/apps/rhotestapp/controllers/ruby/application_controller.rb +21 -0
- data/spec/apps/rhotestapp/controllers/ruby/sample_adapter_controller.rb +8 -0
- data/spec/apps/rhotestapp/models/js/js_sample.js +55 -0
- data/spec/apps/rhotestapp/models/js/sample2.js +25 -0
- data/spec/apps/rhotestapp/{sources → models/ruby}/base_adapter.rb +0 -0
- data/spec/apps/rhotestapp/{sources → models/ruby}/fixed_schema_adapter.rb +0 -0
- data/spec/apps/rhotestapp/{sources → models/ruby}/other_adapter.rb +0 -0
- data/spec/apps/rhotestapp/{sources → models/ruby}/sample_adapter.rb +0 -0
- data/spec/apps/rhotestapp/{sources → models/ruby}/simple_adapter.rb +2 -2
- data/spec/apps/rhotestapp/{sources → models/ruby}/sub_adapter.rb +0 -0
- data/spec/apps/rhotestapp/settings/settings.yml +0 -1
- data/spec/bulk_data/bulk_data_spec.rb +20 -5
- data/spec/cli/cli_spec.rb +83 -0
- data/spec/client_spec.rb +20 -17
- data/spec/client_sync_spec.rb +244 -406
- data/spec/controllers/js_base_spec.rb +89 -0
- data/spec/doc/doc_spec.rb +18 -18
- data/spec/document_spec.rb +29 -13
- data/spec/dynamic_adapter_spec.rb +6 -6
- data/spec/generator/generator_spec.rb +7 -4
- data/spec/jobs/bulk_data_job_spec.rb +14 -10
- data/spec/jobs/source_job_spec.rb +8 -8
- data/spec/license_spec.rb +5 -2
- data/spec/models/js_model_spec.rb +39 -0
- data/spec/node_spec.rb +42 -0
- data/spec/perf/store_perf_spec.rb +67 -12
- data/spec/ping/android_spec.rb +1 -1
- data/spec/read_state_spec.rb +1 -1
- data/spec/rhoconnect_spec.rb +1 -1
- data/spec/server/cors_spec.rb +14 -18
- data/spec/server/server_spec.rb +265 -88
- data/spec/server/stats_spec.rb +1 -1
- data/spec/source_adapter_spec.rb +54 -27
- data/spec/source_spec.rb +8 -3
- data/spec/source_sync_spec.rb +538 -468
- data/spec/spec_helper.rb +35 -4
- data/spec/stats/record_spec.rb +10 -10
- data/spec/{model_spec.rb → store_orm_spec.rb} +56 -54
- data/spec/store_spec.rb +159 -179
- data/spec/support/shared_examples.rb +36 -27
- data/spec/sync_states_spec.rb +40 -33
- data/spec/test_methods_spec.rb +18 -14
- data/spec/user_spec.rb +17 -30
- metadata +156 -52
- data/bench/benchapp/application.rb +0 -39
- data/bench/blobapp/application.rb +0 -44
- data/commands/rhoconnect/clean_start.rb +0 -9
- data/commands/rhoconnect/create_user.rb +0 -18
- data/commands/rhoconnect/delete_device.rb +0 -9
- data/commands/rhoconnect/delete_user.rb +0 -8
- data/commands/rhoconnect/reset.rb +0 -16
- data/commands/rhoconnect/reset_refresh.rb +0 -11
- data/generators/templates/application/application.rb +0 -43
- data/lib/rhoconnect/client_sync.rb +0 -434
- data/lib/rhoconnect/dynamic_adapter.rb +0 -91
- data/lib/rhoconnect/middleware/admin_user.rb +0 -23
- data/lib/rhoconnect/middleware/current_request.rb +0 -16
- data/lib/rhoconnect/middleware/login_required.rb +0 -22
- data/lib/rhoconnect/source_adapter.rb +0 -132
- data/lib/rhoconnect/source_sync.rb +0 -464
- data/spec/apps/rhotestapp/application.rb +0 -23
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
Server.api4 :clientregister, :post, "/rc/#{Rhoconnect::API_VERSION}/clients/:client_id/register", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
end
|
|
1
|
+
# Server.api4 :clientregister, :post, "/rc/#{Rhoconnect::API_VERSION}/clients/:client_id/register", \
|
|
2
|
+
# false, {:verb => :post, :url => ['/application/clientregister', '/api/application/clientregister'] } do |params,user,server|
|
|
3
|
+
# current_client = server.current_client
|
|
4
|
+
# if current_client.nil? and server.current_user and server.current_app
|
|
5
|
+
# fields = {:user_id => server.current_user.id}
|
|
6
|
+
# fields[:id] = params[:client_id].to_s
|
|
7
|
+
# fields[:app_id] = server.current_app.id
|
|
8
|
+
# current_client = Client.create(fields)
|
|
9
|
+
# end
|
|
10
|
+
# current_client.update_fields(params)
|
|
11
|
+
# server.status 200
|
|
12
|
+
# end
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
Server.api4 :clientreset, :post, "/rc/#{Rhoconnect::API_VERSION}/clients/:client_id/reset", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
end
|
|
1
|
+
# Server.api4 :clientreset, :post, "/rc/#{Rhoconnect::API_VERSION}/clients/:client_id/reset", \
|
|
2
|
+
# false, {:verb => :get, :url => ['/application/clientreset', '/api/application/clientreset']} do |params,user,server|
|
|
3
|
+
# ClientSync.reset(server.current_client, params)
|
|
4
|
+
# server.status 200
|
|
5
|
+
# end
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
Server.api4 :set_refresh_time, :put, "/rc/#{Rhoconnect::API_VERSION}/readstate/users/:user_name/sources/:source_name", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
end
|
|
1
|
+
# Server.api4 :set_refresh_time, :put, "/rc/#{Rhoconnect::API_VERSION}/readstate/users/:user_name/sources/:source_name", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/set_refresh_time', '/api/source/set_refresh_time']} do |params,user|
|
|
3
|
+
# source = Source.load(params[:source_name],
|
|
4
|
+
# {:app_id => APP_NAME, :user_id => params[:user_name]})
|
|
5
|
+
# source.poll_interval = params[:poll_interval] if params[:poll_interval]
|
|
6
|
+
# params[:refresh_time] ||= 0
|
|
7
|
+
# source.read_state.refresh_time = Time.now.to_i + params[:refresh_time].to_i
|
|
8
|
+
# ''
|
|
9
|
+
# end
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Server.api4 :get_source_params, :get, "/rc/#{Rhoconnect::API_VERSION}/sources/:source_id", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
end
|
|
1
|
+
# Server.api4 :get_source_params, :get, "/rc/#{Rhoconnect::API_VERSION}/sources/:source_id", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/get_source_params', '/api/source/get_source_params']} do |params,user|
|
|
3
|
+
# Source.load(params[:source_id],{:app_id => APP_NAME,:user_id => '*'}).to_array.to_json
|
|
4
|
+
# end
|
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
Server.api4 :list_sources, :get, "/rc/#{Rhoconnect::API_VERSION}/sources/type/:partition_type", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
end
|
|
1
|
+
# Server.api4 :list_sources, :get, "/rc/#{Rhoconnect::API_VERSION}/sources/type/:partition_type", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/list_sources', '/api/source/list_sources']} do |params,user|
|
|
3
|
+
# sources = App.load(APP_NAME).sources
|
|
4
|
+
# if params['partition_type'].nil? or params['partition_type'] == 'all'
|
|
5
|
+
# sources.to_json
|
|
6
|
+
# else
|
|
7
|
+
# res = []
|
|
8
|
+
# sources.each do |name|
|
|
9
|
+
# s = Source.load(name,{:app_id => APP_NAME,:user_id => '*'})
|
|
10
|
+
# if s and s.partition_type and s.partition_type == params['partition_type'].to_sym
|
|
11
|
+
# res << name
|
|
12
|
+
# end
|
|
13
|
+
# end
|
|
14
|
+
# res.to_json
|
|
15
|
+
# end
|
|
16
|
+
# end
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
Server.api4 :update_source_params, :put, "/rc/#{Rhoconnect::API_VERSION}/sources/:source_id", true, nil do |params,user|
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
end
|
|
1
|
+
# Server.api4 :update_source_params, :put, "/rc/#{Rhoconnect::API_VERSION}/sources/:source_id", true, nil do |params,user|
|
|
2
|
+
# source = Source.load(params[:source_id],
|
|
3
|
+
# {:app_id => APP_NAME, :user_id => '*'})
|
|
4
|
+
# source.update_fields(params[:data])
|
|
5
|
+
# ''
|
|
6
|
+
# end
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Server.api4 :get_db_doc, :get, "/rc/#{Rhoconnect::API_VERSION}/store/:doc", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
end
|
|
1
|
+
# Server.api4 :get_db_doc, :get, "/rc/#{Rhoconnect::API_VERSION}/store/:doc", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/get_db_doc', '/api/source/get_db_doc']} do |params,user|
|
|
3
|
+
# Store.get_db_doc(params[:doc])
|
|
4
|
+
# end
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
Server.api4 :set_db_doc, :post, "/rc/#{Rhoconnect::API_VERSION}/store/:doc", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
end
|
|
1
|
+
# Server.api4 :set_db_doc, :post, "/rc/#{Rhoconnect::API_VERSION}/store/:doc", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/set_db_doc', '/api/source/set_db_doc'] } do |params,user|
|
|
3
|
+
# append_to_doc = params[:append]
|
|
4
|
+
# append_to_doc ||= false
|
|
5
|
+
# Store.set_db_doc(params[:doc],params[:data],append_to_doc)
|
|
6
|
+
# ''
|
|
7
|
+
# end
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Server.api4 :get_adapter, :get, "/rc/#{Rhoconnect::API_VERSION}/system/appserver", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
end
|
|
1
|
+
# Server.api4 :get_adapter, :get, "/rc/#{Rhoconnect::API_VERSION}/system/appserver", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/get_adapter', '/api/source/get_adapter']} do |params,user|
|
|
3
|
+
# {:adapter_url => Rhoconnect.appserver}.to_json
|
|
4
|
+
# end
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
Server.api4 :get_license_info, :get, "/rc/#{Rhoconnect::API_VERSION}/system/license", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
end
|
|
1
|
+
# Server.api4 :get_license_info, :get, "/rc/#{Rhoconnect::API_VERSION}/system/license", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/get_license_info', '/api/admin/get_license_info']} do |params,user|
|
|
3
|
+
# {:rhoconnect_version => Rhoconnect.license.rhoconnect_version,
|
|
4
|
+
# :licensee => Rhoconnect.license.licensee,
|
|
5
|
+
# :seats => Rhoconnect.license.seats,
|
|
6
|
+
# :issued => Rhoconnect.license.issued,
|
|
7
|
+
# :available => Rhoconnect.license.available }.to_json
|
|
8
|
+
# end
|
|
9
9
|
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
Server.api4 :login, :post, "/rc/#{Rhoconnect::API_VERSION}/system/login", true, {:verb => :post, :url => ['/login', '/api/admin/login']} do |params,user,server|
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
end
|
|
8
|
-
|
|
9
|
-
def do_get_api_token(params, user)
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
end
|
|
1
|
+
# Server.api4 :login, :post, "/rc/#{Rhoconnect::API_VERSION}/system/login", true, {:verb => :post, :url => ['/login', '/api/admin/login']} do |params,user,server|
|
|
2
|
+
# token = ''
|
|
3
|
+
# server.logout
|
|
4
|
+
# server.do_login
|
|
5
|
+
# u = User.load(params[:login])
|
|
6
|
+
# token = do_get_api_token(params, u)
|
|
7
|
+
# end
|
|
8
|
+
#
|
|
9
|
+
# def do_get_api_token(params, user)
|
|
10
|
+
# if user and user.admin == 1 and user.token
|
|
11
|
+
# user.token.value
|
|
12
|
+
# else
|
|
13
|
+
# raise ApiException.new(422, "Invalid/missing API user")
|
|
14
|
+
# end
|
|
15
|
+
# end
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
Server.api4 :reset, :post, "/rc/#{Rhoconnect::API_VERSION}/system/reset", true, {:verb => :post, :url => ['/api/reset', '/api/admin/reset']} do |params,user|
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
end
|
|
1
|
+
# Server.api4 :reset, :post, "/rc/#{Rhoconnect::API_VERSION}/system/reset", true, {:verb => :post, :url => ['/api/reset', '/api/admin/reset']} do |params,user|
|
|
2
|
+
# keep_token = user.token.value
|
|
3
|
+
# Store.flush_all
|
|
4
|
+
# app_klass = Object.const_get(camelize(APP_NAME))
|
|
5
|
+
# if app_klass.singleton_methods.map(&:to_sym).include?(:initializer)
|
|
6
|
+
# app_klass.send :initializer, Rhoconnect.base_directory
|
|
7
|
+
# end
|
|
8
|
+
# # restoring previous token value after flushdb
|
|
9
|
+
# user.token = keep_token
|
|
10
|
+
# "DB reset"
|
|
11
|
+
# end
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Server.api4 :save_adapter, :post, "/rc/#{Rhoconnect::API_VERSION}/system/appserver", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
end
|
|
1
|
+
# Server.api4 :save_adapter, :post, "/rc/#{Rhoconnect::API_VERSION}/system/appserver", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/save_adapter', '/api/source/save_adapter']} do |params,user|
|
|
3
|
+
# Rhoconnect.appserver = params['adapter_url'] || params[:attributes]['adapter_url']
|
|
4
|
+
# end
|
|
@@ -1,22 +1,22 @@
|
|
|
1
|
-
Server.api4 :stats, :get, "/rc/#{Rhoconnect::API_VERSION}/system/stats", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
end
|
|
1
|
+
# Server.api4 :stats, :get, "/rc/#{Rhoconnect::API_VERSION}/system/stats", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/stats', '/api/admin/stats']} do |params,user|
|
|
3
|
+
# if Rhoconnect.stats == true
|
|
4
|
+
# names = params[:names]
|
|
5
|
+
# if names
|
|
6
|
+
# Rhoconnect::Stats::Record.keys(names).to_json
|
|
7
|
+
# else
|
|
8
|
+
# metric = params[:metric]
|
|
9
|
+
# rtype = Rhoconnect::Stats::Record.rtype(metric)
|
|
10
|
+
# if rtype == 'zset'
|
|
11
|
+
# # returns [] if no results
|
|
12
|
+
# Rhoconnect::Stats::Record.range(metric,params[:start],params[:finish]).to_json
|
|
13
|
+
# elsif rtype == 'string'
|
|
14
|
+
# Rhoconnect::Stats::Record.get_value(metric) || ''
|
|
15
|
+
# else
|
|
16
|
+
# raise ApiException.new(404, "Unknown metric")
|
|
17
|
+
# end
|
|
18
|
+
# end
|
|
19
|
+
# else
|
|
20
|
+
# raise ApiException.new(500, "Stats not enabled")
|
|
21
|
+
# end
|
|
22
|
+
# end
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
Server.api4 :create_user, :post, "/rc/#{Rhoconnect::API_VERSION}/users", true, {:verb => :post, :url => ['/api/create_user', '/api/user/create_user']} do |params,user|
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
end
|
|
1
|
+
# Server.api4 :create_user, :post, "/rc/#{Rhoconnect::API_VERSION}/users", true, {:verb => :post, :url => ['/api/create_user', '/api/user/create_user']} do |params,user|
|
|
2
|
+
# app = App.load(APP_NAME)
|
|
3
|
+
# u = User.create({:login => params[:attributes]['login']})
|
|
4
|
+
# u.password = params[:attributes]['password']
|
|
5
|
+
# app.users << u.login
|
|
6
|
+
# "User created"
|
|
7
|
+
# end
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
Server.api4 :delete_client, :delete, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/clients/:client_id", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
end
|
|
1
|
+
# Server.api4 :delete_client, :delete, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/clients/:client_id", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/delete_client', '/api/client/delete_client']} do |params,user|
|
|
3
|
+
# Client.load(params[:client_id],{:source_name => '*'}).delete
|
|
4
|
+
# User.load(params[:user_id]).clients.delete(params[:client_id])
|
|
5
|
+
# "Client deleted"
|
|
6
|
+
# end
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
Server.api4 :delete_user, :delete, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
end
|
|
1
|
+
# Server.api4 :delete_user, :delete, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/delete_user', '/api/user/delete_user']} do |params,user|
|
|
3
|
+
# User.load(params[:user_id]).delete
|
|
4
|
+
# App.load(APP_NAME).users.delete(params[:user_id])
|
|
5
|
+
# params = {:app_id => APP_NAME,:user_id => params[:user_id]}
|
|
6
|
+
# App.load(APP_NAME).sources.each{ |source|
|
|
7
|
+
# Source.load(source, params).flush_store_data
|
|
8
|
+
# }
|
|
9
|
+
# "User deleted"
|
|
10
|
+
# end
|
|
11
|
+
#
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
Server.api4 :list_clients, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/clients", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
end
|
|
1
|
+
# Server.api4 :list_clients, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/clients", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/list_clients', '/api/client/list_clients']} do |params,user|
|
|
3
|
+
# User.load(params[:user_id]).clients.members.to_json
|
|
4
|
+
# end
|
|
@@ -1,11 +1,11 @@
|
|
|
1
|
-
Server.api4 :list_source_docs, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/sources/:source_id/docnames", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
end
|
|
1
|
+
# Server.api4 :list_source_docs, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/sources/:source_id/docnames", \
|
|
2
|
+
# true, {:verb => :post, :url => ['/api/list_source_docs', '/api/source/list_source_docs']} do |params,user|
|
|
3
|
+
# res = {}
|
|
4
|
+
# s = Source.load(params[:source_id], {:app_id => APP_NAME,:user_id => params[:user_id]})
|
|
5
|
+
# [:md,:md_size,:md_copy,:errors].each do |doc|
|
|
6
|
+
# db_key = s.docname(doc)
|
|
7
|
+
# res.merge!(doc => db_key)
|
|
8
|
+
# end
|
|
9
|
+
# res.to_json
|
|
10
|
+
# end
|
|
11
11
|
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
Server.api4 :list_users, :get, "/rc/#{Rhoconnect::API_VERSION}/users", true, {:verb => :post, :url => ['/api/list_users', '/api/user/list_users']} do |params,user|
|
|
2
|
-
|
|
3
|
-
end
|
|
1
|
+
# Server.api4 :list_users, :get, "/rc/#{Rhoconnect::API_VERSION}/users", true, {:verb => :post, :url => ['/api/list_users', '/api/user/list_users']} do |params,user|
|
|
2
|
+
# App.load(APP_NAME).users.members.to_json
|
|
3
|
+
# end
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
Server.api4 :ping, :post, "/rc/#{Rhoconnect::API_VERSION}/users/ping", true, {:verb => :post, :url => ['/api/ping', '/api/client/ping']} do |params,user|
|
|
2
|
-
|
|
3
|
-
end
|
|
1
|
+
# Server.api4 :ping, :post, "/rc/#{Rhoconnect::API_VERSION}/users/ping", true, {:verb => :post, :url => ['/api/ping', '/api/client/ping']} do |params,user|
|
|
2
|
+
# User.ping(params)
|
|
3
|
+
# end
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
Server.api4 :show_user, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id", true, nil do |params,user|
|
|
2
|
-
|
|
3
|
-
end
|
|
1
|
+
# Server.api4 :show_user, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id", true, nil do |params,user|
|
|
2
|
+
# User.load(params[:user_id]).to_array.to_json
|
|
3
|
+
# end
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
Server.api4 :update_user, :put, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id", \
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
end
|
|
1
|
+
# Server.api4 :update_user, :put, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id", \
|
|
2
|
+
# true, {:verb => :post, :url => ["/api/update_user", '/api/user/update_user']} do |params,user|
|
|
3
|
+
# User.load(params[:user_id]).update(params[:attributes])
|
|
4
|
+
# "User updated"
|
|
5
|
+
# end
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
Server.api4 :user_get_db_doc, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/sources/:source_id/docs/:doc", true, nil do |params,user|
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
end
|
|
1
|
+
# Server.api4 :user_get_db_doc, :get, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/sources/:source_id/docs/:doc", true, nil do |params,user|
|
|
2
|
+
# s = Source.load(params[:source_id], {:app_id => APP_NAME,:user_id => params[:user_id]})
|
|
3
|
+
# db_key = s.docname(params[:doc])
|
|
4
|
+
# Store.get_db_doc(db_key)
|
|
5
|
+
# end
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
Server.api4 :user_set_db_doc, :post, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/sources/:source_id/docs/:doc", true, nil do |params,user|
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
end
|
|
1
|
+
# Server.api4 :user_set_db_doc, :post, "/rc/#{Rhoconnect::API_VERSION}/users/:user_id/sources/:source_id/docs/:doc", true, nil do |params,user|
|
|
2
|
+
# throw :halt, [500, "Unknown user '#{params[:user_id]}'"] unless User.is_exist?(params[:user_id])
|
|
3
|
+
#
|
|
4
|
+
# s = Source.load(params[:source_id], {:app_id => APP_NAME,:user_id => params[:user_id]})
|
|
5
|
+
# db_key = s.docname(params[:doc])
|
|
6
|
+
# append_to_doc = params[:append]
|
|
7
|
+
# append_to_doc ||= false
|
|
8
|
+
# Store.set_db_doc(db_key,params[:data],append_to_doc)
|
|
9
|
+
# ''
|
|
10
|
+
# end
|
data/lib/rhoconnect/api_token.rb
CHANGED
|
@@ -1,19 +1,18 @@
|
|
|
1
1
|
require 'uuidtools'
|
|
2
2
|
module Rhoconnect
|
|
3
|
-
class ApiToken <
|
|
3
|
+
class ApiToken < StoreOrm
|
|
4
4
|
field :value,:string
|
|
5
5
|
field :user_id,:string
|
|
6
6
|
validates_presence_of :user_id
|
|
7
|
-
|
|
7
|
+
|
|
8
8
|
def self.create(fields)
|
|
9
|
-
fields[:value] = fields[:value] ||
|
|
9
|
+
fields[:value] = fields[:value] || get_random_uuid
|
|
10
10
|
fields[:id] = fields[:value]
|
|
11
|
-
|
|
11
|
+
super(fields)
|
|
12
12
|
end
|
|
13
|
-
|
|
13
|
+
|
|
14
14
|
def user
|
|
15
15
|
User.load(self.user_id)
|
|
16
16
|
end
|
|
17
17
|
end
|
|
18
18
|
end
|
|
19
|
-
|
data/lib/rhoconnect/app.rb
CHANGED
|
@@ -1,63 +1,27 @@
|
|
|
1
1
|
module Rhoconnect
|
|
2
|
-
class App <
|
|
2
|
+
class App < StoreOrm
|
|
3
3
|
field :name, :string
|
|
4
4
|
set :users, :string
|
|
5
|
-
attr_reader :delegate
|
|
6
5
|
validates_presence_of :name
|
|
7
|
-
|
|
6
|
+
|
|
8
7
|
@@sources = []
|
|
9
|
-
|
|
8
|
+
|
|
10
9
|
class << self
|
|
11
10
|
def create(fields={})
|
|
12
11
|
fields[:id] = fields[:name]
|
|
13
12
|
super(fields)
|
|
14
13
|
end
|
|
15
14
|
end
|
|
16
|
-
|
|
17
|
-
def can_authenticate?
|
|
18
|
-
self.delegate && self.delegate.singleton_methods.map(&:to_sym).include?(:authenticate)
|
|
19
|
-
end
|
|
20
|
-
|
|
21
|
-
def can_ans_authenticate?
|
|
22
|
-
self.delegate && self.delegate.singleton_methods.map(&:to_sym).include?(:ans_authenticate)
|
|
23
|
-
end
|
|
24
15
|
|
|
25
|
-
|
|
26
|
-
def authenticate(login, password, session)
|
|
27
|
-
if Rhoconnect.appserver
|
|
28
|
-
auth_result = DynamicAdapter.authenticate(login,password)
|
|
29
|
-
elsif self.delegate
|
|
30
|
-
auth_result = self.delegate.authenticate(login, password, session)
|
|
31
|
-
end
|
|
32
|
-
|
|
33
|
-
if auth_result
|
|
34
|
-
login = auth_result if auth_result.is_a? String
|
|
35
|
-
user = User.load(login) if User.is_exist?(login)
|
|
36
|
-
if not user
|
|
37
|
-
user = User.create(:login => login)
|
|
38
|
-
users << user.id
|
|
39
|
-
end
|
|
40
|
-
return user
|
|
41
|
-
end
|
|
42
|
-
end
|
|
43
|
-
|
|
44
|
-
def ans_authenticate(login, password)
|
|
45
|
-
self.delegate ? self.delegate.ans_authenticate(login, password) : false
|
|
46
|
-
end
|
|
47
|
-
|
|
48
|
-
def delegate
|
|
49
|
-
@delegate.nil? ? Object.const_get(camelize(self.name)) : @delegate
|
|
50
|
-
end
|
|
51
|
-
|
|
52
16
|
def delete
|
|
53
17
|
@@sources = []
|
|
54
18
|
super
|
|
55
19
|
end
|
|
56
|
-
|
|
20
|
+
|
|
57
21
|
def delete_sources
|
|
58
22
|
@@sources = []
|
|
59
23
|
end
|
|
60
|
-
|
|
24
|
+
|
|
61
25
|
def partition_sources(partition,user_id)
|
|
62
26
|
names = []
|
|
63
27
|
@@sources.each do |source|
|
|
@@ -69,11 +33,7 @@ module Rhoconnect
|
|
|
69
33
|
end
|
|
70
34
|
names
|
|
71
35
|
end
|
|
72
|
-
|
|
73
|
-
def store_blob(obj,field_name,blob)
|
|
74
|
-
self.delegate.send :store_blob, obj,field_name,blob
|
|
75
|
-
end
|
|
76
|
-
|
|
36
|
+
|
|
77
37
|
def sources
|
|
78
38
|
@@sources.uniq!
|
|
79
39
|
# Sort sources array by priority
|
|
@@ -27,11 +27,14 @@ Rhoconnect::Server.use Rack::Static, :urls => ['/data'], :root => Rhoconnect
|
|
|
27
27
|
if ENV['DEBUG'] == 'yes'
|
|
28
28
|
Rhoconnect::Server.set :use_async_model, false
|
|
29
29
|
end
|
|
30
|
+
# bootstrap the application
|
|
31
|
+
Rhoconnect.bootstrap(ROOT_PATH)
|
|
32
|
+
# Load RhoConnect application controller
|
|
30
33
|
|
|
34
|
+
# TODO - Move to Rhoconnect.rb??
|
|
31
35
|
module Rhoconnect
|
|
32
36
|
def app
|
|
33
|
-
|
|
34
|
-
url_map = { '/' => Rhoconnect::Server.new }
|
|
37
|
+
url_map = Rhoconnect.url_map
|
|
35
38
|
unless Rhoconnect.disable_resque_console
|
|
36
39
|
url_map['/resque'] = Resque::Server.new
|
|
37
40
|
end
|