msnp-wiki/docs/services/msgrconfig.md
yellows111 221de2169f
Corrections, USR, SYN
Added new section to Protocols (half done with it though): Changes to error codes, to ask "When did that error code get implemented and when did it get removed" Probably could be made better, eh.

5 Commands Remain.

New change record, too.
2024-10-23 21:47:02 +01:00

22 KiB

Introduction

The Messenger Config service (MsgrConfig) is a SOAP (XML) and HTTP Web Service. Introduced with MSNP9.

Defines various configuration options for the Official Client. Replaces svcs.microsoft.com.

It's default URL is http://config.messenger.msn.com/Config/MsgrConfig.asmx.

This service does not require Passport authentication.

Actions

GetClientConfig

Client/Request

As a SOAP Action / POST request

In the HTTP headers, this is defined:

SOAPAction: "http://www.msn.com/webservices/Messenger/Client/GetClientConfig"

<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
	<soap:Body>
		<GetClientConfig xmlns='http://www.msn.com/webservices/Messenger/Client'>
			<clientinfo>
				<Country>US</Country>
				<CLCID>0809</CLCID>
				<PLCID>0409</PLCID>
				<GeoID>242</GeoID>
			</clientinfo>
		</GetClientConfig>
	</soap:Body>
</soap:Envelope>

Where <Country> is the ISO 3166-1 alpha-2 of the binary you are using.

Where <CLCID> is the system's language code in unprefixed hexadecimal.

Where <PLCID> is the binary's language code in unprefixed hexadecimal.

Where <GeoID> is the system's geographic location in decimal.

As query parameters

GET http://config.messenger.msn.com/Config/MsgrConfig.asmx?op=GetClientConfig&Country=US&CLCID=0809&PLCID=0409&GeoID=242&ver=8.5.1302

Where op is always GetClientConfig.

Where Country is the ISO 3166-1 alpha-2 of the binary you are using.

Where CLCID is the system's language code in unprefixed hexadecimal.

Where PLCID is the binary's language code in unprefixed hexadecimal.

Where GeoID is the system's geographic location in decimal.

Where ver is the version of the client as a triplet.

Server/Response

As a SOAP envelope

This only applies if you use a SOAP request.

<?xml version="1.0" encoding="utf-8" ?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
	<soap:Body>
		<GetClientConfigResponse xmlns="http://www.msn.com/webservices/Messenger/Client">
			<GetClientConfigResult><![CDATA[<MsgrConfig>...</MsgrConfig>]]></GetClientConfigResult>
		</GetClientConfigResponse>
	</soap:Body>
</soap:Envelope>

Where <GetClientConfigResponse> contains a <GetClientConfigResult>.

Where GetClientConfigResult always contains a Character Data block containing a <MsgrConfig> element.

Where <MsgrConfig> (in the CDATA) is the Configuration Document.

As a XML document

This only applies if you use query parameters.

<?xml version="1.0" encoding="utf-8" ?>
<MsgrConfig>
...
</MsgrConfig>

Where <MsgrConfig> (everything but the declaration) is the Configuration Document.

The Configuration Document

<MsgrConfig>: The main element, contains everything.

Simple

Contains multiple shared configuration options, usually.

Beta

Contains configuration data for the Beta Program.

Invite

Manages the configuration data for the Beta Program Invitation service.

  • <URL>: The URL to the invitation service.
  • <SiteID>: The Passport Site ID for the invitation service.

Config

Contains options for the configuration data itself.

  • <ExpiresInDays>: The amount of days as a number before this expires

DisablePhoneDialer

If set to 1, the Phone Dialer is disabled.

Logitech

  • <PremiumAVConfigServer>: A URL to the premium Spotlife server (mplocate).
  • <PreRollEnabled>: Are pre-roll advertisements enabled for this feature (1 or 0)?
  • <WebcamConfigServer> A URL to the non-premium Spotlife server (mlocate).

MinFlashPlayer

The minimum version of Adobe/Macromedia Flash Player allowed before the client is allowed to use content that uses the Flash Player software.

This element has no children, but does have the following attributes:

  • BuildNumber: The minimum build number for this MinorVersion.
  • MajorVersion: The minimum major version for the plugin.
  • MinorVersion: The minimum minor version for this MajorVersion.

RadUrl

This element contains the advertisement service base URL.

Relay

Contains configuration data for the Audio/Video relay.

  • <Enabled>: If set to 1, the relay is enabled.
  • <MaxCallLength>: The maximum time (in unknown units) before the call is ended.
  • <RegistrationDomain>: Unknown.
  • <RelayDNS>: Contains the Fully Qualified Domain Name (FQDN) of the relay service.
  • <TimeoutToFallback>: The amount of milliseconds before falling back. If you know what the fallback is, please contact me.

