當前位置: 首頁>>代碼示例>>Java>>正文


Java ActionResponse類代碼示例

本文整理匯總了Java中org.elasticsearch.action.ActionResponse的典型用法代碼示例。如果您正苦於以下問題:Java ActionResponse類的具體用法?Java ActionResponse怎麽用?Java ActionResponse使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


ActionResponse類屬於org.elasticsearch.action包,在下文中一共展示了ActionResponse類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: apply

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
@Override
public <Request extends ActionRequest, Response extends ActionResponse> void apply(Task task, String action,
        Request request, ActionListener<Response> listener, ActionFilterChain<Request, Response> chain) {
    if (false == action.equals(SearchAction.NAME)) {
        chain.proceed(task, action, request, listener);
        return;
    }
    if (context.getHeader(EXAMPLE_HEADER) != null) {
        throw new IllegalArgumentException("Hurray! Sent the header!");
    }
    String auth = context.getHeader(AUTHORIZATION_HEADER);
    if (auth == null) {
        ElasticsearchSecurityException e = new ElasticsearchSecurityException("Authentication required",
                RestStatus.UNAUTHORIZED);
        e.addHeader("WWW-Authenticate", "Basic realm=auth-realm");
        throw e;
    }
    if (false == REQUIRED_AUTH.equals(auth)) {
        throw new ElasticsearchSecurityException("Bad Authorization", RestStatus.FORBIDDEN);
    }
    chain.proceed(task, action, request, listener);
}
 
開發者ID:justor,項目名稱:elasticsearch_my,代碼行數:23,代碼來源:ReindexFromRemoteWithAuthTests.java

示例2: checkIfIndexExists

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
private void checkIfIndexExists(final ActionListener<ActionResponse> listener) {
    client.admin().indices().prepareExists(IndexingProxyPlugin.INDEX_NAME).execute(wrap(response -> {
        if (response.isExists()) {
            if (logger.isDebugEnabled()) {
                logger.debug(IndexingProxyPlugin.INDEX_NAME + " exists.");
            }
            listener.onResponse(response);
        } else {
            createIndex(listener);
        }
    }, e -> {
        if (e instanceof IndexNotFoundException) {
            createIndex(listener);
        } else {
            listener.onFailure(e);
        }
    }));
}
 
開發者ID:codelibs,項目名稱:elasticsearch-indexing-proxy,代碼行數:19,代碼來源:IndexingProxyService.java

示例3: createIndex

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
private void createIndex(final ActionListener<ActionResponse> listener) {
    try (final Reader in = new InputStreamReader(IndexingProxyService.class.getClassLoader().getResourceAsStream(FILE_MAPPING_JSON),
            StandardCharsets.UTF_8)) {
        final String source = Streams.copyToString(in);
        final XContentBuilder settingsBuilder = XContentFactory.jsonBuilder()//
                .startObject()//
                .startObject("index")//
                .field("number_of_shards", numberOfShards)//
                .field("number_of_replicas", numberOfReplicas)//
                .endObject()//
                .endObject();
        client.admin().indices().prepareCreate(IndexingProxyPlugin.INDEX_NAME).setSettings(settingsBuilder)
                .addMapping(IndexingProxyPlugin.TYPE_NAME, source, XContentFactory.xContentType(source))
                .execute(wrap(response -> waitForIndex(listener), listener::onFailure));
    } catch (final IOException e) {
        listener.onFailure(e);
    }
}
 
開發者ID:codelibs,項目名稱:elasticsearch-indexing-proxy,代碼行數:19,代碼來源:IndexingProxyService.java

示例4: renew

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
public <Response extends ActionResponse> void renew(final ActionListener<Response> listener) {
    client.prepareGet(IndexingProxyPlugin.INDEX_NAME, IndexingProxyPlugin.TYPE_NAME, FILE_ID).setRefresh(true).execute(wrap(res -> {
        if (res.isExists()) {
            final Map<String, Object> source = res.getSourceAsMap();
            final String nodeName = (String) source.get(IndexingProxyPlugin.NODE_NAME);
            if (nodeName().equals(nodeName)) {
                renewOnLocal(listener);
            } else {
                renewOnRemote(nodeName, listener);
            }
        } else {
            if (logger.isDebugEnabled()) {
                logger.debug("No file_id. Skipped renew action.");
            }
            listener.onResponse(null);
        }
    }, listener::onFailure));
}
 
開發者ID:codelibs,項目名稱:elasticsearch-indexing-proxy,代碼行數:19,代碼來源:IndexingProxyService.java

