## 57.3. Foreign Data Wrapper Helper Functions Several helper functions are exported from the core server so that authors of foreign data wrappers can get easy access to attributes of FDW-related objects, such as FDW options. To use any of these functions, you need to include the header file `foreign/foreign.h` in your source file. That header also defines the struct types that are returned by these functions. ``` ForeignDataWrapper * GetForeignDataWrapperExtended(Oid fdwid, bits16 flags); ``` This function returns a `ForeignDataWrapper` object for the foreign-data wrapper with the given OID. A `ForeignDataWrapper` object contains properties of the FDW (see `foreign/foreign.h` for details). `flags` is a bitwise-or'd bit mask indicating an extra set of options. It can take the value `FDW_MISSING_OK`, in which case a `NULL` result is returned to the caller instead of an error for an undefined object. ``` ForeignDataWrapper * GetForeignDataWrapper(Oid fdwid); ``` This function returns a `ForeignDataWrapper` object for the foreign-data wrapper with the given OID. A `ForeignDataWrapper` object contains properties of the FDW (see `foreign/foreign.h` for details). ``` ForeignServer * GetForeignServerExtended(Oid serverid, bits16 flags); ``` This function returns a `ForeignServer` object for the foreign server with the given OID. A `ForeignServer` object contains properties of the server (see `foreign/foreign.h` for details). `flags` is a bitwise-or'd bit mask indicating an extra set of options. It can take the value `FSV_MISSING_OK`, in which case a `NULL` result is returned to the caller instead of an error for an undefined object. ``` ForeignServer * GetForeignServer(Oid serverid); ``` This function returns a `ForeignServer` object for the foreign server with the given OID. A `ForeignServer` object contains properties of the server (see `foreign/foreign.h` for details). ``` UserMapping * GetUserMapping(Oid userid, Oid serverid); ``` This function returns a `UserMapping` object for the user mapping of the given role on the given server. (If there is no mapping for the specific user, it will return the mapping for `PUBLIC`, or throw error if there is none.) A `UserMapping` object contains properties of the user mapping (see `foreign/foreign.h` for details). ``` ForeignTable * GetForeignTable(Oid relid); ``` This function returns a `ForeignTable` object for the foreign table with the given OID. A `ForeignTable` object contains properties of the foreign table (see `foreign/foreign.h` for details). ``` List * GetForeignColumnOptions(Oid relid, AttrNumber attnum); ``` This function returns the per-column FDW options for the column with the given foreign table OID and attribute number, in the form of a list of `DefElem`. NIL is returned if the column has no options. Some object types have name-based lookup functions in addition to the OID-based ones: ``` ForeignDataWrapper * GetForeignDataWrapperByName(const char *name, bool missing_ok); ``` This function returns a `ForeignDataWrapper` object for the foreign-data wrapper with the given name. If the wrapper is not found, return NULL if missing\_ok is true, otherwise raise an error. ``` ForeignServer * GetForeignServerByName(const char *name, bool missing_ok); ``` This function returns a `ForeignServer` object for the foreign server with the given name. If the server is not found, return NULL if missing\_ok is true, otherwise raise an error.