TrustedDomains

Contains many <domain> elements.

domain

This empty element has the name attribute, which specifies the Fully Qualified Domain Name of the trusted domain. Treated as a silent wildcard.

ErrorResponseTable

This element only contains <Feature> elements.

Feature

This element only contains <Entry> elements.

This element has two attributes:

  • type: Unknown, but is 0 for Login, 2 for MapFile, and 3 for P2P.
  • name: The name of the feature:
    • Login: Login Process
    • MapFile: Content Cache Map Files
    • P2P: Peer-to-peer communications
Entry

This empty element has two attributes:

  • hr: The HRESULT of this entry, as prefixed hexadecimal.
  • action: What should the Official Client do in this case? (Usually 3.)

TabConfig

Replaces the tabs.asp service on svcs.microsoft.com.

msntabdata

This element only contains <tab> elements.

tab

This element can be repeated multiple times in the parent element.

  • <image>: Either a direct URL to a PNG file (36x32 size) or a resource id:
    • res:mail: A mail icon. Unused?
    • res:bell: A bell icon. Used for the alerts tab.
    • res:calendar: A clock icon. Used for the calendar service.
    • res:money: A stock chart icon or a icon depicting a stack of coins. Used for the finanical stocks service.
    • res:expedia: A plane icon. Used for the travel service.
    • res:carpoint: A car icon. Used for the car reselling service.
    • res:espn: The ESPN "E". Used for the relevant service.
    • res:zone: A joystick icon. Used for the games service.
    • res:msnbc: The MSNBC logo. Used for the relevant service.
    • res:eshop: A shopping bag icon. Used for the shopping service.
  • <name>: The name of this tab that is displayed in the Tab Options dialog.
  • <type>: An all-lowercase unique name for this tab. Setting this to hotmail will hide the tab automatically. Setting this to alerts makes the "View Alerts History" button go to this tab.
  • <contenturl>: A URL to the page that is displayed in the tab.
  • <hiturl>: A URL for a tracking pixel that is requested when this tab is clicked on.
  • <siteid>: The Passport Site ID of this tab. Any value except 0 will attempt to log into Passport automatically when the tab is shown.
  • <tabid>: Unknown what this is used for. If you know, please contact me.
  • <notificationid>: The ID used for opening the alert content in the relevant tab.
  • <hidden>: If true, this tab does not appear in the tab list.

msntabsettings

Contains options for OEM (Original Equipment Manufacturer) tabs. Unknown when this is used. If you know more, feel free to contact me. May only be used in Client Version 4.5 back on svcs?

  • <oemdisplaylimit>: Amount of OEM-defined tabs allowed to be displayed?
  • <oemtotallimit>: Amount of OEM-defined tabs allowed to be loaded

AbchCfg

Replaces the abch_config.asp service on svcs.microsoft.com.

abchconfig

AdMainConfig

  • <AdDownloadTimeInMinutes>: The amount of minutes until downloading the next banner image.
  • <AdMainCfg>: The URL to the advertisement service. Loaded as a HTML document.

AdPhoneConfig

Contains a URL to a document of currently undocumented content using the advertisement service.

LocalizedConfig

Contains a large chunk of special options that can vary wildly between locales.

This element has the attribute Market, which contains the ISO 639-1 language code for this Configuration Document.

AdMainConfig

  • <AdBanner20URL>: The URL to the advertisement service that handles banner advertisements.
  • <TextAdRefresh>: Amount of minutes before downloading a new text advertisement.
  • <TextAdServer>: The URL to the advertisement service that handles text advertisements.

AppDirConfig

  • <AppDirPageURL>: The URL to the page that is displayed that lets you open embedded applications from the Application Directory Service.
  • <AppDirSeviceURL>: [sic], The URL to the Application Directory Sevice, I mean, Service.
  • <AppDirVersionURL>: The URL to the Application Directory Service's version endpoint.

AVPrerollAd

This empty element has four attributes:

  • FetchTimeout: How many milliseconds before the client stops trying to fetch the pre-roll advertisement.
  • IntroLength: How long the advertisement introduction animation plays for in milliseconds.
  • MinAdLength: The minimum advertisement length in milliseconds.
  • URL: The URL to the advertisement service for pre-roll advertisements.

This empty element has one attribute named URL that specifies a web page you can buy a webcam from.

ContactCard