示例5: writeOnLocal

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
public <Request extends ActionRequest, Response extends ActionResponse> void writeOnLocal(final Request request,
        final ActionListener<Response> listener) {
    final ActionListener<Response> next = wrap(res -> {
        final short classType = RequestUtils.getClassType(request);
        if (classType > 0) {
            synchronized (this) {
                streamOutput.writeShort(classType);
                request.writeTo(streamOutput);
                if (flushPerDoc) {
                    streamOutput.flush();
                }
            }
        } else {
            throw new ElasticsearchException("Unknown request: " + request);
        }
        listener.onResponse(res);
    }, listener::onFailure);

    if (streamOutput == null || streamOutput.getByteCount() > dataFileSize) {
        createStreamOutput(next);
    } else {
        next.onResponse(null);
    }
}
 
開發者ID:codelibs,項目名稱:elasticsearch-indexing-proxy,代碼行數:25,代碼來源:IndexingProxyService.java

示例6: apply

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
@Override
public <Request extends ActionRequest, Response extends ActionResponse> void apply(final Task task, final String action,
        final Request request, final ActionListener<Response> listener, final ActionFilterChain<Request, Response> chain) {
    if (logger.isDebugEnabled()) {
        logger.debug("node: " + nodeName() + ", action: " + action + ", request: " + request);
    }
    final Supplier<Response> executor = getExecutor(task, action, request);
    if (executor != null) {
        indexingProxyService.write(request, ActionListener.wrap(res -> {
            listener.onResponse(executor.get());
        }, listener::onFailure));
    } else if (indexingProxyService.isRenewAction(action)) {
        indexingProxyService.renew(ActionListener.wrap(res -> {
            chain.proceed(task, action, request, listener);
        }, listener::onFailure));
    } else {
        chain.proceed(task, action, request, listener);
    }
}
 
開發者ID:codelibs,項目名稱:elasticsearch-indexing-proxy,代碼行數:20,代碼來源:ProxyActionFilter.java

示例7: proceed

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
@Override @SuppressWarnings("unchecked")
public void proceed(String action, ActionResponse response, ActionListener listener) {
    int i = index.decrementAndGet();
    try {
        if (i >= 0) {
            filters[i].apply(action, response, listener, this);
        } else if (i == -1) {
            listener.onResponse(response);
        } else {
            listener.onFailure(new IllegalStateException("proceed was called too many times"));
        }
    } catch (Throwable t) {
        logger.trace("Error during transport action execution.", t);
        listener.onFailure(t);
    }
}
 
開發者ID:baidu,項目名稱:Elasticsearch,代碼行數:17,代碼來源:TransportAction.java

示例8: auth

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
@Override
public <Response extends ActionResponse> boolean auth(Task task, String action, ActionRequest request, ActionListener<Response> listener,
		boolean isJavaClient) {
	if (!restUsing && !isJavaClient) {
		return true;
	}
	if (!clienttUsing && isJavaClient) {
		return true;
	}
	if (isJavaClient) {
		return dealClientAuth(request);
	} else {
		return dealRestAuth(task, action, request, listener);
	}

}
 
開發者ID:psfu,項目名稱:es-sp-tools,代碼行數:17,代碼來源:SimpleAuther.java

示例9: dealRestAuth

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
private <Response extends ActionResponse> boolean dealRestAuth(Task task, String action, ActionRequest request, ActionListener<Response> listener) {
	if (request.remoteAddress() != null) {
		String addr = request.remoteAddress().getAddress();
		Permissions permission = ipListRest.get(addr);
		if (permission != null) {
			if (permission.allowed == true) {
				return true;
			} else {
				return false;
			}
		}
	} else {
		log(10, "dealRestAuth: remoteAddress is null!");
		return true;
	}

	AuthInfo info = SimpleAutherUtil.getAuthInfo(task, action, request, listener);
	if (info.key == null) {
		return false;
	}
	return valKey(null, info.user, info.key);
}
 
開發者ID:psfu,項目名稱:es-sp-tools,代碼行數:23,代碼來源:SimpleAuther.java

示例10: getIndex

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
private String getIndex(ActionResponse response) {
    String index = "";

    if (response instanceof IndexResponse) {
        index = ((IndexResponse) response).getIndex();
    } else if (response instanceof GetResponse) {
        index = ((GetResponse) response).getIndex();
    } else if (response instanceof DeleteResponse) {
        index = ((DeleteResponse) response).getIndex();
    }

    if (isKibanaUserIndex(index)) {
        index = kibanaIndex;
    }

    return index;
}
 
開發者ID:fabric8io,項目名稱:openshift-elasticsearch-plugin,代碼行數:18,代碼來源:KibanaUserReindexAction.java

