Windchill REST Services > Windchill REST Services Domain Capabilities > Examples for Basic REST Operations > Examples for the PTC BOM Transformation Domain > Checking in/Checking Out/Revising/Changing the State of Department Data Objects
  
Checking in/Checking Out/Revising/Changing the State of Department Data Objects
These examples show how to check in, check out, revise, and perform state change operations on Department Data objects:
Example: Checking out a Department Data Object
The following example shows how you can check out a department data object using the following POST URI with the request body. You must specify the checkout note in the request body.
Request Headers
Content-Type: application/json
CSRF_NONCE: <Use the value from Fetch NONCE example>
URI
POST Windchill/servlet/odata/BomTransformation/DepartmentDatas('OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:182859')/PTC.BomTransformation.CheckOut
Request Body
{
"CheckOutNote": "Checked out"
}
Example: Undo Checkout of a Department Data Object
This example shows you how to undo check out of a Department Data object. Use the POST URI.
URI
POST Windchill/servlet/odata/BomTransformation/DepartmentDatas('OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:182859')/PTC.MfgProcMgmt.UndoCheckOut
Request Headers
Content-Type: application/json
CSRF_NONCE: <Use the value from Fetch NONCE example>
Example: Checking in a Department Data Object
The following example shows how you can check in a department data object using the following POST URI with the request body.
Request Headers
Content-Type: application/json
CSRF_NONCE: <Use the value from Fetch NONCE example>
URI
POST Windchill/servlet/odata/BomTransformation/DepartmentDatas('OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:182858')/PTC.BomTransformation.CheckIn
Request Body
{
"KeepCheckedOut": "false",
"CheckInNote": "check in",
"CheckOutNote": ""
}
Example: Changing the State of a Department Data Object
The following example shows how you can change the (life cycle) state of a specific department data object with multiple versions. In this request, you can specify only the latest iteration of a particular revision of the object. For example, consider an department data object with three iterations of its Revision A – A.1, A.2 and A.3. The request changes the state only for A.3. Use the following POST URI with the request body. In this example the state is specified in the request body.
Request Headers
Content-Type: application/json
CSRF_NONCE: <Use the value from Fetch NONCE example>
URI
POST Windchill/servlet/odata/BomTransformation/DepartmentDatas('OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:182858')/PTC.BomTransformation.SetState
Request Body
{
"State": {
"Value": "INWORK",
"DISPLAY": "In Work"
}
}
Example: Changing the State of Multiple Department Data Objects
The following example shows how you can change the (life cycle) state of two department data objects with multiple versions. For example, if one department data object has versions A.1 and A.2 and the other department data object has versions C.1, C.2, and C.3, then the request changes the state only for A.2 and C.3, respectively. Use the following POST URI with the request body.
Request Headers
Content-Type: application/json
CSRF_NONCE: <Use the value from Fetch NONCE example>
URI
POST Windchill/servlet/odata/BomTransformation/SetStateDepartmentDatas
Request Body
{
"DepartmentDatas": [
{
"ID": "OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:182834"
},
{
"ID": "OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:182345"
}
],
"State": {
"Value": "CANCELLED",
"Display": "Cancelled"
}
}
Revising a Department Data Object
This example shows you how you can revise a specific department data object to the desired Revision directly. For example, if the existing Revision of the object is A, then the request revises the specified department data object to Revision J, directly. In this example, the specified department data object is revised to Revision J. Use the following POST URI with the request body.
URI
POST /Windchill/servlet/odata/BomTransformation/DepartmentDatas('OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:182859')/PTC.BomTransformation.Revise
Request Headers
Content-Type: application/json
CSRF_NONCE: <Use the value from Fetch NONCE example>
Request Body
{
"VersionId": "J"
}
Example: Revising Multiple Department Data Objects
This example shows you how to increment the revision of each of the two department data objects, by one. For example, if you specify the OID of one department data object of Revision M and the OID of other department data object of Revision C in the request body, then the request revises the objects to Revision N and Revision D, respectively. Use the following POST URI with the request body.
* 
If you want to revise each of the two objects simultaneously from Revision A to J, then you must send the request nine times by replacing the older Revision OIDs of the objects with their newer Revision OIDs in each subsequent request. For example, if you send the first request that revises the objects from Revision A to B, then in the second request, you must specify the OIDs of Revision B in the request body to revise the objects from Revision B to C. Similarly, in the third request, you must specify the OIDs of Revision C to revise the objects from Revision C to D, and so on.
Request Headers
Content-Type: application/json
CSRF_NONCE: <Use the value from Fetch NONCE example>
URI
POST Windchill/servlet/odata/BomTransformation/ReviseDepartmentDatas
Request Body
{
"DepartmentDatas": [
{
"ID": "OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:183265"
},
{
"ID": "OR:com.ptc.windchill.enterprise.data.PlantFunctionalData:183323"
}
]
}