You are viewing an old version of this page. View the current version.
        
        
            Compare with Current
                        View Page History
        
        
                            « Previous
            
            
                                     Version 15
                            
                            Next »
            
        
     
            
                                            
        
                           
        Structure Service
Structure Service
A hierarchical tree structure(eg: cost structure) could be added and later retrieved from a project/object using the Structure service
 
Create a new structure in a project
    		
        Resource: projects/<project_id>/structures 
URL: https://api-stage.bimplus.net/v2/<team_slug>/projects/<project_id>/structures
Example:https://api-stage.bimplus.net/v2/bimplus/projects/622272da-f1ff-45ab-a3f0-c8f1255c80e8/structures
JSON Structure: 
 
  
   
    | Name | Mandatory / Optional | Type | Description | 
   
    | parentId | mandatory | string(guid) | Parent node id of the structure (for the first structure, projectId is the parentId) | 
   
    | name | mandatory | string | Name of the structure | 
   
    | description | optional | string | Description of the structure | 
   
    | type | optional | string | Type of the structure (eg: costStructure, specificationStructure) | 
   
    | nr | will be ignored | integer | The index of the structure | 
   
    | color | optional | integer | Color of the structure | 
   
    | id | will be ignored | string(guid) | Unique guid of the structure | 
   
    | startDate | optional | string (date) | Start date ( depends on type of structure ) | 
   
    | endDate | optional | string (date) | End date ( depends on type of structure ) | 
  
 
 
  POST
 Create a new structure(eg: cost structure, specification structure) under a project
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
 
 
 
  {
    "name": "TestStructure",
    "description": "FullLifeCycleTest",
    "type": "CostStructure"
}
  
 
 
 
  {
    "parentId": "622272da-f1ff-45ab-a3f0-c8f1255c80e8",
    "name": "TestStructure",
    "description": "FullLifeCycleTest",
    "type": "CostStructure",
    "nr": 1,
    "color": 0,
    "id": "179439d6-df16-41cc-bd2c-74d05b7995d5"
}
  
    
 
Get the structure details
    		
         GET
 Get details of a specified structure.
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
 
 
 
  {
    "name": "TestStructure",
    "description": "FullLifeCycleTest",
    "type": "CostStructure",
    "nr": 1,
    "color": 0,
    "id": "179439d6-df16-41cc-bd2c-74d05b7995d5"
}
  
    
 
Create a sub-node under the structure
    		
        Resource: structures/<structure_id> 
URL: https://api-stage.bimplus.net/v2/<team_slug>/structures/<structure_id> 
Example:https://api-stage.bimplus.net/v2/bimplus/structures/179439d6-df16-41cc-bd2c-74d05b7995d5
JSON Structure: 
 
  
   
    | Name | Mandatory / Optional | Type | Description | 
   
    | parentId | mandatory | string(guid) | Parent node id of the structure (the id specified in the resource url) | 
   
    | name | mandatory | string | Name of the structure | 
   
    | description | optional | string | Description of the structure | 
   
    | type | optional | string | Type of the structure (eg: costStructure, specificationStructure) | 
   
    | nr | will be ignored | integer | The index of the structure | 
   
    | color | optional | integer | Color of the structure | 
   
    | id | will be ignored | string(guid) | Unique guid of the structure | 
  
 
 
  POST
 Create a sub-node under a particular structure
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
 
 
 
  {
    "parentId": "179439d6-df16-41cc-bd2c-74d05b7995d5",
    "name": "Node 1",
    "type": "TopologyStructure",
    "nr": 1,
    "color": 0,
    "id": "adf506ae-3628-4501-9af1-22bcf27e4ab4"
}
  
    
 
Get the structure topology
    		
         GET
 Get details of a specified structure.
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
 
 
 
  {
    "parent": null,
    "name": "TestStructure",
    "type": "Structure",
    "children": [
        {
            "parent": "179439d6-df16-41cc-bd2c-74d05b7995d5",
            "name": "Node 1",
            "type": "Structure",
            "children": [],
            "id": "adf506ae-3628-4501-9af1-22bcf27e4ab4"
        }
    ],
    "id": "179439d6-df16-41cc-bd2c-74d05b7995d5"
}
  
    
 
Assign an object to the latest/last structure node
    		
        Resource: structures/<structure_id>/assign/<object_id> 
URL: https://api-stage.bimplus.net/v2/<team_slug>/structures/<structure_id>/assign/<object_id> 
Example:https://api-stage.bimplus.net/v2/bimplus/structures/179439d6-df16-41cc-bd2c-74d05b7995d5/assign/df4a81d6-42fb-4187-bbce-82a2fc093b2f
JSON Structure: 
 
  
   
    | Name | Mandatory / Optional | Type | Description | 
   
    | color | optional | string(guid) | The id of the last node to which an object will be assigned | 
   
    | objectId | will be ignored | string(guid) | The id of the object to whom a structure will be assigned | 
   
    | name | mandatory | string | The name of the structure-object connection | 
   
    | nr | will be ignored | integer | The index of the structure-object connection | 
   
    | id | will be ignored | string(guid) | Unique guid of the structure-object connection | 
   
    | variantType | optional | string(guid) | Variant Type Id to whom the object will be assigned | 
   
    | IfcGloballyUniqueId | optional | string | IFC globally unique ID | 
  
 
 
  POST
 Assign an object to the latest/last structure node
 
