Search in sources :

Example 1 with ApiException

use of com.haleconnect.api.user.v1.ApiException in project hale by halestudio.

the class HaleConnectInputSupplier method getLastModified.

/**
 * @return details on the hale connect project
 */
public Long getLastModified() {
    if (lastModified == null) {
        Owner owner = HaleConnectUrnBuilder.extractProjectOwner(getLocation());
        String projectId = HaleConnectUrnBuilder.extractProjectId(getLocation());
        final BucketsApi api = ProjectStoreHelper.getBucketsApi(basePathResolver, apiKey);
        final ApiResponse<BucketDetail> response;
        try {
            response = api.getBucketInfoWithHttpInfo(owner.getType().getJsonValue(), owner.getId(), projectId);
            lastModified = response.getData().getLastModified();
        } catch (ApiException e) {
        // Not fatal
        }
    }
    return lastModified;
}
Also used : BucketsApi(com.haleconnect.api.projectstore.v1.api.BucketsApi) BucketDetail(com.haleconnect.api.projectstore.v1.model.BucketDetail) ApiException(com.haleconnect.api.projectstore.v1.ApiException)

Example 2 with ApiException

use of com.haleconnect.api.user.v1.ApiException in project hale by halestudio.

the class HaleConnectServiceImpl method createUploadFileCallback.

private ApiCallback<Feedback> createUploadFileCallback(final SettableFuture<Boolean> future, final ProgressIndicator progress, final File file, final int totalWork) {
    return new ApiCallback<Feedback>() {

        AtomicLong chunkWritten = new AtomicLong(0);

        AtomicLong bytesReported = new AtomicLong(0);

        @Override
        public void onDownloadProgress(long bytesRead, long contentLength, boolean done) {
        // not required
        }

        @Override
        public void onFailure(com.haleconnect.api.projectstore.v1.ApiException e, int statusCode, Map<String, List<String>> responseHeaders) {
            progress.end();
            future.setException(new HaleConnectException(e.getMessage(), e, statusCode, responseHeaders));
        }

        @Override
        public void onSuccess(Feedback result, int statusCode, Map<String, List<String>> responseHeaders) {
            if (result.getError()) {
                log.error(MessageFormat.format("Error uploading project file \"{0}\": {1}", file.getAbsolutePath(), result.getMessage()));
                future.set(false);
            } else {
                future.set(true);
            }
            progress.end();
        }

        @Override
        public void onUploadProgress(long bytesWritten, long contentLength, boolean done) {
            // bytesWritten contains the accumulated amount of bytes written
            if (totalWork != ProgressIndicator.UNKNOWN) {
                // Wait until at least 1 KiB was written
                long chunk = chunkWritten.get();
                chunk += bytesWritten - bytesReported.get();
                if (chunk >= 1024) {
                    long workToReport = chunk >> 10;
                    // cannot overflow, total size in KiB
                    // is guaranteed to be < Integer.MAX_VALUE
                    progress.advance(Math.toIntExact(workToReport));
                    chunk -= workToReport << 10;
                // chunkWritten now always < 1024
                }
                chunkWritten.set(chunk);
                bytesReported.set(bytesWritten);
            }
        }
    };
}
Also used : AtomicLong(java.util.concurrent.atomic.AtomicLong) ApiCallback(com.haleconnect.api.projectstore.v1.ApiCallback) Feedback(com.haleconnect.api.projectstore.v1.model.Feedback) HaleConnectException(eu.esdihumboldt.hale.io.haleconnect.HaleConnectException) Map(java.util.Map) ConcurrentHashMap(java.util.concurrent.ConcurrentHashMap) ApiException(com.haleconnect.api.user.v1.ApiException)

Example 3 with ApiException

use of com.haleconnect.api.user.v1.ApiException in project hale by halestudio.

the class HaleConnectServiceImpl method getOrganisationInfo.

/**
 * @see eu.esdihumboldt.hale.io.haleconnect.HaleConnectService#getOrganisationInfo(java.lang.String)
 */
@Override
public HaleConnectOrganisationInfo getOrganisationInfo(String orgId) throws HaleConnectException {
    if (!this.isLoggedIn()) {
        return null;
    }
    if (!orgInfoCache.containsKey(orgId)) {
        OrganisationsApi api = UserServiceHelper.getOrganisationsApi(this, this.getSession().getToken());
        try {
            OrganisationInfo org = api.getOrganisation(orgId);
            orgInfoCache.put(org.getId(), new HaleConnectOrganisationInfo(org.getId(), org.getName()));
        } catch (ApiException e) {
            throw new HaleConnectException(e.getMessage(), e);
        }
    }
    return orgInfoCache.get(orgId);
}
Also used : HaleConnectOrganisationInfo(eu.esdihumboldt.hale.io.haleconnect.HaleConnectOrganisationInfo) OrganisationInfo(com.haleconnect.api.user.v1.model.OrganisationInfo) HaleConnectOrganisationInfo(eu.esdihumboldt.hale.io.haleconnect.HaleConnectOrganisationInfo) HaleConnectException(eu.esdihumboldt.hale.io.haleconnect.HaleConnectException) OrganisationsApi(com.haleconnect.api.user.v1.api.OrganisationsApi) ApiException(com.haleconnect.api.user.v1.ApiException)

