teams-for-linux icon indicating copy to clipboard operation
teams-for-linux copied to clipboard

Custom background images?

Open nitro322 opened this issue 2 years ago • 10 comments

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.

nitro322 avatar Sep 15 '22 22:09 nitro322

Are you referring to background during video calls? If so, it's already working I believe.

jijojosephk avatar Sep 16 '22 08:09 jijojosephk

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.

nitro322 avatar Sep 16 '22 13:09 nitro322

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.

jijojosephk avatar Sep 16 '22 14:09 jijojosephk

@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

jijojosephk avatar Sep 16 '22 14:09 jijojosephk

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.

nitro322 avatar Sep 16 '22 14:09 nitro322

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.

Screenshot from 2022-09-16 22-27-06 Screenshot from 2022-09-16 22-27-58

jijojosephk avatar Sep 16 '22 16:09 jijojosephk

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.

nitro322 avatar Sep 16 '22 17:09 nitro322

Oh, I see. Have you had used the feature on the destop for linux or have you used windows or mac version?

jijojosephk avatar Sep 16 '22 17:09 jijojosephk

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.

nitro322 avatar Sep 16 '22 17:09 nitro322

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.

jijojosephk avatar Sep 16 '22 18:09 jijojosephk

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 avatar Oct 06 '22 08:10 malanvaneck

@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

jijojosephk avatar Oct 06 '22 16:10 jijojosephk

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=

malanvaneck avatar Oct 11 '22 12:10 malanvaneck

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 avatar Oct 11 '22 14:10 malanvaneck

@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

jijojosephk avatar Oct 11 '22 18:10 jijojosephk

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.

malanvaneck avatar Oct 12 '22 09:10 malanvaneck

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 avatar Oct 20 '22 01:10 Xisiqomelir

@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.

jijojosephk avatar Oct 20 '22 08:10 jijojosephk

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.

Xisiqomelir avatar Oct 20 '22 08:10 Xisiqomelir

@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 avatar Dec 26 '22 19:12 cpfeiffer

@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.

DerXteMensch avatar Jan 12 '23 14:01 DerXteMensch

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 avatar Jan 20 '23 11:01 amenk

@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

kw-pr avatar Jan 20 '23 12:01 kw-pr

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.

image

  1. Search for the function configureEffect
  2. Open a new meeting in a channel
  3. Click any of the built-in backgrounds
  4. Code should stop now at that function
  5. Paste A.backgroundImageUrl = "data: ....." with your image into the console, press enter (probably a hosted image works as well?)
  6. 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?

amenk avatar Jan 20 '23 15:01 amenk

@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

cpfeiffer avatar Jan 22 '23 18:01 cpfeiffer

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]);
};

jijojosephk avatar May 07 '23 08:05 jijojosephk

@amenk @cpfeiffer try the above.

jijojosephk avatar May 07 '23 08:05 jijojosephk

@jijojosephk Seems to work pretty well. It replaces all the in-built images with the custom one. Draft pull request incoming ...

amenk avatar May 07 '23 09:05 amenk

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

jijojosephk avatar May 08 '23 19:05 jijojosephk

@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

jijojosephk avatar May 09 '23 06:05 jijojosephk