Skip to content

Commit

Permalink
[googletts] Dispose oAuth2 service
Browse files Browse the repository at this point in the history
Related to #14818

Signed-off-by: Laurent Garnier <lg.hc@free.fr>
  • Loading branch information
lolodomo committed May 5, 2023
1 parent 58470ca commit 3e43c2c
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 11 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -113,11 +113,6 @@ class GoogleCloudAPI {
*/
private @Nullable GoogleTTSConfig config;

/**
* Status flag
*/
private boolean initialized;

private final Gson gson = new GsonBuilder().create();
private final ConfigurationAdmin configAdmin;
private final OAuthFactory oAuthFactory;
Expand All @@ -143,6 +138,11 @@ class GoogleCloudAPI {
void setConfig(GoogleTTSConfig config) {
this.config = config;

if (oAuthService != null) {
oAuthFactory.ungetOAuthService(GoogleTTSService.SERVICE_PID);
oAuthService = null;
}

String clientId = config.clientId;
String clientSecret = config.clientSecret;
if (clientId != null && !clientId.isEmpty() && clientSecret != null && !clientSecret.isEmpty()) {
Expand All @@ -152,17 +152,14 @@ void setConfig(GoogleTTSConfig config) {
false);
this.oAuthService = oAuthService;
getAccessToken();
initialized = true;
initVoices();
} catch (AuthenticationException | CommunicationException e) {
logger.warn("Error initializing Google Cloud TTS service: {}", e.getMessage());
oAuthService = null;
initialized = false;
voices.clear();
}
} else {
oAuthService = null;
initialized = false;
voices.clear();
}

Expand All @@ -176,6 +173,14 @@ void setConfig(GoogleTTSConfig config) {
}
}

public void dispose() {
if (oAuthService != null) {
oAuthFactory.ungetOAuthService(GoogleTTSService.SERVICE_PID);
oAuthService = null;
}
voices.clear();
}

/**
* Fetches the OAuth2 tokens from Google Cloud Platform if the auth-code is set in the configuration. If successful
* the auth-code will be removed from the configuration.
Expand Down Expand Up @@ -367,8 +372,10 @@ public byte[] synthesizeSpeech(String text, GoogleTTSVoice voice, String codec)
return audio;
} catch (AuthenticationException | CommunicationException e) {
logger.warn("Error initializing Google Cloud TTS service: {}", e.getMessage());
oAuthService = null;
initialized = false;
if (oAuthService != null) {
oAuthFactory.ungetOAuthService(GoogleTTSService.SERVICE_PID);
oAuthService = null;
}
voices.clear();
} catch (FileNotFoundException e) {
logger.warn("Could not write file {} to cache: {}", audioFileInCache, e.getMessage());
Expand Down Expand Up @@ -490,6 +497,6 @@ private String getUniqueFilenameForText(String text, String voiceName) {
}

boolean isInitialized() {
return initialized;
return oAuthService != null;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@
import org.osgi.service.cm.ConfigurationAdmin;
import org.osgi.service.component.annotations.Activate;
import org.osgi.service.component.annotations.Component;
import org.osgi.service.component.annotations.Deactivate;
import org.osgi.service.component.annotations.Modified;
import org.osgi.service.component.annotations.Reference;
import org.slf4j.Logger;
Expand Down Expand Up @@ -139,6 +140,11 @@ protected void activate(Map<String, Object> config) {
updateConfig(config);
}

@Deactivate
protected void dispose() {
apiImpl.dispose();
}

/**
* Initializing audio formats. Google supports 3 formats:
* LINEAR16
Expand Down

0 comments on commit 3e43c2c

Please sign in to comment.