示例11: bind

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
protected <T extends ActionResponse> AsyncFuture<T> bind(
    final ListenableActionFuture<T> actionFuture
) {
    final ResolvableFuture<T> future = async.future();

    actionFuture.addListener(new ActionListener<T>() {
        @Override
        public void onResponse(T result) {
            future.resolve(result);
        }

        @Override
        public void onFailure(Exception e) {
            future.fail(e);
        }
    });

    return future;
}
 
開發者ID:spotify,項目名稱:heroic,代碼行數:20,代碼來源:AbstractElasticsearchBackend.java

示例12: checkIfIndexExists

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
private void checkIfIndexExists(final ActionListener<ActionResponse> listener) {
    client.admin().indices().prepareExists(index).execute(wrap(response -> {
        if (response.isExists()) {
            if (logger.isDebugEnabled()) {
                logger.debug(index + " exists.");
            }
            listener.onResponse(response);
        } else {
            createIndex(listener);
        }
    }, e -> {
        if (e instanceof IndexNotFoundException) {
            createIndex(listener);
        } else {
            listener.onFailure(e);
        }
    }));
}
 
開發者ID:codelibs,項目名稱:elasticsearch-configsync,代碼行數:19,代碼來源:ConfigSyncService.java

示例13: createIndex

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
private void createIndex(final ActionListener<ActionResponse> listener) {
    try (final Reader in = new InputStreamReader(ConfigSyncService.class.getClassLoader().getResourceAsStream(FILE_MAPPING_JSON),
            StandardCharsets.UTF_8)) {
        final String source = Streams.copyToString(in);
        final XContentBuilder settingsBuilder = XContentFactory.jsonBuilder()//
                .startObject()//
                .startObject("index")//
                .field("number_of_replicas", 0)//
                .endObject()//
                .endObject();
        client.admin().indices().prepareCreate(index).setSettings(settingsBuilder)
                .addMapping(type, source, XContentType.JSON)
                .execute(wrap(response -> waitForIndex(listener), listener::onFailure));
    } catch (final IOException e) {
        listener.onFailure(e);
    }
}
 
開發者ID:codelibs,項目名稱:elasticsearch-configsync,代碼行數:18,代碼來源:ConfigSyncService.java

示例14: apply

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
@Override
public void apply(final String action, final ActionResponse response,
        @SuppressWarnings("rawtypes") final ActionListener listener,
        final ActionFilterChain chain) {
    if (!CreateSnapshotAction.NAME.equals(action) || !clusterService.state().nodes().localNodeMaster()) {
        chain.proceed(action, response, listener);
    } else {
        final CreateSnapshotResponse createSnapshotResponse = (CreateSnapshotResponse) response;
        final SnapshotInfo snapshotInfo = createSnapshotResponse
                .getSnapshotInfo();
        dictionarySnapshotService.createDictionarySnapshot(
                ((ActionListenerWrapper<?>) listener).getSnapshotId(),
                snapshotInfo, new ActionListener<Void>() {

                    @Override
                    public void onResponse(final Void resp) {
                        chain.proceed(action, response, listener);
                    }

                    @Override
                    public void onFailure(final Throwable e) {
                        listener.onFailure(e);
                    }
                });
    }
}
 
開發者ID:codelibs,項目名稱:elasticsearch-dictionary,代碼行數:27,代碼來源:CreateSnapshotActionFilter.java

示例15: executeBlocking

import org.elasticsearch.action.ActionResponse; //導入依賴的package包/類
private void executeBlocking(final ActionRequest action) {
    try {
        if (action instanceof PutMappingRequest) {
            getDataContext().getElasticSearchClient().createMapping((PutMappingRequest) action);
        } else {
            final ActionResponse result = getDataContext().getElasticSearchClient().execute(action);

            if (result instanceof BulkResponse && ((BulkResponse) result).hasFailures()) {
                BulkItemResponse[] failedItems = ((BulkResponse) result).getItems();
                for (int i = 0; i < failedItems.length; i++) {
                    if (failedItems[i].isFailed()) {
                        final BulkItemResponse failedItem = failedItems[i];
                        logger.error("Bulk failed with item no. {} of {}: id={} op={} status={} error={}", i + 1,
                                failedItems.length, failedItem.getId(), failedItem.getOpType(), failedItem.status(),
                                failedItem.getFailureMessage());
                    }
                }
            }
        }
    } catch (IOException e) {
        logger.warn("Could not execute command {} ", action, e);
        throw new MetaModelException("Could not execute " + action, e);
    }
}
 
開發者ID:apache,項目名稱:metamodel,代碼行數:25,代碼來源:ElasticSearchRestUpdateCallback.java


注:本文中的org.elasticsearch.action.ActionResponse類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。