Note :
Works with two different inputs
 - Object ID is present in the url - this object ID is used
- Object ID is not present, but content json contains IfcGloballyUniqueId - a corresponding Bimplus object is found and used as input object ID
 - if this IFC id is not found -> return "404 Not Found", if present multiple times -> return "409 Conflict"
 
 
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
 
 
 
  {
  "name": "WallConnection",
  "variantType" : "35b986c2-e9cd-482e-9281-6000671a49f0"
}
  
 
 
 
  {
    "structureId": "adf506ae-3628-4501-9af1-22bcf27e4ab4",
    "objectId": "df4a81d6-42fb-4187-bbce-82a2fc093b2f",
    "name": "WallConnection",
    "nr": 1,
    "id": "35b986c2-e9cd-482e-9281-6000671a49f0"
}
  
    
 
Assign additional objects to the latest structureElement node
    		
        {
    "structureId": "adf506ae-3628-4501-9af1-22bcf27e4ab4",
    "objectId": "df4a81d6-42fb-4187-bbce-82a2fc093b2f",
    "name": "WallConnection",
    "nr": 1,
    "id": "35b986c2-e9cd-482e-9281-6000671a49f0",
    "variantType" : "35b986c2-e9cd-482e-9281-6000671a49f0"
}
  
  
Remove assigned object from the latest structureElement node
Copy Structure
    		
        Resource: structures/<structure_id>/copy
URL: https://api-stage.bimplus.net/v2/<team_slug>/structures/<structure_id>/copy
Example: https://api-stage.bimplus.net/v2/bimplus/structures/35b986c2-e9cd-482e-9281-6000671a49f0/copy
 
JSON Structure: 
 
 
  
   
    |  |  |  |  | 
  
  
   
    |   |   |   |   | 
   
    | name | mandatory | string | Name of the new structure | 
   
    |   |   |   |   | 
   
    | type | optional | string | Type of the new structure (eg: costStructure, specificationStructure) | 
   
    | nr | will be ignored | integer | The index of the new structure | 
   
    | color | optional | integer | Color of the new structure | 
   
    | id | will be ignored | string(guid) | Unique guid of the structure | 
   
    | startDate | optional | string (date) | Start date ( depends on type of structure ) | 
   
    | endDate | optional | string (date) | End date ( depends on type of structure ) | 
  
 
 
 
  
  
Update the structure
    		
        Resource: structures/<structure_id>
URL: https://api-stage.bimplus.net/v2/<team_slug>/structures/<structure_id> 
Example:https://api-stage.bimplus.net/v2/bimplus/structures/179439d6-df16-41cc-bd2c-74d05b7995d5
JSON Structure: 
 
  
   
    | Name | Mandatory / Optional | Type | Description | 
   
    | parentId | optional | string(guid) | Parent node id of the structure (for the first structure, projectId is the parentId) | 
   
    | name | optional | string | Name of the structure | 
   
    | description | optional | string | Description of the structure | 
   
    | type | optional | string | Type of the structure (eg: costStructure, specificationStructure) | 
   
    | nr | optional | integer | The index of the structure | 
   
    | color | optional | integer | Color of the structure | 
   
    | id | will be ignored | string(guid) | Unique guid of the structure | 
  
 
   PUT
 Update the specified structure
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
 
 
 
  {
  "name": "Updated Structure"
}
  
 
 
 
  {
    "parentId": "622272da-f1ff-45ab-a3f0-c8f1255c80e8",
    "name": "Updated Structure",
    "description": "FullLifeCycleTest",
    "type": "CostStructure",
    "nr": 1,
    "color": 0,
    "id": "179439d6-df16-41cc-bd2c-74d05b7995d5"
}
  
    
 
Delete the structure
    		
         DELETE
 Deletes a specified structure.
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
   
  
 
Resource: structures/<structure_id>
URL: https://api-stage.bimplus.net/v2/<team_slug>/structures/<structure_id> 
Example:https://api-stage.bimplus.net/v2/bimplus/structures/179439d6-df16-41cc-bd2c-74d05b7995d5
JSON Structure: 
 
  
   
    | Name | Mandatory / Optional | Type | Description | 
   
    | parentId | optional | string(guid) | Parent node id of the structure (for the first structure, projectId is the parentId) | 
   
    | name | optional | string | Name of the structure | 
   
    | description | optional | string | Description of the structure | 
   
    | type | optional | string | Type of the structure (eg: costStructure, specificationStructure) | 
   
    | nr | optional | integer | The index of the structure | 
   
    | color | optional | integer | Color of the structure | 
   
    | id | will be ignored | string(guid) | Unique guid of the structure | 
  
 
  
Create a new variant in a project
    		
         POST
 Create a new variant of defined structure(eg: cost structure, specification structure) under a project
 
 
  Authorization: BimPlus 9c1874a62c974dcfa75e0132c423a088
Content-Type: application/json
  
 
 
 
  {
    "name": "TestVariant",
    "description": "Description of the Test variant"
}
  
 
 
 
  {
  "name": "TestVariant",
  "description": "Description of the Test variant",
  "id": "733e429a-e232-4e5d-a41e-9bd50aa9763c"
}