Skip to content

Commit

Permalink
RESTful webservice to receive notifications of artifact uploads
Browse files Browse the repository at this point in the history
  • Loading branch information
gd-tmagrys committed Jun 28, 2015
1 parent 601963c commit b0c6f59
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 9 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -18,5 +18,6 @@
import com.griddynamics.cd.nrp.internal.model.api.ArtifactMetaInfo;

public interface ArtifactUpdateApiClient {
void sendRequest(ArtifactMetaInfo metaInfo);
void enqueueRequest(ArtifactMetaInfo artifactMetaInfo);

}
Original file line number Diff line number Diff line change
Expand Up @@ -51,22 +51,52 @@ public class ArtifactUpdateApiClientImpl extends ComponentSupport implements Art
* ExecutorService shares between clients. All treads are created in the same executor
*/
private final ExecutorService asyncRequestsExecutorService;
private final BlockingQueue<ArtifactMetaInfo> blockingQueue;

@Inject
public ArtifactUpdateApiClientImpl(ConfigurationsManager configurationsManager) {
this.configurationsManager = configurationsManager;
BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>(configurationsManager.getConfiguration().getRequestsQueueSize());
this.asyncRequestsExecutorService = new ThreadPoolExecutor(
configurationsManager.getConfiguration().getRequestsSendingThreadsCount(),
configurationsManager.getConfiguration().getRequestsSendingThreadsCount(),
30, TimeUnit.SECONDS, queue);
this.blockingQueue =
new LinkedBlockingQueue<>(configurationsManager.
getConfiguration().getRequestsQueueSize());
this.asyncRequestsExecutorService =
Executors.newFixedThreadPool(
configurationsManager.getConfiguration()
.getRequestsSendingThreadsCount());
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
while (true){
try{
final ArtifactMetaInfo artifactMetaInfo = blockingQueue.take();
asyncRequestsExecutorService.submit(new Runnable() {
@Override
public void run() {
sendRequest(artifactMetaInfo);
}
});
}catch (Exception e){
log.error(e.getMessage(),e);
}
}
}
});
thread.start();
}

@Override
public void enqueueRequest(ArtifactMetaInfo artifactMetaInfo){
try {
blockingQueue.offer(artifactMetaInfo, 30, TimeUnit.SECONDS);
}catch(Exception e){
log.error(e.getMessage(),e);
}
}

/**
* Sends replication requests to all nexus servers configured in XML file
* @param metaInfo Artifact information
*/
@Override
public void sendRequest(ArtifactMetaInfo metaInfo) {
for (NexusServer server : configurationsManager.getConfiguration().getServers()) {
AsyncWebResource.Builder service = getService(server.getUrl(), server.getUser(), server.getPassword());
Expand Down Expand Up @@ -126,7 +156,6 @@ private AsyncWebResource.Builder getService(String nexusUrl, String login, Strin
private Client getClient(String login, String password) {
ClientConfig config = new DefaultClientConfig();
Client client = Client.create(config);
client.setExecutorService(asyncRequestsExecutorService);
if (login != null && !login.isEmpty() && password != null) {
log.debug("Creating HTTP client with authorized HTTPBasicAuthFilter.");
client.addFilter(new HTTPBasicAuthFilter(login, password));
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ public void onArtifactUploading(RepositoryItemEventStore event) {
updateArtifactStatus(metaInfo, artifactStatus);
if (artifactStatus.isReadyForReplication()) {
log.debug("File with hashes received for: " + metaInfo.toString() + " Sending request");
artifactUpdateApiClient.sendRequest(metaInfo);
artifactUpdateApiClient.enqueueRequest(metaInfo);
clearStatus(metaInfo);
}
}
Expand Down

0 comments on commit b0c6f59

Please sign in to comment.