[MS-FSFDP]:

Forms Services Feature Detection Protocol

Intellectual Property Rights Notice for Open Specifications Documentation

§  Technical Documentation. Microsoft publishes Open Specifications documentation for protocols, file formats, languages, standards as well as overviews of the interaction among each of these technologies.

§  Copyrights. This documentation is covered by Microsoft copyrights. Regardless of any other terms that are contained in the terms of use for the Microsoft website that hosts this documentation, you may make copies of it in order to develop implementations of the technologies described in the Open Specifications and may distribute portions of it in your implementations using these technologies or your documentation as necessary to properly document the implementation. You may also distribute in your implementation, with or without modification, any schema, IDL's, or code samples that are included in the documentation. This permission also applies to any documents that are referenced in the Open Specifications.

§  No Trade Secrets. Microsoft does not claim any trade secret rights in this documentation.

§  Patents. Microsoft has patents that may cover your implementations of the technologies described in the Open Specifications. Neither this notice nor Microsoft's delivery of the documentation grants any licenses under those or any other Microsoft patents. However, a given Open Specification may be covered by Microsoft Open Specification Promise or the Community Promise. If you would prefer a written license, or if the technologies described in the Open Specifications are not covered by the Open Specifications Promise or Community Promise, as applicable, patent licenses are available by contacting .

§  Trademarks. The names of companies and products contained in this documentation may be covered by trademarks or similar intellectual property rights. This notice does not grant any licenses under those rights. For a list of Microsoft trademarks, visit www.microsoft.com/trademarks.

§  Fictitious Names. The example companies, organizations, products, domain names, e-mail addresses, logos, people, places, and events depicted in this documentation are fictitious. No association with any real company, organization, product, domain name, email address, logo, person, place, or event is intended or should be inferred.

Reservation of Rights. All other rights are reserved, and this notice does not grant any rights other than specifically described above, whether by implication, estoppel, or otherwise.

Tools. The Open Specifications do not require the use of Microsoft programming tools or programming environments in order for you to develop an implementation. If you have access to Microsoft programming tools and environments you are free to take advantage of them. Certain Open Specifications are intended for use in conjunction with publicly available standard specifications and network programming art, and assumes that the reader either is familiar with the aforementioned material or has immediate access to it.

Revision Summary

Date / Revision History / Revision Class / Comments /
4/4/2008 / 0.1 / New / Initial Availability
6/27/2008 / 1.0 / Major / Revised and edited the technical content
12/12/2008 / 1.01 / Editorial / Revised and edited the technical content
7/13/2009 / 1.02 / Major / Revised and edited the technical content
8/28/2009 / 1.03 / Editorial / Revised and edited the technical content
11/6/2009 / 1.04 / Editorial / Revised and edited the technical content
2/19/2010 / 2.0 / Minor / Updated the technical content
3/31/2010 / 2.01 / Editorial / Revised and edited the technical content
4/30/2010 / 2.02 / Editorial / Revised and edited the technical content
6/7/2010 / 2.03 / Editorial / Revised and edited the technical content
6/29/2010 / 2.04 / Editorial / Changed language and formatting in the technical content.
7/23/2010 / 2.05 / Minor / Clarified the meaning of the technical content.
9/27/2010 / 2.05 / None / No changes to the meaning, language, or formatting of the technical content.
11/15/2010 / 2.05 / None / No changes to the meaning, language, or formatting of the technical content.
12/17/2010 / 2.05 / None / No changes to the meaning, language, or formatting of the technical content.
3/18/2011 / 2.05 / None / No changes to the meaning, language, or formatting of the technical content.
6/10/2011 / 2.6 / Minor / Clarified the meaning of the technical content.
1/20/2012 / 3.0 / Major / Significantly changed the technical content.
4/11/2012 / 3.0 / None / No changes to the meaning, language, or formatting of the technical content.
7/16/2012 / 3.0 / None / No changes to the meaning, language, or formatting of the technical content.
9/12/2012 / 3.0 / None / No changes to the meaning, language, or formatting of the technical content.
10/8/2012 / 3.0.1 / Editorial / Changed language and formatting in the technical content.
2/11/2013 / 3.0.1 / None / No changes to the meaning, language, or formatting of the technical content.
7/30/2013 / 4.0 / Major / Significantly changed the technical content.
11/18/2013 / 4.0 / None / No changes to the meaning, language, or formatting of the technical content.
2/10/2014 / 4.0 / None / No changes to the meaning, language, or formatting of the technical content.
4/30/2014 / 4.0 / None / No changes to the meaning, language, or formatting of the technical content.
7/31/2014 / 4.0 / None / No changes to the meaning, language, or formatting of the technical content.
10/30/2014 / 4.0 / None / No changes to the meaning, language, or formatting of the technical content.
2/26/2016 / 5.0 / Major / Significantly changed the technical content.

