blob: b592142848551b42d4489c03eda8aa2de2b9b243 [file] [log] [blame]
// Copyright 2014 Google Inc. All Rights Reserved.
//
// 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.
package com.google.enterprise.adaptor.sharepoint;
import com.google.enterprise.adaptor.Acl;
import com.google.enterprise.adaptor.AsyncDocIdPusher;
import com.google.enterprise.adaptor.DocId;
import com.google.enterprise.adaptor.DocIdPusher;
import java.util.Collections;
import java.util.logging.Level;
import java.util.logging.Logger;
public class AccumulatingAsyncDocIdPusher implements AsyncDocIdPusher{
private static final Logger log
= Logger.getLogger(AccumulatingAsyncDocIdPusher.class.getName());
private final DocIdPusher pusher;
AccumulatingAsyncDocIdPusher(DocIdPusher pusher) {
if (pusher == null) {
throw new NullPointerException();
}
this.pusher = pusher;
}
@Override
public void pushDocId(DocId docid) {
try {
pusher.pushDocIds(Collections.singletonList(docid));
} catch (InterruptedException e) {
log.log(Level.WARNING, "Interrupted during pushDocId", e);
Thread.currentThread().interrupt();
}
}
@Override
public void pushRecord(DocIdPusher.Record record) {
try {
pusher.pushRecords(Collections.singletonList(record));
} catch (InterruptedException e) {
log.log(Level.WARNING, "Interrupted during pushRecord", e);
Thread.currentThread().interrupt();
}
}
@Override
public void pushNamedResource(DocId docid, Acl acl) {
try {
pusher.pushNamedResources(Collections.singletonMap(docid, acl));
} catch (InterruptedException e) {
log.log(Level.WARNING, "Interrupted during pushNamedResource", e);
Thread.currentThread().interrupt();
}
}
}