All notable changes to this project will be documented in this file.
The format is based on Keep a Changelog and this project adheres to Semantic Versioning.
- Migrated SDK to new project
- Migrated SDK to .Net 6.0
- Add Github Actions pipeline
- add support for column formulas
- Webhooks for columns support
- disable Newtonsoft default configuration of deserializing strings that "look like" dates into C# DateTime objects, see README for details on how to opt-out of this change if required.
- type and object definitions to support multi-picklist columns
- dashboard widget model to support widgets that are in an error state
- additions to CellDataItem widget contents to support METRIC widgets containing sheet summary fields
- support for sheet profiles
- include format and objectValue in the includes for GetCellHistory (Issue #109)
- continue to support level 0 widget types
- CARD_DONE tag to column tags enumeration
Description
property to Column model- ListUsers accepts an
includes
parameter - the only currently accepted argument value isLAST_LOGIN
- 'DateFormat' property to FormatTables model
SOURCE
as include flag to GetSightSOURCE
andSCOPE
as include flags to GetReport
- Significant overhaul to Sights (AKA dashboards) - added separate content models for each widget type
- Started a revamp of ITs to provide better test coverage
- rules, ruleRecipients and shares to inclusions
- exclusion to CopySheet method
- Support for .NET Standard 2.0. Nuget.org package contains assemblies for both .NET Framework 4.5.2 and .NET Standard 2.0.
- Added missing public class declarations for some of the ObjectValue types
- Implement Event Reporting
- Added group inclusion to GetCurrentUser
- Added BASE URI definition for Smartsheetgov
- Fixed GetRow to process include and exclude parameters
- Added opt-in for TLS 1.2. TLS 1.0 will be disabled soon for Smartsheet API.
- WebContent as a valid widget type for Sights
- Missing Workspace item to Sheet model
- Support for Multi-Assign feature
- deleteAllForApiClient parameter to OAuth revoke
- ProjectSettings nonWorkingDays should be a string (modified from DateTime)
- Automation rules
- Cross sheet references
- Added import API endpoints to allow SDK users to import Sheets from XLSX and CSV files
- Data validation (more information about cell value parsing including validation can be found here)
- Passthrough mechanism to pass raw JSON requests through to the API (documented in README/Advanced Topics)
- Sheet filter implementation
- Row sort feature
- User profile properties (including profileImage) to UserModel
- Scope, location, and favoriteFlag inclusion to search
- getSheet() ifVersionAfter parameter
- Expose Change-Agent, Assumed-User, and User-Agent on Smartsheet client
- Bulk access to sheet version through sheetVersion inclusion
- Missing report and sheet publish flags
- Missing title widget for Sights
- Deserialization of error detail
- Cleaned up logging for binary HTTP entities
- Methods to clear hyperlink and cellLink (examples can be found in the
RowTests.cs
mock tests)
- Implementation of objectValue to better support PredecessorList and objectValue primitives (examples of how to set and clear Predecessor list can be found in the
RowTests.cs
mock tests) - HttpClient interface to allow SDK users to inject HTTP headers or implement an HTTP proxy by extending DefaultHttpClient (a proxy sample is provided in the Advanced Topics section of the README)
- Removed outdated Link model and replaced all references with current Hyperlink model
- Removed ShouldRetry and CalcBackoff interfaces and replaced with HttpClient interface methods. You can now customize shouldRetry or calcBackoff using the same method as proxy or request header injection (i.e., extend DefaultHttpClient).
- Several deserialization issues with Sights
- Changed Duration values to floats to be consistent with the API
- Don't modify comments array when setComment is called for outbound comment
- Don't attempt to rety non-JSON responses
- Documented in Github releases page