Table of Contents

1 Introduction 6

1.1 Glossary 6

1.2 References 7

1.2.1 Normative References 7

1.2.2 Informative References 8

1.3 Overview 8

1.4 Relationship to Other Protocols 8

1.5 Prerequisites/Preconditions 9

1.6 Applicability Statement 9

1.7 Versioning and Capability Negotiation 9

1.8 Vendor-Extensible Fields 9

1.9 Standards Assignments 9

2 Messages 10

2.1 Transport 10

2.2 Message Syntax 10

2.2.1 Request Syntax 10

2.2.1.1 Request HTTP Version 10

2.2.1.2 Request HTTP Method 10

2.2.1.3 Request-URI Syntax 10

2.2.1.3.1 Request-URI Details 10

2.2.1.3.2 Query Component Details 10

2.2.1.3.2.1 Request for Form Server Detection 11

2.2.1.3.2.2 Request for Form Server Version Retrieval 11

2.2.1.3.2.3 Request for Rendering URL Construction 11

2.2.1.4 Request Headers Syntax 12

2.2.2 Response Syntax 12

2.2.2.1 Response Status-Line 12

2.2.2.1.1 Success Response 12

2.2.2.1.2 Failure Response 13

2.2.2.2 Response Headers 13

2.2.2.3 Response Body Syntax 13

2.2.2.3.1 Response for Form Server Detection Request 13

2.2.2.3.2 Response for Form Server Version Retrieval Request 13

2.2.2.3.3 Response for Rendering URL Construction Request 13

3 Protocol Details 15

3.1 Common Details 15

3.1.1 Abstract Data Model 15

3.1.2 Timers 15

3.1.3 Initialization 15

3.1.4 Higher-Layer Triggered Events 15

3.1.5 Message Processing Events and Sequencing Rules 15

3.1.6 Timer Events 15

3.1.7 Other Local Events 15

3.2 Client Details 16

3.2.1 Abstract Data Model 16

3.2.2 Timers 16

3.2.3 Initialization 16

3.2.4 Higher-Layer Triggered Events 16

3.2.5 Message Processing Events and Sequencing Rules 16

3.2.6 Timer Events 17

3.2.7 Other Local Events 17

3.3 Server Details 17

3.3.1 Abstract Data Model 17

3.3.2 Timers 17

3.3.3 Initialization 17

3.3.4 Higher-Layer Triggered Events 17

3.3.5 Message Processing Events and Sequencing Rules 17

3.3.6 Timer Events 18

3.3.7 Other Local Events 18

4 Protocol Examples 19

4.1 Form Server Detection 19

4.1.1 Client Request 19

4.1.2 Server Response 19

4.1.2.1 Response When Form Server Is Enabled 19

4.1.2.2 Response When Form Server Is Not Enabled 19

4.2 Form Server Version Retrieval 19

4.2.1 Client Request 19

4.2.2 Server Response 20

4.2.2.1 Response When Form Server Is Enabled 20

4.2.2.2 Response When Form Server Is Not Enabled 20

4.3 Rendering URL Construction 20

4.3.1 Client Request 20

4.3.2 Server Response 20

4.3.2.1 Response When Form Server Is Enabled 20

4.3.2.2 Response When Form Server Is Not Enabled 21

5 Security 22

5.1 Security Considerations for Implementers 22

5.2 Index of Security Parameters 22

6 Appendix A: Product Behavior 23

7 Change Tracking 24

8 Index 26

1  Introduction

The Forms Services Feature Detection Protocol enables a protocol client to detect status of form server features, get the form server version, and get the constructed URL that is required to render a form in a Web browser.

Sections 1.5, 1.8, 1.9, 2, and 3 of this specification are normative. All other sections and examples in this specification are informative.

1.1  Glossary

This document uses the following terms:

200 OK: A response to indicate that the request has succeeded.

absolute URI: An absolute Uniform Resource Identifier (URI), as described in [RFC3986].

ASCII: The American Standard Code for Information Interchange (ASCII) is an 8-bit character-encoding scheme based on the English alphabet. ASCII codes represent text in computers, communications equipment, and other devices that work with text. ASCII refers to a single 8-bit ASCII character or an array of 8-bit ASCII characters with the high bit of each character set to zero.

Augmented Backus-Naur Form (ABNF): A modified version of Backus-Naur Form (BNF), commonly used by Internet specifications. ABNF notation balances compactness and simplicity with reasonable representational power. ABNF differs from standard BNF in its definitions and uses of naming rules, repetition, alternatives, order-independence, and value ranges. For more information, see [RFC5234].

authentication: The act of proving an identity to a server while providing key material that binds the identity to subsequent communications.

