Project Properties can be accessed and modified through this API using three services: GET,PUT, and PATCH. These three services allow for the retrieval, complete update, and partial update of Project Properties.
...
If we had a Project in our database with an Id of 11101 and we run a GET request at the following URL: http://host:port/flexdeploy/rest/project/11101
The GET request would return the following JSON Project Property list
Code Block | ||||
---|---|---|---|---|
| ||||
[ { "propertyName": "FD_PARTIAL_FILE_EXCLUDES", "propertyValue": "java", "credentialId": null }, { "propertyName": "FD_PARTIAL_FILE_INCLUDES", "propertyValue": "sql", "credentialId": null }, { "propertyName": "FDJDBC_OTHERPROPERTY_ROOTREPLACEMENT_TARGET_FOLDERDEFAULT", "propertyValue": "/other_root_target_foldertrue", "credentialId": null }, { "propertyName": "FDJDBC_PROPERTYRETRY_REPLACEMENTCOUNT_DEFAULT", "propertyValue": "true"5, "credentialId": null }, { "propertyName": "FDJDBC_RETRYSQL_COUNT_DEFAULTEXTENSIONS", "propertyValue": 5, "credentialId": null }, { "propertyName": "FDJDBC_SQL_EXTENSIONS", "propertyValue": "seq,tbl,idx,typ,"seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", "credentialId": null }, { "propertyName": "FDJDBC_SQL_ROOT_TARGET_FOLDER", "propertyValue": "/sql", "credentialId": null }, { "propertyName": "JDBC_ALTERNATE_SCHEMA_PASS", "propertyValue": "*****", "credentialId": 49384 } ] |
PUT
This PUT service will update the propertyValue of each property in the project associated with the Project id specified in the URL.
Info | ||
---|---|---|
| ||
http://host:port/flexdeploy/rest/v1/project/{projectid}/property |
Request
Attributes | Type | Required | Description |
---|---|---|---|
projectid | URL | Yes | This is the Id of the Project which will have it's Properties updated. |
properties | List<PropertyValuePojo> | Yes | This is the list of properties being set for the project. Attributes for a property object are described below |
PropertyValuePojo
Attributes | Type | Required | Description |
---|---|---|---|
propertyName | String | Yes | This is the key name of the property |
propertyValue | String | No | This is the value that the property with the associated propertyName will be updated to |
credentialId | Long | No | The id of the credential associated to this property. Applicable only for encrypted properties |
Tip |
---|
All unlisted properties for the project will default to null for PUT requests. |
Response Codes
HTTP Code | Description |
---|---|
200 | Project was found and its Properties were updated |
400 | Bad request |
401 | Authentication failure |
403 | Authorization failure (no access to resource) |
404 | Project not found |
500 | Unexpected internal server error |
Example
...
Code Block | ||||
---|---|---|---|---|
| ||||
[ { "propertyName": "FD_PARTIAL_FILE_EXCLUDES", "propertyValue": "java", "credentialId": null }, { "propertyName": "FD_PARTIAL_FILE_INCLUDES", "propertyValue": "", "credentialId": null }, { "propertyName": "FDJDBC_OTHERPROPERTY_ROOTREPLACEMENT_TARGET_FOLDERDEFAULT", "propertyValue": "/other_root_target_foldertrue", "credentialId": null }, { "propertyName": "FDJDBC_PROPERTYRETRY_REPLACEMENTCOUNT_DEFAULT", "propertyValue": "true"5, "credentialId": null }, { "propertyName": "FDJDBC_RETRYSQL_COUNT_DEFAULTEXTENSIONS", "propertyValue": 5, "credentialId": null }, { "propertyName": "FDJDBC_SQL_EXTENSIONS", "propertyValue": "seq,tbl,idx,typ,tps,"seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", "credentialId": null }, { "propertyName": "FDJDBC_SQL_ROOT_TARGET_FOLDER", "propertyValue": "/sql", "credentialId": null }, { "propertyName": "JDBC_ALTERNATE_SCHEMA_PASS", "propertyValue": "*****", "credentialId": 49384 } ] |
...
Code Block | ||||
---|---|---|---|---|
| ||||
[ { "propertyName": "FD_PARTIAL_FILE_EXCLUDES", "propertyValue": "java", "credentialId": null }, { "propertyName": "FD_PARTIAL_FILE_INCLUDES", "propertyValue": "sql", "credentialId": null }, { "propertyName": "FDJDBC_OTHERPROPERTY_ROOTREPLACEMENT_TARGET_FOLDERDEFAULT", "propertyValue": "true", "credentialId": null }, { "propertyName": "FDJDBC_PROPERTYRETRY_REPLACEMENTCOUNT_DEFAULT", "propertyValue": "true"5, "credentialId": null }, { "propertyName": "FDJDBC_RETRY_COUNT_DEFAULT"SQL_EXTENSIONS", "propertyValue": 5"seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", "credentialId": null }, { "propertyName": "FDJDBCJDBC_ALTERNATE_SQLSCHEMA_EXTENSIONSPASS", "propertyValue": "seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", ", "credentialId": null }, { "propertyName": "JDBC_ALTERNATE_SCHEMA_PASS", "propertyValue": "", "credentialId": 71422 } ] |
...
71422
}
] |
The PUT request would then update the Project Properties of the Project with Id 25262 and return the following JSON Project Properties list.
Code Block | ||||
---|---|---|---|---|
| ||||
[ { "propertyName": "FD_PARTIAL_FILE_EXCLUDES", "propertyValue": "java", "credentialId": null }, { "propertyName": "FD_PARTIAL_FILE_INCLUDES", "propertyValue": "sql", "credentialId": null }, { "propertyName": "FDJDBC_OTHERPROPERTY_ROOTREPLACEMENT_TARGET_FOLDERDEFAULT", "propertyValue": null"true", "credentialId": null }, { "propertyName": "FDJDBC_PROPERTYRETRY_REPLACEMENTCOUNT_DEFAULT", "propertyValue": "true"5, "credentialId": null }, { "propertyName": "FDJDBC_RETRYSQL_COUNT_DEFAULTEXTENSIONS", "propertyValue": 5"seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", "credentialId": null }, { "propertyName": "FDJDBC_SQL_EXTENSIONSROOT_TARGET_FOLDER", "propertyValue": "seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", "null, "credentialId": null }, { "propertyName": "FDJDBCJDBC_SQLALTERNATE_ROOTSCHEMA_TARGET_FOLDERPASS", " "propertyValue": null, "credentialId": null }, { "propertyName": "JDBC_ALTERNATE_SCHEMA_PASS", "propertyValue": "*****", "credentialId": 71422 } ] |
PATCH
This PATCH service will update an existing Project's Properties with the information passed through a JSON object. If a property is not listed it will not be updated in the Project.
Info | ||
---|---|---|
| ||
http://host:port/flexdeploy/rest/v1/project/{projectid}/property |
Request
Attributes | Type | Required | Description |
---|---|---|---|
projectId | URL | Yes | This is the Id of the Project which will have it's Properties updated. |
properties | List<PropertyValuePojo> | Yes | This is the list of properties being set for the project. Attributes for a property object are described below |
PropertyValuePojo
Attributes | Type | Required | Description |
---|---|---|---|
propertyName | String | Yes | This is the key name of the property |
propertyValue | String | No | This is the value that the property with the associated propertyName will be updated to |
credentialId | Long | No | The id of the credential associated to this property. Applicable only for encrypted properties |
Include Page | ||||
---|---|---|---|---|
|
Response Codes
HTTP Code | Description |
---|---|
200 | Project was found and its Properties were updated |
400 | Bad request |
401 | Authentication failure |
403 | Authorization failure (no access to resource) |
404 | Project not found |
500 | Unexpected internal server error |
Example
If we had a Project in our database with an Id of 12723 and had the following attributes
Code Block | ||||
---|---|---|---|---|
| ||||
[ { "propertyName": "FD_PARTIAL_FILE_EXCLUDES", "propertyValue": "java", "credentialId": null }, { "propertyName": "FD_PARTIAL_FILE_INCLUDES", "propertyValue": "sql", "credentialId": null }, { "propertyName": "FDJDBC_OTHERPROPERTY_ROOT_TARGET_FOLDER"REPLACEMENT_DEFAULT", "propertyValue": null"true", "credentialId": null }, { "propertyName": "FDJDBC_PROPERTYRETRY_REPLACEMENTCOUNT_DEFAULT", "propertyValue": "true"5, "credentialId": null }, { "propertyName": "FDJDBC_RETRYSQL_COUNT_DEFAULTEXTENSIONS", "propertyValue": 5"seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", "credentialId": null }, { "propertyName": "FDJDBC_SQL_ROOT_TARGET_EXTENSIONSFOLDER", "propertyValue": "seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc",null, "credentialId": null }, { "propertyName": "FDJDBCJDBC_SQLALTERNATE_ROOTSCHEMA_TARGET_FOLDERPASS", "propertyValue": null, "credentialId": null }, { "propertyName": "JDBC_ALTERNATE_SCHEMA_PASS", "propertyValue": " "propertyValue": "*****", "credentialId": 71422 } ] |
When we run a PATCH request at the following URL: http://host:port/flexdeploy/rest/project/12723
And the PATCH request receives the following JSON Project Properties object,
Code Block | ||||
---|---|---|---|---|
| ||||
[ { "propertyName": "FD_PARTIAL_FILE_EXCLUDES", "propertyValue": "java", "credentialId": null }, { "propertyName": "FDJDBC_SQL_ROOT_TARGET_FOLDER", "propertyValue": "/targetfolder", "credentialId": null }, { "propertyName": "JDBCFD_ALTERNATEPARTIAL_SCHEMAFILE_PASSEXCLUDES", "propertyValue": "java", "credentialId": 80855null } ] |
The PATCH request would then update the specified Project's Properties and return the following JSON object
Code Block | ||||
---|---|---|---|---|
| ||||
[ }, { "propertyName": "FDFDJDBC_SQL_PARTIALROOT_FILETARGET_EXCLUDESFOLDER", "propertyValue": "java/targetfolder", "credentialId": null }, { "propertyName": "JDBC_ALTERNATE_SCHEMA_PASS", "propertyValue": "", "credentialId": null80855 }, } ] |
The PATCH request would then update the specified Project's Properties and return the following JSON object
Code Block | ||||
---|---|---|---|---|
| ||||
[ { "propertyName": "FD_PARTIAL_FILE_INCLUDESEXCLUDES", "propertyValue": "sqljava", "credentialId": null }, { "propertyName": "FDJDBCFD_OTHERPARTIAL_ROOTFILE_TARGET_FOLDERINCLUDES", "propertyValue": null"sql", "credentialId": null }, { "propertyName": "FDJDBC_PROPERTY_REPLACEMENT_DEFAULT", "propertyValue": "true", "credentialId": null }, { "propertyName": "FDJDBC_RETRY_COUNT_DEFAULT", "propertyValue": 5, "credentialId": null }, { "propertyName": "FDJDBC_SQL_EXTENSIONS", "propertyValue": "seq,tbl,idx,typ,tps,tpb,sql,pkh,plb,pks,pkb,pls,pck,fnc,trg,spc,bdy,prc", "credentialId": null }, { "propertyName": "FDJDBC_SQL_ROOT_TARGET_FOLDER", "propertyValue": "/targetfolder", "credentialId": null }, { "propertyName": "JDBC_ALTERNATE_SCHEMA_PASS", "propertyValue": "*****", "credentialId": 80855 } ] |