blob: eeec1edf3bcb44200519234ad969d6dd45f4f70f [file] [log] [blame]
% Licensed under the Apache License, Version 2.0 (the "License"); you may not
% use this file except in compliance with the License. You may obtain a copy of
% the License at
%
% http://www.apache.org/licenses/LICENSE-2.0
%
% Unless required by applicable law or agreed to in writing, software
% distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
% WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
% License for the specific language governing permissions and limitations under
% the License.
-module(mem3_httpd_handlers).
-export([url_handler/1, db_handler/1, design_handler/1, handler_info/3]).
url_handler(<<"_membership">>) -> fun mem3_httpd:handle_membership_req/1;
url_handler(<<"_reshard">>) -> fun mem3_reshard_httpd:handle_reshard_req/1;
url_handler(_) -> no_match.
db_handler(<<"_shards">>) -> fun mem3_httpd:handle_shards_req/2;
db_handler(<<"_sync_shards">>) -> fun mem3_httpd:handle_sync_req/2;
db_handler(_) -> no_match.
design_handler(_) -> no_match.
handler_info('GET', [<<"_membership">>], _) ->
{'cluster.membership.read', #{}};
handler_info('GET', [<<"_reshard">>], _) ->
{'reshard.summary.read', #{}};
handler_info('GET', [<<"_reshard">>, <<"state">>], _) ->
{'reshard.state.read', #{}};
handler_info('PUT', [<<"_reshard">>, <<"state">>], _) ->
{'reshard.state.write', #{}};
handler_info('GET', [<<"_reshard">>, <<"jobs">>], _) ->
{'reshard.jobs.read', #{}};
handler_info('POST', [<<"_reshard">>, <<"jobs">>], _) ->
{'reshard.jobs.create', #{}};
handler_info('GET', [<<"_reshard">>, <<"jobs">>, JobId], _) ->
{'reshard.job.read', #{'job.id' => JobId}};
handler_info('DELETE', [<<"_reshard">>, <<"jobs">>, JobId], _) ->
{'reshard.job.delete', #{'job.id' => JobId}};
handler_info('GET', [DbName, <<"_shards">>], _) ->
{'db.shards.read', #{'db.name' => DbName}};
handler_info('GET', [DbName, <<"_shards">>, DocId], _) ->
{'db.shards.read', #{'db.name' => DbName, 'doc.id' => DocId}};
handler_info('POST', [DbName, <<"_sync_shards">>], _) ->
{'db.shards.sync', #{'db.name' => DbName}};
handler_info(_, _, _) ->
no_match.