This repository has been archived by the owner on Jan 21, 2022. It is now read-only.
v0.0.2
Abacus - Change History
The Abacus usage metering and aggregation service.
v0.0.2 - 10/30/2015
Usage submission
- Accept and record duplicate usage docs
- Fix issue with db partitioning in provisioning service
Usage accumulation
- Fix timing and event sequencing issues in tests
App usage metering
- Fix detection of duplicate usage docs with multiple consumers
Misc
- App health checks based on error rates
- Optional registration in Eureka for monitoring with Hystrix
- Support easier app environment configuration with .rc files
Prerequisites
- Node.js 0.12, 4.2
- CouchDB 1.6 compatible database
- Cloud Foundry v210+
v0.0.2-rc.2 - 10/23/2015
Usage submission
- Change consumer field type to a string
- Improve error reporting
- Store provider client id with submitted usage
Usage accumulation
- Bug fixes with usage accumulation and slack windows
- Improve reliability of duplicate usage doc detection
Usage reports
- Fix handling of undefined usage values
App usage metering
- Improvements to make test logic independent of timing
- Throttle usage submission at startup time
Security
- Pass Abacus token instead of client token to resource config service
- Add a test UAA stub service allowing all tests to run with security
- Use more consistent config variable names
Performance improvements
- Faster duplicate usage doc detection
- Reduced number of database writes per usage doc
- Fixed Node.js IO starvation issues under load
Misc
- More flexible database name configuration
- More flexible database partitioning configuration
Prerequisites
- Node.js 0.10, 0.12, 4.2
- CouchDB 1.6 compatible database
- Cloud Foundry v210+
v0.0.2-rc.1 - 10/16/2015
Usage submission
- Simpler and more consistent usage submission API
- Single usage model for runtime and service resources
- Pluggable usage validation
Usage accumulation
- Usage accumulation over month, day, hour, min, sec time windows
- Configurable accumulation functions
- Automatic calculation of time-based usage consumption
- Handling of out of sequence and delayed usage
Usage aggregation
- Usage aggregation over orgs, spaces, resources, consumers and apps
- Configurable aggregation functions
Usage rating
- Rating of aggregated usage
- Configurable pricing and rating functions
Usage reports
- Simpler and more consistent usage reporting API
- Default usage summary reports
- Configurable summary and charge calculation functions
- GraphQL usage query API
Platform integration and onboarding
- Pluggable resource provider and resource configuration onboarding
- Pluggable org collection management
Security
- Authentication using OAuth tokens
- Usage submission authorization using OAuth scopes
- Pluggable usage reporting authorization
App usage metering
- CF app usage bridge to Abacus
Documentation
- Improvements to the API doc
- FAQ with a few initial questions
Misc
- Support for usage region info
- Performance improvements
- DB error handling improvements
- Increased test coverage
- Integration and performance tests
Prerequisites
- Node.js 0.10, 0.12, 4.2
- CouchDB 1.6 compatible database
- Cloud Foundry v210+
v0.0.1 - 07/14/2015
Initial public contribution