Blog intergration configuration options.

  • <AddToMySpaceSiteId>: The Passport Site ID used in <AddToMySpaceUrl>.
  • <AddToMySpaceUrl>: The URL used for the "Add to my blog" service.
  • <ContactCardDisabled>: Is the Contact Card Service disabled? (true or false)
  • <CreateSpaceSiteId>: The Passport Site ID used in <CreateSpaceUrl>.
  • <CreateSpaceUrl>: The URL used for the "Create a blog" service.
  • <GetItemVerUrl>: The URL to the storage service that provides the GetItemVersion SOAP action.
  • <GetXmlFeedUrl>: The URL to the Contact Card Service.
  • <MySpaceSiteId>: The Passport Site ID used in <MySpaceUrl>.
  • <MySpaceUrl>: The URL used for the "Visit my blog" service.
  • <SpaceBaseSiteId>: The Passport Site ID used in <SpaceBaseUrl>.
  • <SpaceBaseUrl>: The URL used for the blogging service.
  • <SpaceIntegrationEnabled>: Is this feature enabled? (true or false).

DynamicContent

Contains product advertisement configuration data.

merchant

Can contain:

  • <bkgrounds>
  • <emoticons2>
  • <themepacks>
  • <winks2>
bkgrounds

Free Background advertisement data. Only contains <slots>.

slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal.

emoticons2

Free Emoticon Pack advertisement data. Only contains <slots>.

Supports attribute visibleto, which is the Client Versions allowed to use this content. Usually 7.0.729 and greater.

slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal.

themepacks

Free Theme Pack advertisement data. Only contains <slots>.

slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal.

winks2

Free Winks advertisement data. Only contains <slots>.

Supports attribute visibleto, which is the Client Versions allowed to use this content. Usually 7.0.729 and greater.

slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal.

premium

Premium product advertisement configuration data.

bkgrounds

Premium background advertisement configuration data.

  • <providersiteid>: The Passport Site ID used for <providerurl>.
  • <providerurl>: The product provider URL.
  • <slots>: Contains multiple <URL> elements.
slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal.

emoticons2

Premium emoticon pack advertisement configuration data.

Supports attribute visibleto, which is the Client Versions allowed to use this content. Usually 7.0.729 and greater.

  • <providersiteid>: The Passport Site ID used for <providerurl>.
  • <providerurl>: The product provider URL.
  • <slots>: Contains multiple <URL> elements.
slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal.

themepacks

Premium Theme Pack advertisement configuration data.

  • <providersiteid>: The Passport Site ID used for <providerurl>.
  • <providerurl>: The product provider URL.
  • <slots>: Contains multiple <URL> elements.
slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal.

winks2

Premium Wink advertisement configuration data.

Supports attribute visibleto, which is the Client Versions allowed to use this content. Usually 7.0.729 and greater.

  • <providersiteid>: The Passport Site ID used for <providerurl>.
  • <providerurl>: The product provider URL.
  • <slots>: Contains multiple <URL> elements.
slots

Contains multiple <URL> elements that contain a URL to a msnmenuitem XML document. For more information read this section on msnmenuitem documents.

The <URL> element supports one attribute named id which is the identification number of this slot.

The <URL> element supports a formatting string of $PUID$, which is replaced with your Passport User ID in unprefixed lowercase hexadecimal. which is the identification number of this slot.

EditorialConfig

This element contains a URL to a XML document that contains editorial data.

FlashUpgradeURL

This element contains a URL to a web page that tells you how to update Adobe/Macromedia Flash Player, with the $VERSION$ in the URL being replaced with the current version of the plugin.

MessengerBlogURL

This element contains a URL that specifies the official blog of the service. Adds the "Open Messenger Blog" option to the Contact List's Tools menu.

MobileMessaging

This empty element has five attributes:

  • Mode: Unknown. RPPNew works.
  • CrossSell: Unknown. 1 works.
  • CharMax: The maximum amount of characters that can be sent using this service.
  • OperatorPage: The URL to the landing page of this service.
  • ValidRoutes: A semi-colon delimited list of ISO 3166-1 alpha-2 codes that specify which phone numbers this service is allowed to use.

MSNSearch

Controls the URLs used by search features.

  • <DesktopInstallURL>: The promotional page that opens when attempting a desktop search without the required software installed.
  • <ImagesURL>: The image search service URL.
  • <NearMeURL>: The search service URL for local services.
  • <NewsURL>: The news search service URL.
  • <SearchKidsURL>: The search service URL for children's accounts.
  • <SearchURL>: The search service URL.
  • <SharedSearchURL>: The search service URL used in the inline search feature.
  • <SharedSearchURL2>: The other search service URL used in the inline search feature.

All <...URL> elements support two formatting strings:

  • $QUERY$: The search query.
  • $FC$: The format code.

