The getDescendants action returns one or more person profiles like those from getProfile. From a starting profile, specified by a "key" that is a WikiTree ID or User ID, the children are followed to a requested depth.
Param | Value |
---|---|
action | getProfile |
key | WikiTree ID or Id |
depth | The number of generations forward to follow the child ids |
fields | Optional comma-separated list of fields to return for each profile |
bioFormat | Optional: "wiki", "html", or "both" |
resolveRedirect | Optional. If 1, then requested profiles that are redirections are followed to the final profile |
The "key" parameter is used to indicate which profile to return. This can be either a "WikiTree ID" or a "User ID". The WikiTree ID is the name used after "/wiki" in the URL of the Person page. For example, for Person Profile Pages like https://www.wikitree.com/wiki/Shoshone-1, the WikiTree ID is "Shonshone-1".
Note that the Mother and Father fields in a Person profile are (User) IDs. Depending on what data you retrieve for Mother/Father it may be easier to use getPerson to follow those than getProfile (which requires a Page ID or WikiTree ID)
The depth is how many steps/generations to recursively follow the children to gather descendants. A depth of 1 returns the children, 2 returns children & grandchildren, etc.
The "fields" parameter is optional. If left out, a default set of fields is returned. For Person profile pages, the default is all fields other than the biography, children and spouses. For Free-Space profile pages, the default is to return all fields.
You can specify which fields to return by setting the "fields" parameter to a comma-separated list of those you want. You can also use "*" to indicate "all fields".
If you request the "bio" field (the text biography for a Person profile), the default is to return the content as it's stored, with wiki markup. You can instead request that this markup be rendered into HTML (as it would appear on the profile's web page) by specifying a "bioFormat" of "html". If you use a bioFormat value of "both", then both the original wiki text and the rendered HTML will be returned.
Generally if you start at a valid profile and follow use the ids associated with relationships (mother, father) you should get a valid/complete profile in return. However, in some circumstances you may end up requesting a profile that has been merged away into another profile, or otherwise is redirected. If you set resolveRedirect=1 in your POST to the API, then any profiles that would be returned that are redirections will be followed to their end point, and that final profile will be returned.
Field | Description |
---|---|
descendants | Array of Person profile data (with fields specified by the "fields" parameter). |
See getProfile.md for the fields in each Person profile.
curl 'https://api.wikitree.com/api.php?action=getDescendants&key=Adams-35&depth=1&fields=Id,Name,Mother,Father'
[
{
"user_name": "Adams-35",
"descendants": [
{
"Id": 3636,
"Name": "Adams-35",
"Father": 3640,
"Mother": 3641
},
{
"Id": 3586,
"Name": "Adams-10",
"Father": 3636,
"Mother": 3637
},
{
"Id": 3638,
"Name": "Adams-36",
"Father": 3636,
"Mother": 3637
},
{
"Id": 3639,
"Name": "Adams-37",
"Father": 3636,
"Mother": 3637
}
],
"status": 0
}
]