teams-for-linux
teams-for-linux copied to clipboard
Custom background images?
Hello. I'm using your teams-for-linux client again after switching to the "official" client for a couple of years. With the recent news about Microsoft killing off the Linux client, was delighted to see that this project was still going strong, and even more so to learn that you're supporting background blur and images and various other features Microsoft apparently couldn't be bothered to support themselves on Linux. Very much appreciate what you've been doing here.
I'm trying to add a custom background image. My understanding from some basic searching is that there's supposed to be an Add Image option in the background image selector, but I don't seem to have that. Honestly not sure if this is a bug, known limitation, or if I'm just missing something since I've never done this before.
Can you please provide any guidance on whether this is supported and if so, how to use this feature? Apologies for the basic question here, but couldn't find a clear answer and not sure where else to ask. Thanks.
Are you referring to background during video calls? If so, it's already working I believe.
Adding a custom background image during video calls, yes. If that's working for you, mind sharing how to do that? I'm expecting to see some kind of Add Image link or button in the "Show background effects" pane. I have the ability to select blur and various canned images, and get the Preview and Apply options, but nothing related to adding images.
Ok, i understand now. I was referring to predefined backgrounds in the teams app. Never tried uploading image from local machine. Implementing this feature may be difficult. If it's present in web version, it could be possible here as well. I'd have it checked. Thanks.
@nitro322
Can you check in chrome?
https://support.microsoft.com/en-us/office/change-your-background-for-a-teams-meeting-f77a2381-443a-499d-825e-509a140f4780
I tested with Vivaldi (not Chrome, but uses the same engine and I've never observed any compatibility issues between it and Chrome) and get the same behavior as the electron app. You bring up a good point about the web version - I was thinking of Teams as a desktop application, but if you're essentially re-packaging the web version then I could see where that feature wouldn't be supported. Checking the link you sent, for example, shows instructions for desktop and mobile clients, but not web.
So, looks like this may not be supported after all. Bummer, but not a big deal. Appreciate the dialog. Feel free to close this if you agree this isn't supported with the web app.
It's sort of hidden. You can use the teams-for-linux app itself.
- Start a call
- Click on ...
- Show background effects
- There you go.
Right, I can find that part. I'm talking about custom images. Ie., this (from that same microsoft link you posted above):
You can also replace your background with one of the images provided, or with one of your own choosing. To use an image of your own, select Add new and then select one to upload from your computer. Make sure it's a .JPG, .PNG, or .BMP file.
That "Add new" option doesn't exist for me.
Oh, I see. Have you had used the feature on the destop for linux or have you used windows or mac version?
It didn't exist in the Linux client. No background effects options existed. No, I've never used the Windows or Mac version, hence my general uncertainty in the OP as I've never actually used this feature myself before. But many of my work colleagues have used it, so I know it works under the right conditions. Seems like those conditions exclude the web client, unfortunately.
Right, I see the images are dynamically loaded from a CDN. We might be able to do some hacks to achieve.
For example: https://static.cdn.microsoft.com/image1 request can be locally served using a different image. By faking the response and make the logic believe that it actually came from a web server. We can experiment.
Hi there @jijojosephk, I really hope there is something we could do. Is there could you possibly point me to what specific URL I can overwrite to fake the images? I see the above DNS does not actually exist.
@malanvaneck that was just a url I added while writing comment. Not an actual one.
Preview: https://statics.teams.cdn.office.net/evergreen-assets/backgroundimages/teamsBackgroundContemporaryOffice03_thumb.png?v=0.1
Background: https://statics.teams.cdn.office.net/evergreen-assets/backgroundimages/teamsBackgroundContemporaryOffice03.png?v=0.1
Thanks @jijojosephk
Actually faking the URL locally will be a problem as its an HTTPS request:
[19537:1011/141457.927329:ERROR:ssl_client_socket_impl.cc(983)] handshake failed; returned -1, SSL error code 1, net_error -202 [ERROR] Unknown cert issuer for url: https://statics.teams.cdn.office.net/evergreen-assets/backgroundimages/fluentSpaces4.png?v=0.1 [ERROR] Issuer Name: Internet Widgits Pty Ltd [ERROR] The unknown certificate fingerprint is: sha256/qF4veWeE4gVPvPp+5bV0ACX4JxChH39nMhTy+in7s3Q=
Apologies, only just now saw the --customCACertsFingerprints option. Got around the cert issues like this: teams-for-linux --customCACertsFingerprints sha256/dRZpQs2cfMlKCdkKOMvGNHASikwm0WmHRtIhEypr880=
Images are not successfully being pulled from my mini python server: 127.0.0.1 - - [11/Oct/2022 16:49:08] "OPTIONS /evergreen-assets/backgroundimages/teamsBackgroundContemporaryOffice01.png?v=0.1 HTTP/1.1" 200 - 127.0.0.1 - - [11/Oct/2022 16:49:08] "GET /evergreen-assets/backgroundimages/teamsBackgroundContemporaryOffice01.png?v=0.1 HTTP/1.1" 200 - 127.0.0.1 - - [11/Oct/2022 16:49:08] "OPTIONS /evergreen-assets/backgroundimages/teamsBackgroundContemporaryOffice01.png?v=0.1 HTTP/1.1" 200 - 127.0.0.1 - - [11/Oct/2022 16:49:08] "GET /evergreen-assets/backgroundimages/teamsBackgroundContemporaryOffice01.png?v=0.1 HTTP/1.1" 200 -
But black image on teams-for-linux
@malanvaneck I think you're pretty close. I also get black background. You're not changing the protocol or scheme. You might be stuck in CORS issue. What do you see in the debugger?
I took a slightly different route. Looks like the approach I'm taking requires some help from electron dev I guess. I left a comment in bug here
What I tried is below with response ERR_UNKNOWN_URL_SCHEME
// In the main file
protocol.registerSchemesAsPrivileged([
{
scheme: 'atom',
privileges: {
bypassCSP: true,
corsEnabled: true,
secure: true,
standard: true,
supportFetchAPI: true
}
}
]);
// When app is ready
protocol.registerHttpProtocol('atom', (request, callback) => {
request.url = path.join(__dirname, '../assets/bg/bg1.png');
callback(request);
});
// Before request
window.webContents.session.webRequest.onBeforeRequest({ urls: ['https://*/*'] }, (details, callback) => {
if (details.url === 'https://mywebsite.com/bg/bg1.png') {
callback({
redirectURL: 'atom://bg1.png'
});
} else {
// Proceed normally
callback({});
}
});
net::ERR_UNKNOWN_URL_SCHEME
Hi there @jijojosephk, I see these errors in the logs: 41818:1012/093045.034783:ERROR:ssl_client_socket_impl.cc(983)] handshake failed; returned -1, SSL error code 1, net_error -202
Also, I have noticed that overwriting the statics.teams.cdn.office.net DNS name to point to local causes Teams to sometimes be unresponsive.
Hello, I'm extremely interested in this feature. I reboot to the other partition literally only to switch on the company-required background for departmental calls and all the rest of the time I'm peacefully in Linux reading chat. With the previous official client I can confirm it was impossible to switch the background, but for the Windows client it was fairly straightforward to add a custom bg.
Where are the default backgrounds stored? Perhaps one of them could be overwritten?
@Xisiqomelir They're not stored locally, served from a MS CDN. I tried to fake the response from a local file but did not succeed. 32253 seems to be blocker from electron framework.
Ahh that’s typically M$ and very annoying.
In any case, thanks for your work in keeping the client alive especially this year that they’re trying to kill it.
@jijojosephk It works if you serve the image via https with an Access-Control-Allow-Origin
header (just setting it to *
worked). Redirecting to a data:
url might also work.
@cpfeiffer Could you tell us how exactly this can be used?
What code do we need given that we have a URL of a custom background picture? And where do we need to put that code?
Speaking as a user of teams-for-linux, not a developer.
I tried a data URL (that's some Cat Picutre)
window.webContents.session.webRequest.onBeforeRequest({ urls: ['https://*/*'] }, (details, callback) => {
if (details.url === 'https://statics.teams.cdn.office.net/evergreen-assets/backgroundimages/teamsBackgroundContemporaryOffice03.png?v=0.1') {
callback({
redirectURL: ''
});
} else {
// Proceed normally
callback({});
}
});
But I am getting
Uncaught TypeError: Cannot read properties of undefined (reading 'session')
at <anonymous>:1:20
(I tried this in the dev tools )
EDIT: tried inserting it into onBeforeRequestHandler / app/mainAppWindow/index.js:135
UNSAFE_REDIRECT .. happens also for data urls
@amenk UNSAFE_REDIRECT : Maybe you need to add the Access-Control-Allow-Origin: *
header
Not sure how... I found this https://stackoverflow.com/a/52243138/956397
I tried a lot with CORS and the request but it all caused UNSAFE_REDIRECTS or made everything stop working.
But now I found another way to change the background to a custom one, using the debugger.
- Search for the function configureEffect
- Open a new meeting in a channel
- Click any of the built-in backgrounds
- Code should stop now at that function
- Paste
A.backgroundImageUrl = "data: ....."
with your image into the console, press enter (probably a hosted image works as well?) - Continue the code
The custom image should show in the preview and I tested that it is also visible to the other party in a call.
Unfortunately that custom background is not preserved after restarts.
The other question is if this can be made usable in a nice way - i.e. is the Electron app able to inject / patch Javascript code?
@DerXteMensch Sorry, this is nothing for end-users, yet. I was merely trying to check if it works at all, because all previous attempts in this thread appeared to have been unsuccessful. All I did was patch the onBeforeRequestHandler()
, check the URL for one of the default background images and redirect to a custom image of my own. The only "special" thing I had to do was return the Access-Control-Allow-Origin: *
policy from my custom server.
To make this usable for end-users, one would
- allow configuring a server-URL hosting custom background images and the appropriate json file so that the images can be listed in the UI
- or find a way to host them locally, with or without TLS
- add the redirect in the
onBeforeRequestHandler()
to the server-URL or locally hosted service
Well I have something interesting :smile: Once the page is loaded. Open debug->console and execute the script below.
Replace args[0]=<daturl>
with base64 converted image of your choice. You may use https://www.base64-image.de/ to convert.
Click calendar Meet Now Select background effect Click any image
May be we're very close :smile:
const controller = typeof window.angular !== 'undefined' ? window.angular.element(document.documentElement).controller() : null;
const x = controller.callingService._deviceManagerService.setBackgroundImageOnDevice;
controller.callingService._deviceManagerService.setBackgroundImageOnDevice = (...args) => {
args[0] = '<daturl>'; x.apply(controller.callingService._deviceManagerService, [...args]);
};
@amenk @cpfeiffer try the above.
@jijojosephk Seems to work pretty well. It replaces all the in-built images with the custom one. Draft pull request incoming ...
Breakthrough :tada: Now I need to stitch everything together as a feature. Hooray!
The car image is hosted in apache. So we need to have a light weight web server starting with application at a custom port. Then things are pretty doable.
https://user-images.githubusercontent.com/11662148/236913080-4f5ee054-bf76-431b-a17f-511a24643ada.mp4
@nitro322 @malanvaneck @Xisiqomelir @cpfeiffer @DerXteMensch @amenk @kw-pr try 1.0.84
pre-release. Read https://github.com/IsmaelMartinez/teams-for-linux/tree/develop/app/config