If the element is <SharedSearchURL> or <SharedSearchURL2>, the $FORMAT$ formatting string is avaliable.

MsnTodayConfig

  • <MsnTodaySiteID>: The Passport Site ID that <MsnTodayURL> uses. Setting this to 0 disables authentication.
  • <MsnTodayURL>: The URL to the daily news service.

MusicIntegration

This empty element has two attributes:

  • URL: The URL to the music search function, supporting the following formatting strings:
    • $TITLE$: The title of the song.
    • $ARTIST$: The artist of the song.
    • $ALBUM$: The album of the song.
    • $WMID$: The Windows Media DRM ID of the song (if avaliable).
  • SiteID: The Passport Site ID that URL uses.

PremiumAV

This empty element has the attribute Visibility. 1 likely enables this feature.

RL

  • <ViewProfileURL>: The URL used to open the Member Directory for this user. Has the following formatting strings:
    • %1: Unknown
    • %2: Unknown
    • %3: Unknown
    • %4: Unknown
    • %5: Unknown
    • %6: The user handle that you want to view.

TermsOfUse

  • <TermsOfUseSID>: The Passport Site ID that <TermsOfUseURL> uses, if this is 0, no authentication is attempted.
  • <TermsOfUseURL>: The URL to the Messenger Service Terms of Use.

UPUX

This element contains many <Product> elements.

Product

This element has three required attributes and three optional attributes:

  • id: The ID for this Product Provider
  • PartnerID: The partner 2 character code.
  • ProductName: The type of product:
    • Winks
    • Emoticons
    • Backgrounds
    • Theme Packs
    • Dynamic Display Pictures
  • BrandName (optional): The display name of this product.
  • DialogMenuString (optional): What the client shows when promoting this product.
  • IntegrationType (optional): How the client should promote this product. Can either be medium or deep.

This element contains the following children:

  • <BillingURL>: The page that provides payment options for this product.
  • <BillingHelpURL>: The page that provides information on purchasing content.
  • <ProductShopURL>: The page that provides the marketplace service.
  • <BasePurchaseURL>: The page that opens when a client uses the "Get this" feature.
...URL

These empty elements have three attributes:

  • LaunchWindowType: If this is IE, open in the default browser, otherwise the internal page viewer in the client.
  • SiteID: The Passport Site ID for URL.
  • URL: The URL to this service. If this element is <BasePurchaseURL>, then the formatting string $CONTENTID$ is avaliable.

VoiceClip

This empty element has one attribute named Hidden, If this is 1, the feature is hidden.

WebWatchConfig

  • <SendSiteID>: The Passport Site ID that <SendURL> uses. Unused, always 0.
  • <SendURL>: The URL for the unimplemented send function.
  • <SetupSiteID>: The Passport Site ID that <SetupURL> uses.
  • <SetupURL>: The URL for the Web Watch Setup wizard.

Other Related documents

msnmenuitem XML Document

<?xml version="1.0" encoding="UTF-8"?>
<msnmenuitem version="1.0">
	<thumburl>http://.../.png</thumburl>
	<displaytext>...</displaytext>
	<clickurl>http://...</clickurl>
	<clicktrackurl></clicktrackurl>
	<siteid>0</siteid>
</msnmenuitem>

Where <msnmenudata> contains:

  • <thumburl>: The thumbnail for this product (50x50 PNG).
  • <displaytext>: The display name for this product.
  • <clickurl>: The URL to the marketplace page for this product.
  • <clicktrackurl>: The URL for the click tracking service.
  • <siteid>: The Passport Site ID used for <clickurl> (and <clicktrackurl>?).

If the item is for a <premium> product, <clickurl> is opened in the internal page browser. If it is for a <merchant> product instead, <clickurl> is sent to MessengerContentInstaller.InstallIndirectContent.

TODO: What is a "Merchant CAB file"? InstallIndirectContent wants one.

Editorial document

<?xml version="1.0" encoding="utf-8" ?>
<msn-data>
	<RefreshLogin>True</RefreshLogin>
	<RefreshInterval>60</RefreshInterval>
	<article-group>
		<article>
			<title>...</title>
			<url>http://...</url>
		</article>
			<title>...</title>
			<url>http://...</url>
		</article>
			<title>...</title>
			<url>http://...</url>
		</article>
	</article-group>
</msn-data>

Where <RefreshLogin> specifies if this document should be re-downloaded every time you log into the Messenger Service.

Where <RefreshInterval> specifies in minutes when this document should be automatically re-downloaded.

Where <article-group> contains multiple <article> elements:

  • <title>: The display name of this article.
  • <url>: The URL to this aricle.