Example 4 with ApiException

use of com.haleconnect.api.user.v1.ApiException in project hale by halestudio.

the class HaleConnectServiceImpl method login.

/**
 * @see eu.esdihumboldt.hale.io.haleconnect.HaleConnectService#login(java.lang.String,
 *      java.lang.String)
 */
@Override
public boolean login(String username, String password) throws HaleConnectException {
    LoginApi loginApi = UserServiceHelper.getLoginApi(this);
    Credentials credentials = UserServiceHelper.buildCredentials(username, password);
    try {
        Token token = loginApi.login(credentials);
        if (token != null) {
            UsersApi usersApi = UserServiceHelper.getUsersApi(this, token.getToken());
            // First get the current user's profile to obtain the user ID
            // required to fetch the extended profile (including the user's
            // roles/organisations) in the next step
            UserInfo shortProfile = usersApi.getProfileOfCurrentUser();
            session = new HaleConnectSessionImpl(username, token.getToken(), usersApi.getProfile(shortProfile.getId()));
            notifyLoginStateChanged();
        } else {
            clearSession();
        }
    } catch (ApiException e) {
        if (e.getCode() == 401) {
            clearSession();
        } else {
            throw new HaleConnectException(e.getMessage(), e);
        }
    }
    return isLoggedIn();
}
Also used : UsersApi(com.haleconnect.api.user.v1.api.UsersApi) Token(com.haleconnect.api.user.v1.model.Token) UserInfo(com.haleconnect.api.user.v1.model.UserInfo) HaleConnectUserInfo(eu.esdihumboldt.hale.io.haleconnect.HaleConnectUserInfo) HaleConnectException(eu.esdihumboldt.hale.io.haleconnect.HaleConnectException) LoginApi(com.haleconnect.api.user.v1.api.LoginApi) Credentials(com.haleconnect.api.user.v1.model.Credentials) ApiException(com.haleconnect.api.user.v1.ApiException)

Example 5 with ApiException

use of com.haleconnect.api.user.v1.ApiException in project hale by halestudio.

the class HaleConnectInputSupplier method getInput.

@Override
public InputStream getInput() throws IOException {
    Owner owner = HaleConnectUrnBuilder.extractProjectOwner(getLocation());
    String projectId = HaleConnectUrnBuilder.extractProjectId(getLocation());
    FilesApi api = ProjectStoreHelper.getFilesApi(basePathResolver, apiKey);
    final ApiResponse<File> response;
    try {
        response = api.getProjectFilesAsZipWithHttpInfo(owner.getType().getJsonValue(), owner.getId(), projectId);
    } catch (com.haleconnect.api.projectstore.v1.ApiException e) {
        throw new IOException(e.getMessage(), e);
    }
    // Cache lastModified timestamp at the time of import
    getLastModified();
    return new BufferedInputStream(new FileInputStream(response.getData()));
}
Also used : FilesApi(com.haleconnect.api.projectstore.v1.api.FilesApi) BufferedInputStream(java.io.BufferedInputStream) ApiException(com.haleconnect.api.projectstore.v1.ApiException) IOException(java.io.IOException) File(java.io.File) FileInputStream(java.io.FileInputStream)

Aggregations

ApiException (com.haleconnect.api.user.v1.ApiException)5 HaleConnectException (eu.esdihumboldt.hale.io.haleconnect.HaleConnectException)5 UsersApi (com.haleconnect.api.user.v1.api.UsersApi)3 UserInfo (com.haleconnect.api.user.v1.model.UserInfo)3 HaleConnectUserInfo (eu.esdihumboldt.hale.io.haleconnect.HaleConnectUserInfo)3 ApiCallback (com.haleconnect.api.projectstore.v1.ApiCallback)2 ApiException (com.haleconnect.api.projectstore.v1.ApiException)2 BucketsApi (com.haleconnect.api.projectstore.v1.api.BucketsApi)2 FilesApi (com.haleconnect.api.projectstore.v1.api.FilesApi)2 BucketDetail (com.haleconnect.api.projectstore.v1.model.BucketDetail)2 Feedback (com.haleconnect.api.projectstore.v1.model.Feedback)2 LoginApi (com.haleconnect.api.user.v1.api.LoginApi)2 OrganisationsApi (com.haleconnect.api.user.v1.api.OrganisationsApi)2 Credentials (com.haleconnect.api.user.v1.model.Credentials)2 OrganisationInfo (com.haleconnect.api.user.v1.model.OrganisationInfo)2 Token (com.haleconnect.api.user.v1.model.Token)2 HaleConnectOrganisationInfo (eu.esdihumboldt.hale.io.haleconnect.HaleConnectOrganisationInfo)2 File (java.io.File)2 ListenableFuture (com.google.common.util.concurrent.ListenableFuture)1 SettableFuture (com.google.common.util.concurrent.SettableFuture)1