feature: A package of SharePoint elements that can be activated or deactivated for a specific feature scope.

form: A document with a set of controls into which users can enter information. Controls on a form can be bound to elements in the data source of the form, such as fields and groups. See also bind.

form file: An XML file that contains data that is entered into an InfoPath form by using a web browser or Microsoft InfoPath.

form server: A server that can host XML-based electronic forms and that supports rendering those forms in a web browser.

form template: A file or set of files that defines the data structure, appearance, and behavior of a form.

form template (.xsn) file: A cabinet (.cab) file with an .xsn file name extension that contains the files that comprise a form template.

HTTP method: In an HTTP message, a token that specifies the method to be performed on the resource that is identified by the Request-URI, as described in [RFC2616].

Hypertext Transfer Protocol (HTTP): An application-level protocol for distributed, collaborative, hypermedia information systems (text, graphic images, sound, video, and other multimedia files) on the World Wide Web.

Hypertext Transfer Protocol Secure (HTTPS): An extension of HTTP that securely encrypts and decrypts web page requests. In some older protocols, "Hypertext Transfer Protocol over Secure Sockets Layer" is still used (Secure Sockets Layer has been deprecated). For more information, see [SSL3] and [RFC5246].

message body: The content within an HTTP message, as described in [RFC2616] section 4.3.

query component: A portion of a URL that follows a question mark (?), as described in [RFC3986].

rendering URL: The URL that is used to render an InfoPath form in a web browser if the form cannot be opened by using Microsoft InfoPath.

Request-URI: A URI in an HTTP request message, as described in [RFC2616].

site: A group of related pages and data within a SharePoint site collection. The structure and content of a site is based on a site definition. Also referred to as SharePoint site and web site.

site collection: A set of websites (1) that are in the same content database, have the same owner, and share administration settings. A site collection can be identified by a GUID or the URL of the top-level site for the site collection. Each site collection contains a top-level site, can contain one or more subsites, and can have a shared navigational structure.

Status-Code: A 3-digit integer result code in an HTTP response message, as described in [RFC2616].

Status-Line: The first line of an HTTP response message, as described in [RFC2616].

Unicode: A character encoding standard developed by the Unicode Consortium that represents almost all of the written languages of the world. The Unicode standard [UNICODE5.0.0/2007] provides three forms (UTF-8, UTF-16, and UTF-32) and seven schemes (UTF-8, UTF-16, UTF-16 BE, UTF-16 LE, UTF-32, UTF-32 LE, and UTF-32 BE).

Uniform Resource Identifier (URI): A string that identifies a resource. The URI is an addressing mechanism defined in Internet Engineering Task Force (IETF) Uniform Resource Identifier (URI): Generic Syntax [RFC3986].

Uniform Resource Locator (URL): A string of characters in a standardized format that identifies a document or resource on the World Wide Web. The format is as specified in [RFC1738].

UTF-8: A byte-oriented standard for encoding Unicode characters, defined in the Unicode standard. Unless specified otherwise, this term refers to the UTF-8 encoding form specified in [UNICODE5.0.0/2007] section 3.9.

MAY, SHOULD, MUST, SHOULD NOT, MUST NOT: These terms (in all caps) are used as defined in [RFC2119]. All statements of optional behavior use either MAY, SHOULD, or SHOULD NOT.

1.2  References

Links to a document in the Microsoft Open Specifications library point to the correct section in the most recently published version of the referenced document. However, because individual documents in the library are not updated at the same time, the section numbers in the documents may not match. You can confirm the correct section numbering by checking the Errata.

1.2.1  Normative References

We conduct frequent surveys of the normative references to assure their continued availability. If you have any issue with finding a normative reference, please contact . We will assist you in finding the relevant information.

[RFC1945] Berners-Lee, T., Fielding, R., and Frystyk, H., "Hypertext Transfer Protocol -- HTTP/1.0", RFC 1945, May 1996, http://www.ietf.org/rfc/rfc1945.txt

[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate Requirement Levels", BCP 14, RFC 2119, March 1997, http://www.rfc-editor.org/rfc/rfc2119.txt

[RFC2616] Fielding, R., Gettys, J., Mogul, J., et al., "Hypertext Transfer Protocol -- HTTP/1.1", RFC 2616, June 1999, http://www.rfc-editor.org/rfc/rfc2616.txt

[RFC2818] Rescorla, E., "HTTP Over TLS", RFC 2818, May 2000, http://www.rfc-editor.org/rfc/rfc2818.txt

[RFC3986] Berners-Lee, T., Fielding, R., and Masinter, L., "Uniform Resource Identifier (URI): Generic Syntax", STD 66, RFC 3986, January 2005, http://www.ietf.org/rfc/rfc3986.txt