Skip to content

Commit

Permalink
Merge branch 'master' into refactor-api-keys-service
Browse files Browse the repository at this point in the history
  • Loading branch information
giancarloromeo authored Dec 4, 2024
2 parents 387a197 + f56acf6 commit 29ea1c9
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 22 deletions.
4 changes: 3 additions & 1 deletion packages/service-library/src/servicelib/redis.py
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,7 @@
from redis.backoff import ExponentialBackoff
from settings_library.redis import RedisDatabase, RedisSettings
from tenacity import retry
from yarl import URL

from .background_task import periodic_task
from .logging_utils import log_catch, log_context
Expand Down Expand Up @@ -94,7 +95,8 @@ def __post_init__(self):
async def setup(self) -> None:
if not await self.ping():
await self.shutdown()
raise CouldNotConnectToRedisError(dsn=self.redis_dsn)
url_safe: URL = URL(self.redis_dsn).with_password("???")
raise CouldNotConnectToRedisError(dsn=f"{url_safe}")

self._health_check_task = asyncio.create_task(
self._check_health(),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,27 +27,7 @@ qx.Class.define("osparc.widget.PersistentIframe", {
construct: function(source, el) {
this.base(arguments, source);

this.themeSwitchHandler = msg => {
this.postThemeSwitch(msg.getData());
};

this.postThemeSwitch = theme => {
const iframe = this._getIframeElement();
if (this._getIframeElement()) {
const iframeDomEl = iframe.getDomElement();
const iframeSource = iframe.getSource();
if (iframeDomEl && iframeSource) {
const msg = "osparc;theme=" + theme;
try {
iframeDomEl.contentWindow.postMessage(msg, iframeSource);
} catch (err) {
console.log(`Failed posting message ${msg} to iframe ${iframeSource}\n${err.message}`);
}
}
}
};

qx.event.message.Bus.getInstance().subscribe("themeSwitch", this.themeSwitchHandler);
this.__attachInterframeMessageHandlers();
},

statics: {
Expand Down Expand Up @@ -265,6 +245,69 @@ qx.Class.define("osparc.widget.PersistentIframe", {
this.__iframe.setSource(newValue);
},

__attachInterframeMessageHandlers: function() {
this.__attachTriggerers();
this.__attachListeners();
},

__attachTriggerers: function() {
this.postThemeSwitch = theme => {
const iframe = this._getIframeElement();
if (iframe) {
const iframeDomEl = iframe.getDomElement();
const iframeSource = iframe.getSource();
if (iframeDomEl && iframeSource) {
const msg = "osparc;theme=" + theme;
try {
iframeDomEl.contentWindow.postMessage(msg, iframeSource);
} catch (err) {
console.log(`Failed posting message ${msg} to iframe ${iframeSource}\n${err.message}`);
}
}
}
};

this.themeSwitchHandler = msg => {
this.postThemeSwitch(msg.getData());
};
qx.event.message.Bus.getInstance().subscribe("themeSwitch", this.themeSwitchHandler);
},

__attachListeners: function() {
this.__iframe.addListener("load", () => {
const iframe = this._getIframeElement();
if (iframe) {
const iframeDomEl = iframe.getDomElement();
if (iframeDomEl) {
window.addEventListener("message", message => {
const data = message.data;
if (data) {
this.__handleIframeMessage(data);
}
});
}
}
}, this);
},

__handleIframeMessage: function(data) {
if (data["type"] && data["message"]) {
if (data["type"] === "theme") {
// switch theme driven by the iframe
const message = data["message"];
if (message.includes("osparc;theme=")) {
const themeName = message.replace("osparc;theme=", "");
const validThemes = osparc.ui.switch.ThemeSwitcher.getValidThemes();
const themeFound = validThemes.find(theme => theme.basename === themeName);
const themeManager = qx.theme.manager.Meta.getInstance();
if (themeFound !== themeManager.getTheme()) {
themeManager.setTheme(themeFound);
}
}
}
}
},

// override
_getIframeElement: function() {
return this.__iframe._getIframeElement(); // eslint-disable-line no-underscore-dangle
Expand Down

0 comments on commit 29ea1c9

Please sign in to comment.