Documentation ¶
Overview ¶
Package chartmogul is a simple Go API library for Chartmogul public API.
HTTP 2 ¶
ChartMogul's current stable version of nginx is incompatible with HTTP 2 implementation of Go. For this reason the application must run with the following (or otherwise prohibit HTTP 2):
export GODEBUG=http2client=0
Uses the library gorequest, which allows simple struct->query, body->struct, struct->body.
Index ¶
- Constants
- func SetURL(specialURL string)
- func Setup(timeoutConf time.Duration)
- type API
- func (api API) AddCustomAttributesToCustomer(customerUUID string, customAttributes []*CustomAttribute) (*CustomAttributes, error)
- func (api API) AddCustomAttributesWithEmail(email string, customAttributes []*CustomAttribute) (*Customers, error)
- func (api API) AddTagsToCustomer(customerUUID string, tags []string) (*TagsResult, error)
- func (api API) AddTagsToCustomersWithEmail(email string, tags []string) (*Customers, error)
- func (api API) CancelSubscription(subscriptionUUID string, cancelSubscriptionParams *CancelSubscriptionParams) (*Subscription, error)
- func (api API) ConnectSubscriptions(customerUUID string, subscriptions []Subscription) error
- func (api API) CreateCustomer(newCustomer *NewCustomer) (*Customer, error)
- func (api API) CreateDataSource(name string) (*DataSource, error)
- func (api API) CreateDataSourceWithSystem(dataSource *DataSource) (*DataSource, error)
- func (api API) CreateInvoices(invoices []*Invoice, customerUUID string) (*Invoices, error)
- func (api API) CreatePlan(plan *Plan) (result *Plan, err error)
- func (api API) CreatePlanGroup(planGroup *PlanGroup) (result *PlanGroup, err error)
- func (api API) CreateTransaction(transaction *Transaction, invoiceUUID string) (*Transaction, error)
- func (api API) DeleteCustomer(customerUUID string) error
- func (api API) DeleteCustomerInvoices(dataSourceUUID, customerUUID string) error
- func (api API) DeleteCustomerInvoicesV2(dataSourceUUID, customerUUID string, ...) error
- func (api API) DeleteDataSource(uuid string) error
- func (api API) DeleteInvoice(invoiceUUID string) error
- func (api API) DeletePlan(planUUID string) error
- func (api API) DeletePlanGroup(planGroupUUID string) error
- func (api API) EmptyDataSource(dataSourceUUID string) error
- func (api API) ListAllInvoices(listAllInvoicesParams *ListAllInvoicesParams) (*Invoices, error)
- func (api API) ListCustomers(listCustomersParams *ListCustomersParams) (*Customers, error)
- func (api API) ListDataSources() (*DataSources, error)
- func (api API) ListDataSourcesWithFilters(listDataSourcesParams *ListDataSourcesParams) (*DataSources, error)
- func (api API) ListInvoices(cursor *Cursor, customerUUID string) (*Invoices, error)
- func (api API) ListPlanGroupPlans(cursor *Cursor, planGroupUUID string) (*PlanGroupPlans, error)
- func (api API) ListPlanGroups(cursor *Cursor) (*PlanGroups, error)
- func (api API) ListPlans(listPlansParams *ListPlansParams) (*Plans, error)
- func (api API) ListSubscriptions(cursor *Cursor, customerUUID string) (*Subscriptions, error)
- func (api API) MergeCustomers(mergeCustomersParams *MergeCustomersParams) error
- func (api API) MetricsCreateActivitiesExport(CreateMetricsActivitiesExportParam *CreateMetricsActivitiesExportParam) (*MetricsActivitiesExport, error)
- func (api API) MetricsListActivities(cursor *Cursor, customerUUID string) (*MetricsActivities, error)
- func (api API) MetricsListSubscriptions(cursor *Cursor, customerUUID string) (*MetricsSubscriptions, error)
- func (api API) MetricsRetrieveARPA(metricsFilter *MetricsFilter) (*ARPAResult, error)
- func (api API) MetricsRetrieveARR(metricsFilter *MetricsFilter) (*ARRResult, error)
- func (api API) MetricsRetrieveASP(metricsFilter *MetricsFilter) (*ASPResult, error)
- func (api API) MetricsRetrieveActivitiesExport(activitiesExportUUID string) (*MetricsActivitiesExport, error)
- func (api API) MetricsRetrieveAll(metricsFilter *MetricsFilter) (*MetricsResult, error)
- func (api API) MetricsRetrieveCustomerChurnRate(metricsFilter *MetricsFilter) (*CustomerChurnRateResult, error)
- func (api API) MetricsRetrieveCustomerCount(metricsFilter *MetricsFilter) (*CustomerCountResult, error)
- func (api API) MetricsRetrieveLTV(metricsFilter *MetricsFilter) (*LTVResult, error)
- func (api API) MetricsRetrieveMRR(metricsFilter *MetricsFilter) (*MRRResult, error)
- func (api API) MetricsRetrieveMRRChurnRate(metricsFilter *MetricsFilter) (*MRRChurnRateResult, error)
- func (api API) Ping() (bool, error)
- func (api API) PurgeDataSource(dataSourceUUID string) error
- func (api API) RemoveCustomAttributes(customerUUID string, customAttributes []string) (*CustomAttributes, error)
- func (api API) RemoveTagsFromCustomer(customerUUID string, tags []string) (*TagsResult, error)
- func (api API) RetrieveAccount() (*Account, error)
- func (api API) RetrieveCustomer(customerUUID string) (*Customer, error)
- func (api API) RetrieveCustomersAttributes(customerUUID string) (*Attributes, error)
- func (api API) RetrieveDataSource(dataSourceUUID string) (*DataSource, error)
- func (api API) RetrieveInvoice(invoiceUUID string) (*Invoice, error)
- func (api API) RetrievePlan(planUUID string) (*Plan, error)
- func (api API) RetrievePlanGroup(planGroupUUID string) (*PlanGroup, error)
- func (api API) SearchCustomers(searchCustomersParams *SearchCustomersParams) (*Customers, error)
- func (api *API) SetClient(newClient *http.Client)
- func (api API) UpdateCustomAttributesOfCustomer(customerUUID string, customAttributes map[string]interface{}) (*CustomAttributes, error)
- func (api API) UpdateCustomer(customer *Customer, customerUUID string) (*Customer, error)
- func (api API) UpdateCustomerV2(input *UpdateCustomer, customerUUID string) (*Customer, error)
- func (api API) UpdatePlan(plan *Plan, planUUID string) (*Plan, error)
- func (api API) UpdatePlanGroup(planGroup *PlanGroup, planGroupUUID string) (*PlanGroup, error)
- type ARPAMetrics
- type ARPAResult
- type ARRMetrics
- type ARRResult
- type ASPMetrics
- type ASPResult
- type Account
- type Address
- type AllMetrics
- type AttributeWithSource
- type Attributes
- type CancelSubscriptionParams
- type CreateMetricsActivitiesExportParam
- type Cursor
- type CustID
- type CustomAttribute
- type CustomAttributes
- type Customer
- type CustomerChurnRateMetrics
- type CustomerChurnRateResult
- type CustomerCountMetrics
- type CustomerCountResult
- type Customers
- type DataSource
- type DataSources
- type DeleteCustomerInvoicesParams
- type Errors
- type HTTPError
- type IApi
- type Invoice
- type Invoices
- type LTVMetrics
- type LTVResult
- type LineItem
- type ListAllInvoicesParams
- type ListCustomersParams
- type ListDataSourcesParams
- type ListPlansParams
- type MRRChurnRateMetrics
- type MRRChurnRateResult
- type MRRMetrics
- type MRRResult
- type MergeCustomersParams
- type MetricsActivities
- type MetricsActivitiesExport
- type MetricsActivity
- type MetricsFilter
- type MetricsResult
- type MetricsSubscription
- type MetricsSubscriptions
- type NestedParams
- type NewAttributes
- type NewCustomer
- type Params
- type Ping
- type Plan
- type PlanGroup
- type PlanGroupPlans
- type PlanGroups
- type Plans
- type RequestErrors
- type SearchCustomersParams
- type Subscription
- type Subscriptions
- type Summary
- type TagsByEmail
- type TagsResult
- type Transaction
- type UpdateCustomer
Constants ¶
const ( // AttrTypeString is one of the possible data types for custom attributes. AttrTypeString = "String" // AttrTypeInteger is one of the possible data types for custom attributes. AttrTypeInteger = "Integer" // AttrTypeTimestamp is one of the possible data types for custom attributes. AttrTypeTimestamp = "Timestamp" // AttrTypeBoolean is one of the possible data types for custom attributes. AttrTypeBoolean = "Boolean" )
const ( // ErrKeyExternalID is key in Errors map indicating there's a problem with External ID of the resource. ErrKeyExternalID = "external_id" // ErrKeyTransactionExternalID is key in Errors map indicating there's a problem with External ID of the transaction. ErrKeyTransactionExternalID = "transactions.external_id" // ErrKeyLineItemsExternalID indicates problem with one/any of line items' external IDs ErrKeyLineItemsExternalID = "line_items.external_id" // ErrKeyName - data source name ErrKeyName = "name" // ErrValCustomerExternalIDExists = can't import new customer with the same external ID ErrValCustomerExternalIDExists = "The external ID for this customer already exists in our system." // ErrValLineItemExternalIDExists = can't import invoice, b'c line item external ID exists ErrValLineItemExternalIDExists = "The external ID for this line item already exists in our system." // ErrValExternalIDExists = can't save Transaction, because it exists already. ErrValExternalIDExists = "has already been taken" // ErrValInvoiceExternalIDExists = invoice already exists ErrValInvoiceExternalIDExists = "The external ID for this invoice already exists in our system." // ErrValPlanExternalIDExists = plan already exists ErrValPlanExternalIDExists = "A plan with this identifier already exists in our system." // ErrValHasAlreadyBeenTaken = data source name taken ErrValHasAlreadyBeenTaken = "Has already been taken." )
Variables ¶
This section is empty.
Functions ¶
Types ¶
type API ¶
API is the handle for communicating with Chartmogul.
func (API) AddCustomAttributesToCustomer ¶
func (api API) AddCustomAttributesToCustomer(customerUUID string, customAttributes []*CustomAttribute) (*CustomAttributes, error)
AddCustomAttributesToCustomer adds custom attributes to specific customer.
See https://dev.chartmogul.com/v1.0/reference#customer-attributes
func (API) AddCustomAttributesWithEmail ¶
func (api API) AddCustomAttributesWithEmail(email string, customAttributes []*CustomAttribute) (*Customers, error)
AddCustomAttributesWithEmail adds custom attributes to customers with specific email.
See https://dev.chartmogul.com/v1.0/reference#customer-attributes
func (API) AddTagsToCustomer ¶
func (api API) AddTagsToCustomer(customerUUID string, tags []string) (*TagsResult, error)
AddTagsToCustomer gives customer new tags.
func (API) AddTagsToCustomersWithEmail ¶
AddTagsToCustomersWithEmail gives new tags to (multiple) customers identified by e-mail only.
func (API) CancelSubscription ¶
func (api API) CancelSubscription(subscriptionUUID string, cancelSubscriptionParams *CancelSubscriptionParams) (*Subscription, error)
CancelSubscription creates an Import API Data Source in ChartMogul.
func (API) ConnectSubscriptions ¶ added in v1.1.7
func (api API) ConnectSubscriptions(customerUUID string, subscriptions []Subscription) error
ConnectSubscriptions connects two subscription objects
See https://dev.chartmogul.com/reference#connect-subscriptions
func (API) CreateCustomer ¶
func (api API) CreateCustomer(newCustomer *NewCustomer) (*Customer, error)
CreateCustomer loads the customer to Chartmogul. New endpoint - with attributes.
func (API) CreateDataSource ¶
func (api API) CreateDataSource(name string) (*DataSource, error)
CreateDataSource creates an API Data Source in ChartMogul.
func (API) CreateDataSourceWithSystem ¶ added in v1.1.4
func (api API) CreateDataSourceWithSystem(dataSource *DataSource) (*DataSource, error)
CreateDataSourceWithSystem creates an API Data Source in ChartMogul. * Allows other parameters than just the name.
func (API) CreateInvoices ¶
CreateInvoices loads an invoice to a customer in Chartmogul. Customer must have a valid UUID! (use return value of API)
func (API) CreatePlan ¶
CreatePlan creates plan under given Data Source.
func (API) CreatePlanGroup ¶ added in v1.2.6
CreatePlanGroup creates plan group with given name and plans.
func (API) CreateTransaction ¶
func (api API) CreateTransaction(transaction *Transaction, invoiceUUID string) (*Transaction, error)
CreateTransaction loads an transaction to a customer in Chartmogul. Customer must have a valid UUID! (use return value of API)
func (API) DeleteCustomer ¶
DeleteCustomer deletes one customer by UUID.
func (API) DeleteCustomerInvoices ¶ added in v1.1.4
DeleteCustomerInvoices deletes all customer's invoices by UUID for given data source UUID.
func (API) DeleteCustomerInvoicesV2 ¶ added in v1.2.5
func (api API) DeleteCustomerInvoicesV2(dataSourceUUID, customerUUID string, deleteCustomerInvoicesParams *DeleteCustomerInvoicesParams) error
DeleteCustomerInvoicesV2 deletes all customer's invoices by UUID & ExternalID for given data source UUID.
func (API) DeleteDataSource ¶
DeleteDataSource deletes the data source identified by its UUID.
func (API) DeleteInvoice ¶ added in v1.1.3
DeleteInvoice deletes one invoice by UUID.
func (API) DeletePlan ¶
DeletePlan deletes one plan by UUID.
func (API) DeletePlanGroup ¶ added in v1.2.6
DeletePlanGroup deletes one plan group by UUID.
func (API) EmptyDataSource ¶ added in v1.3.1
EmptyDataSource deletes all the data in the data source, but keeps the UUID.
func (API) ListAllInvoices ¶ added in v1.1.2
func (api API) ListAllInvoices(listAllInvoicesParams *ListAllInvoicesParams) (*Invoices, error)
ListAllInvoices lists all imported invoices. Use parameters to narrow down the search/for paging. listAllInvoicesParams can be nil, in which case default values on API are used.
func (API) ListCustomers ¶
func (api API) ListCustomers(listCustomersParams *ListCustomersParams) (*Customers, error)
ListCustomers lists all Customers for cutomer of given UUID.
func (API) ListDataSources ¶
func (api API) ListDataSources() (*DataSources, error)
ListDataSources lists all available Data Sources (no paging).
func (API) ListDataSourcesWithFilters ¶ added in v1.1.4
func (api API) ListDataSourcesWithFilters(listDataSourcesParams *ListDataSourcesParams) (*DataSources, error)
ListDataSourcesWithFilters lists all available Data Sources (no paging). * Allows filtering.
func (API) ListInvoices ¶
ListInvoices lists all imported invoices for a customer.
func (API) ListPlanGroupPlans ¶ added in v1.2.6
func (api API) ListPlanGroupPlans(cursor *Cursor, planGroupUUID string) (*PlanGroupPlans, error)
ListPlanGroupPlans returns list of plans in with a plan group given the plan group uuid.
func (API) ListPlanGroups ¶ added in v1.2.6
func (api API) ListPlanGroups(cursor *Cursor) (*PlanGroups, error)
ListPlanGroups returns list of plan groups.
func (API) ListPlans ¶
func (api API) ListPlans(listPlansParams *ListPlansParams) (*Plans, error)
ListPlans returns list of plans.
func (API) ListSubscriptions ¶
func (api API) ListSubscriptions(cursor *Cursor, customerUUID string) (*Subscriptions, error)
ListSubscriptions lists all subscriptions for cutomer of given UUID.
func (API) MergeCustomers ¶
func (api API) MergeCustomers(mergeCustomersParams *MergeCustomersParams) error
MergeCustomers merges two cutomers.
func (API) MetricsCreateActivitiesExport ¶ added in v1.5.1
func (api API) MetricsCreateActivitiesExport(CreateMetricsActivitiesExportParam *CreateMetricsActivitiesExportParam) (*MetricsActivitiesExport, error)
MetricsCreateActivitiesExport requests creation of an activities export in Chartmogul.
See https://dev.chartmogul.com/v1.0/reference#activities_export
func (API) MetricsListActivities ¶
func (api API) MetricsListActivities(cursor *Cursor, customerUUID string) (*MetricsActivities, error)
MetricsListActivities lists all activities for cutomer of a given UUID.
See https://dev.chartmogul.com/v1.0/reference#list-customer-activities
func (API) MetricsListSubscriptions ¶
func (api API) MetricsListSubscriptions(cursor *Cursor, customerUUID string) (*MetricsSubscriptions, error)
MetricsListSubscriptions lists all subscriptions for cutomer of a given UUID.
See https://dev.chartmogul.com/v1.0/reference#list-customer-subscriptions
func (API) MetricsRetrieveARPA ¶
func (api API) MetricsRetrieveARPA(metricsFilter *MetricsFilter) (*ARPAResult, error)
MetricsRetrieveARPA retrieves the ARPA metrics, for the specified time period.
func (API) MetricsRetrieveARR ¶
func (api API) MetricsRetrieveARR(metricsFilter *MetricsFilter) (*ARRResult, error)
MetricsRetrieveARR retrieves the ARR metrics, for the specified time period.
func (API) MetricsRetrieveASP ¶
func (api API) MetricsRetrieveASP(metricsFilter *MetricsFilter) (*ASPResult, error)
MetricsRetrieveASP retrieves the ASP metrics, for the specified time period.
func (API) MetricsRetrieveActivitiesExport ¶ added in v1.5.1
func (api API) MetricsRetrieveActivitiesExport(activitiesExportUUID string) (*MetricsActivitiesExport, error)
MetricsRetrieveActivitiesExport returns one activities export as in API.
See https://dev.chartmogul.com/v1.0/reference#activities_export
func (API) MetricsRetrieveAll ¶
func (api API) MetricsRetrieveAll(metricsFilter *MetricsFilter) (*MetricsResult, error)
MetricsRetrieveAll retrieves all key metrics, for the specified time period.
See https://dev.chartmogul.com/v1.0/reference#retrieve-all-key-metrics
func (API) MetricsRetrieveCustomerChurnRate ¶
func (api API) MetricsRetrieveCustomerChurnRate(metricsFilter *MetricsFilter) (*CustomerChurnRateResult, error)
MetricsRetrieveCustomerChurnRate retrieves customer churn rate, for the specified time period.
See https://dev.chartmogul.com/v1.0/reference#retrieve-customer-churn-rate
func (API) MetricsRetrieveCustomerCount ¶
func (api API) MetricsRetrieveCustomerCount(metricsFilter *MetricsFilter) (*CustomerCountResult, error)
MetricsRetrieveCustomerCount retrieves customer count, for the specified time period.
See https://dev.chartmogul.com/v1.0/reference#retrieve-customer-count
func (API) MetricsRetrieveLTV ¶
func (api API) MetricsRetrieveLTV(metricsFilter *MetricsFilter) (*LTVResult, error)
MetricsRetrieveLTV retrieves LTV metrics, for the specified time period.
func (API) MetricsRetrieveMRR ¶
func (api API) MetricsRetrieveMRR(metricsFilter *MetricsFilter) (*MRRResult, error)
MetricsRetrieveMRR retrieves the MRR metrics, for the specified time period.
func (API) MetricsRetrieveMRRChurnRate ¶
func (api API) MetricsRetrieveMRRChurnRate(metricsFilter *MetricsFilter) (*MRRChurnRateResult, error)
MetricsRetrieveMRRChurnRate retrieves all key metrics, for the specified time period.
See https://dev.chartmogul.com/v1.0/reference#retrieve-mrr-churn-rate
func (API) PurgeDataSource ¶ added in v1.1.4
PurgeDataSource deletes all the data except the data source itself and the customers
func (API) RemoveCustomAttributes ¶
func (api API) RemoveCustomAttributes(customerUUID string, customAttributes []string) (*CustomAttributes, error)
RemoveCustomAttributes removes a list of custom attributes from a specific customer.
See https://dev.chartmogul.com/v1.0/reference#customer-attributes
func (API) RemoveTagsFromCustomer ¶
func (api API) RemoveTagsFromCustomer(customerUUID string, tags []string) (*TagsResult, error)
RemoveTagsFromCustomer deletes passed tags from customer of given UUID.
func (API) RetrieveAccount ¶ added in v1.5.0
RetrieveAccount returns details of current account.
func (API) RetrieveCustomer ¶
RetrieveCustomer returns one customer as in API.
func (API) RetrieveCustomersAttributes ¶
func (api API) RetrieveCustomersAttributes(customerUUID string) (*Attributes, error)
RetrieveCustomersAttributes returns attributes for given customer UUID.
See https://dev.chartmogul.com/v1.0/reference#customer-attributes
func (API) RetrieveDataSource ¶
func (api API) RetrieveDataSource(dataSourceUUID string) (*DataSource, error)
RetrieveDataSource returns one Data Source by UUID.
func (API) RetrieveInvoice ¶ added in v1.1.3
RetrieveInvoice returns one Invoice by UUID.
func (API) RetrievePlan ¶
RetrievePlan returns one plan by UUID.
func (API) RetrievePlanGroup ¶ added in v1.2.6
RetrievePlanGroup returns one plan group by UUID.
func (API) SearchCustomers ¶
func (api API) SearchCustomers(searchCustomersParams *SearchCustomersParams) (*Customers, error)
SearchCustomers lists all Customers for cutomer of given UUID.
func (API) UpdateCustomAttributesOfCustomer ¶
func (api API) UpdateCustomAttributesOfCustomer(customerUUID string, customAttributes map[string]interface{}) (*CustomAttributes, error)
UpdateCustomAttributesOfCustomer updates custom attributes of a specific customer.
See https://dev.chartmogul.com/v1.0/reference#customer-attributes
func (API) UpdateCustomer ¶
UpdateCustomer updates one customer in API.
func (API) UpdateCustomerV2 ¶ added in v1.1.6
func (api API) UpdateCustomerV2(input *UpdateCustomer, customerUUID string) (*Customer, error)
UpdateCustomerV2 updates one customer in API.
See https://dev.chartmogul.com/v1.0/reference#update-a-customer
func (API) UpdatePlan ¶
UpdatePlan returns list of plans.
func (API) UpdatePlanGroup ¶ added in v1.2.6
UpdatePlanGroup updates a name or plans.
type ARPAMetrics ¶
ARPAMetrics represents results of Metrics API.
type ARPAResult ¶
type ARPAResult struct { Entries []*ARPAMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
ARPAResult represents results of Metrics API.
type ARRMetrics ¶
ARRMetrics represents results of Metrics API.
type ARRResult ¶
type ARRResult struct { Entries []*ARRMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
ARRResult represents results of Metrics API.
type ASPMetrics ¶
ASPMetrics represents results of Metrics API.
type ASPResult ¶
type ASPResult struct { Entries []*ASPMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
ASPResult represents results of Metrics API.
type Account ¶ added in v1.5.0
type Account struct { Name string `json:"name"` Currency string `json:"currency"` TimeZone string `json:"time_zone"` WeekStartOn string `json:"week_start_on"` }
Account details in ChartMogul
type Address ¶
type Address struct { AddressZIP string `json:"address_zip,omitempty"` City string `json:"city,omitempty"` State string `json:"state,omitempty"` Country string `json:"country,omitempty"` }
Address is subdocument of Customer.
type AllMetrics ¶
type AllMetrics struct { Date string `json:"date"` CustomerChurnRate float64 `json:"customer-churn-rate"` MrrChurnRate float64 `json:"mrr-churn-rate"` Ltv float64 `json:"ltv"` Customers uint32 `json:"customers"` Asp float64 `json:"asp"` Arpa float64 `json:"arpa"` Arr float64 `json:"arr"` Mrr float64 `json:"mrr"` }
AllMetrics represents results of Metrics API.
type AttributeWithSource ¶ added in v1.1.1
type AttributeWithSource struct { Value interface{} `json:"value"` Source string `json:"source"` }
AttributeWithSource covers the special case when you need to update customer's attribute and chage the source which shows in the ChartMogul UI.
type Attributes ¶
type Attributes struct { Tags []string `json:"tags,omitempty"` Stripe map[string]interface{} `json:"stripe,omitempty"` Clearbit map[string]interface{} `json:"clearbit,omitempty"` Custom map[string]interface{} `json:"custom,omitempty"` }
Attributes is subdocument of Customer.
type CancelSubscriptionParams ¶
type CancelSubscriptionParams struct { CancelledAt string `json:"cancelled_at,omitempty"` CancellationDates *[]string `json:"cancellation_dates,omitempty"` }
CancelSubscriptionParams represents arguments to be marshalled into JSON.
type CreateMetricsActivitiesExportParam ¶ added in v1.5.1
type CreateMetricsActivitiesExportParam struct { Type string `json:"type,omitempty"` StartDate string `json:"start-date,omitempty"` EndDate string `json:"end-date,omitempty"` }
CreateMetricsActivitiesExportParam to create a MetricsActivitiesExport.
type Cursor ¶
type Cursor struct { Page uint32 `json:"page,omitempty"` PerPage uint32 `json:"per_page,omitempty"` }
Cursor contains query parameters for paging in CM. Attributes for query must be string, because gorequest library cannot convert anything else.
type CustID ¶
type CustID struct { DataSourceUUID string `json:"data_source_uuid,omitempty"` ExternalID string `json:"external_id,omitempty"` CustomerUUID string `json:"customer_uuid,omitempty"` }
CustID - use either DataSourceUUID & ExternalID or CustomerUUID
type CustomAttribute ¶
type CustomAttribute struct { Type string `json:"type"` Key string `json:"key"` Value interface{} `json:"value"` Source string `json:"source,omitempty"` }
CustomAttribute = typed custom attribute.
type CustomAttributes ¶
type CustomAttributes struct {
Custom map[string]interface{} `json:"custom"`
}
CustomAttributes contains updated custom attributes.
type Customer ¶
type Customer struct { ID uint32 `json:"id,omitempty"` // Basic info DataSourceUUID string `json:"data_source_uuid,omitempty"` DataSourceUUIDs []string `json:"data_source_uuids,omitempty"` UUID string `json:"uuid,omitempty"` ExternalID string `json:"external_id,omitempty"` ExternalIDs []string `json:"external_ids,omitempty"` Name string `json:"name,omitempty"` Email string `json:"email,omitempty"` Status string `json:"status,omitempty"` CustomerSince string `json:"customer-since,omitempty"` Attributes *Attributes `json:"attributes,omitempty"` Address *Address `json:"address,omitempty"` // Other info Mrr float64 `json:"mrr,omitempty"` Arr float64 `json:"arr,omitempty"` BillingSystemURL string `json:"billing-system-url,omitempty"` ChartmogulURL string `json:"chartmogul-url,omitempty"` BillingSystemType string `json:"billing-system-type,omitempty"` Currency string `json:"currency,omitempty"` CurrencySign string `json:"currency-sign,omitempty"` // For update Company string `json:"company,omitempty"` Country string `json:"country,omitempty"` State string `json:"state,omitempty"` City string `json:"city,omitempty"` Zip string `json:"zip,omitempty"` LeadCreatedAt string `json:"lead_created_at,omitempty"` FreeTrialStartedAt string `json:"free_trial_started_at,omitempty"` Errors Errors `json:"errors,omitempty"` }
Customer is the customer as represented in the API.
type CustomerChurnRateMetrics ¶
type CustomerChurnRateMetrics struct { Date string `json:"date"` CustomerChurnRate float64 `json:"customer-churn-rate"` }
CustomerChurnRateMetrics represents results of Metrics API.
type CustomerChurnRateResult ¶
type CustomerChurnRateResult struct { Entries []*CustomerChurnRateMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
CustomerChurnRateResult represents results of Metrics API.
type CustomerCountMetrics ¶
CustomerCountMetrics represents results of Metrics API.
type CustomerCountResult ¶
type CustomerCountResult struct { Entries []*CustomerCountMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
CustomerCountResult represents results of Metrics API.
type Customers ¶
type Customers struct { Entries []*Customer `json:"entries,omitempty"` Page uint32 `json:"page"` PerPage uint32 `json:"per_page"` HasMore bool `json:"has_more,omitempty"` CurrentPage int32 `json:"current_page,omitempty"` TotalPages int32 `json:"total_pages,omitempty"` }
Customers is result of listing customers in API.
type DataSource ¶
type DataSource struct { UUID string `json:"uuid"` Name string `json:"name"` CreatedAt string `json:"created_at"` Status string `json:"status"` System string `json:"system"` Errors Errors `json:"errors,omitempty"` }
DataSource represents API data source in ChartMogul. See https://dev.chartmogul.com/v1.0/reference#list-data-sources
type DataSources ¶
type DataSources struct {
DataSources []*DataSource `json:"data_sources"`
}
DataSources is the result of listing data sources, but doesn't contain any paging.
type DeleteCustomerInvoicesParams ¶ added in v1.2.5
type DeleteCustomerInvoicesParams struct {
CustomerExternalID string
}
DeleteCustomerInvoicesParams - optional param for deleting all customer invoices.
type Errors ¶
Errors contains error feedback from ChartMogul
func (Errors) IsAlreadyExists ¶
IsAlreadyExists is helper that returns true, if there's only one error and it means the uploaded resource of the same external_id already exists.
func (Errors) IsInvoiceAndItsEntitiesAlreadyExist ¶ added in v1.2.1
IsInvoiceAndItsEntitiesAlreadyExist returns true if: * invoice already exists AND * ANY other entities (line items, transactions) already exist AND * no other error
So, eg. if the invoice doesn't exist, but the transaction does, you have a different problem (duplicating txns) and this returns false.
func (Errors) IsInvoiceAndTransactionAlreadyExist ¶
IsInvoiceAndTransactionAlreadyExist occurs when both invoice and tx exist already. Use `IsInvoiceAndItsEntitiesAlreadyExist` if you'd like to catch line items as well.
type IApi ¶
type IApi interface { Ping() (res bool, err error) // Data sources CreateDataSource(name string) (*DataSource, error) CreateDataSourceWithSystem(dataSource *DataSource) (*DataSource, error) RetrieveDataSource(dataSourceUUID string) (*DataSource, error) ListDataSources() (*DataSources, error) ListDataSourcesWithFilters(listDataSourcesParams *ListDataSourcesParams) (*DataSources, error) PurgeDataSource(dataSourceUUID string) error EmptyDataSource(dataSourceUUID string) error DeleteDataSource(dataSourceUUID string) error // Invoices CreateInvoices(invoices []*Invoice, customerUUID string) (*Invoices, error) ListInvoices(cursor *Cursor, customerUUID string) (*Invoices, error) ListAllInvoices(listAllInvoicesParams *ListAllInvoicesParams) (*Invoices, error) RetrieveInvoice(invoiceUUID string) (*Invoice, error) DeleteInvoice(invoiceUUID string) error // Plans CreatePlan(plan *Plan) (result *Plan, err error) RetrievePlan(planUUID string) (*Plan, error) ListPlans(listPlansParams *ListPlansParams) (*Plans, error) UpdatePlan(plan *Plan, planUUID string) (*Plan, error) DeletePlan(planUUID string) error // Plan Groups CreatePlanGroup(planGroup *PlanGroup) (result *PlanGroup, err error) RetrievePlanGroup(planGroupUUID string) (*PlanGroup, error) ListPlanGroups(cursor *Cursor) (*PlanGroups, error) UpdatePlanGroup(plan *PlanGroup, planGroupUUID string) (*PlanGroup, error) DeletePlanGroup(planGroupUUID string) error ListPlanGroupPlans(cursor *Cursor, planGroupUUID string) (*PlanGroupPlans, error) // Subscriptions CancelSubscription(subscriptionUUID string, cancelSubscriptionParams *CancelSubscriptionParams) (*Subscription, error) ListSubscriptions(cursor *Cursor, customerUUID string) (*Subscriptions, error) // Transactions CreateTransaction(transaction *Transaction, invoiceUUID string) (*Transaction, error) // Customers CreateCustomer(newCustomer *NewCustomer) (*Customer, error) RetrieveCustomer(customerUUID string) (*Customer, error) UpdateCustomer(Customer *Customer, customerUUID string) (*Customer, error) UpdateCustomerV2(Customer *UpdateCustomer, customerUUID string) (*Customer, error) ListCustomers(ListCustomersParams *ListCustomersParams) (*Customers, error) SearchCustomers(SearchCustomersParams *SearchCustomersParams) (*Customers, error) MergeCustomers(MergeCustomersParams *MergeCustomersParams) error DeleteCustomer(customerUUID string) error DeleteCustomerInvoices(dataSourceUUID, customerUUID string) error DeleteCustomerInvoicesV2(dataSourceUUID, customerUUID string, DeleteCustomerInvoicesParams *DeleteCustomerInvoicesParams) error // - Cusomer Attributes RetrieveCustomersAttributes(customerUUID string) (*Attributes, error) // Tags AddTagsToCustomer(customerUUID string, tags []string) (*TagsResult, error) AddTagsToCustomersWithEmail(email string, tags []string) (*Customers, error) RemoveTagsFromCustomer(customerUUID string, tags []string) (*TagsResult, error) // Custom Attributes AddCustomAttributesToCustomer(customerUUID string, customAttributes []*CustomAttribute) (*CustomAttributes, error) AddCustomAttributesWithEmail(email string, customAttributes []*CustomAttribute) (*Customers, error) UpdateCustomAttributesOfCustomer(customerUUID string, customAttributes map[string]interface{}) (*CustomAttributes, error) RemoveCustomAttributes(customerUUID string, customAttributes []string) (*CustomAttributes, error) // Metrics MetricsRetrieveAll(metricsFilter *MetricsFilter) (*MetricsResult, error) MetricsRetrieveMRR(metricsFilter *MetricsFilter) (*MRRResult, error) MetricsRetrieveARR(metricsFilter *MetricsFilter) (*ARRResult, error) MetricsRetrieveARPA(metricsFilter *MetricsFilter) (*ARPAResult, error) MetricsRetrieveASP(metricsFilter *MetricsFilter) (*ASPResult, error) MetricsRetrieveCustomerCount(metricsFilter *MetricsFilter) (*CustomerCountResult, error) MetricsRetrieveCustomerChurnRate(metricsFilter *MetricsFilter) (*CustomerChurnRateResult, error) MetricsRetrieveMRRChurnRate(metricsFilter *MetricsFilter) (*MRRChurnRateResult, error) MetricsRetrieveLTV(metricsFilter *MetricsFilter) (*LTVResult, error) // Metrics - Subscriptions & Activities MetricsListSubscriptions(cursor *Cursor, customerUUID string) (*MetricsSubscriptions, error) MetricsListActivities(cursor *Cursor, customerUUID string) (*MetricsActivities, error) MetricsCreateActivitiesExport(CreateMetricsActivitiesExportParam *CreateMetricsActivitiesExportParam) (*MetricsActivitiesExport, error) MetricsRetrieveActivitiesExport(activitiesExportUUID string) (*MetricsActivitiesExport, error) // Account RetrieveAccount() (*Account, error) }
IApi defines the interface of the library. Necessary eg. for mocks in testing.
type Invoice ¶
type Invoice struct { UUID string `json:"uuid,omitempty"` CustomerUUID string `json:"customer_uuid,omitempty"` CustomerExternalID string `json:"customer_external_id,omitempty"` Currency string `json:"currency"` DataSourceUUID string `json:"data_source_uuid,omitempty"` Date string `json:"date"` DueDate string `json:"due_date,omitempty"` ExternalID string `json:"external_id"` LineItems []*LineItem `json:"line_items"` Transactions []*Transaction `json:"transactions,omitempty"` Errors *Errors `json:"errors,omitempty"` }
Invoice is the data for ChartMogul to auto-generate subscriptions.
type Invoices ¶
type Invoices struct { CustomerUUID string `json:"customer_uuid,omitempty"` CurrentPage uint32 `json:"current_page,omitempty"` TotalPages uint32 `json:"total_pages,omitempty"` Error string `json:"error,omitempty"` Invoices []*Invoice `json:"invoices"` }
Invoices is wrapper for bulk importing invoices In case of /v1/invoices endpoint, the customer_uuid is on individual invoices and here it's empty.
type LTVMetrics ¶
LTVMetrics represents results of Metrics API.
type LTVResult ¶
type LTVResult struct { Entries []*LTVMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
LTVResult represents results of Metrics API.
type LineItem ¶
type LineItem struct { UUID string `json:"uuid,omitempty"` AccountCode string `json:"account_code,omitempty"` AmountInCents int `json:"amount_in_cents"` CancelledAt string `json:"cancelled_at,omitempty"` Description string `json:"description,omitempty"` DiscountAmountInCents int `json:"discount_amount_in_cents,omitempty"` DiscountCode string `json:"discount_code,omitempty"` ExternalID string `json:"external_id,omitempty"` PlanUUID string `json:"plan_uuid,omitempty"` Prorated bool `json:"prorated,omitempty"` Quantity int `json:"quantity,omitempty"` ServicePeriodEnd string `json:"service_period_end,omitempty"` ServicePeriodStart string `json:"service_period_start,omitempty"` SubscriptionExternalID string `json:"subscription_external_id,omitempty"` SubscriptionSetExternalID string `json:"subscription_set_external_id,omitempty"` SubscriptionUUID string `json:"subscription_uuid,omitempty"` TaxAmountInCents int `json:"tax_amount_in_cents,omitempty"` TransactionFeesInCents int `json:"transaction_fees_in_cents,omitempty"` Type string `json:"type"` }
LineItem represents a singular items of the invoices
type ListAllInvoicesParams ¶ added in v1.1.2
type ListAllInvoicesParams struct { CustomerUUID string `json:"customer_uuid,omitempty"` DataSourceUUID string `json:"data_source_uuid,omitempty"` ExternalID string `json:"external_id,omitempty"` Cursor }
ListAllInvoicesParams optional parameters for ListAllInvoices
type ListCustomersParams ¶
type ListCustomersParams struct { DataSourceUUID string `json:"data_source_uuid,omitempty"` Status string `json:"status,omitempty"` System string `json:"system,omitempty"` ExternalID string `json:"external_id,omitempty"` Cursor }
ListCustomersParams = parameters for listing customers in API.
type ListDataSourcesParams ¶ added in v1.1.4
type ListDataSourcesParams struct { Name string `json:"name,omitempty"` System string `json:"system,omitempty"` }
ListDataSourcesParams are optional parameters for listing data sources.
type ListPlansParams ¶
type ListPlansParams struct { DataSourceUUID string `json:"data_source_uuid"` ExternalID string `json:"external_id,omitempty"` System string `json:"system,omitempty"` Cursor }
ListPlansParams = optional parameters for listing plans.
type MRRChurnRateMetrics ¶
type MRRChurnRateMetrics struct { Date string `json:"date"` MRRChurnRate float64 `json:"mrr-churn-rate"` }
MRRChurnRateMetrics represents results of Metrics API.
type MRRChurnRateResult ¶
type MRRChurnRateResult struct { Entries []*MRRChurnRateMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
MRRChurnRateResult represents results of Metrics API.
type MRRMetrics ¶
type MRRMetrics struct { Date string `json:"date"` MRR float64 `json:"mrr"` MRRNewBusiness float64 `json:"mrr-new-business"` MRRExpansion float64 `json:"mrr-expansion"` MRRContraction float64 `json:"mrr-contraction"` MRRChurn float64 `json:"mrr-churn"` MRRReactivation float64 `json:"mrr-reactivation"` }
MRRMetrics represents results of Metrics API.
type MRRResult ¶
type MRRResult struct { Entries []*MRRMetrics `json:"entries,omitempty"` Summary *Summary `json:"summary"` }
MRRResult represents results of Metrics API.
type MergeCustomersParams ¶
MergeCustomersParams - identify source and target for merging.
type MetricsActivities ¶
type MetricsActivities struct { Entries []*MetricsActivity `json:"entries"` HasMore bool `json:"has_more"` PerPage uint32 `json:"per_page"` Page uint32 `json:"page"` }
MetricsActivities is the result of listing activities in Metrics API.
type MetricsActivitiesExport ¶ added in v1.5.1
type MetricsActivitiesExport struct { ID string `json:"id"` Status string `json:"status"` FileURL string `json:"file_url"` Params Params `json:"params"` ExpiresAt string `json:"expires_at"` CreatedAt string `json:"created_at"` }
MetricsActivitiesExport represents Metrics API activity export in ChartMogul.
type MetricsActivity ¶
type MetricsActivity struct { ID uint64 `json:"id"` Date string `json:"date"` ActivityArr float64 `json:"activity-arr"` ActivityMrr float64 `json:"activity-mrr"` ActivityMrrMovement float64 `json:"activity-mrr-movement"` Currency string `json:"currency"` CurrencySign string `json:"currency-sign"` Description string `json:"description"` Type string `json:"type"` }
MetricsActivity represents Metrics API activity in ChartMogul.
type MetricsFilter ¶
type MetricsFilter struct { StartDate string `json:"start-date,omitempty"` EndDate string `json:"end-date,omitempty"` Interval string `json:"interval,omitempty"` Geo string `json:"geo,omitempty"` Plans string `json:"plans,omitempty"` }
MetricsFilter convenient object to hold all filtering parameters.
type MetricsResult ¶
type MetricsResult struct {
Entries []*AllMetrics `json:"entries,omitempty"`
}
MetricsResult represents results of Metrics API.
type MetricsSubscription ¶
type MetricsSubscription struct { ID uint64 `json:"id"` ExternalID string `json:"external_id"` Plan string `json:"plan"` Quantity uint32 `json:"quantity"` BillingCycleCount uint32 `json:"billing-cycle-count"` MRR float64 `json:"mrr"` ARR float64 `json:"arr"` Status string `json:"status"` BillingCycle string `json:"billing-cycle"` StartDate string `json:"start-date"` EndDate string `json:"end-date"` Currency string `json:"currency"` CurrencySign string `json:"currency-sign"` }
MetricsSubscription represents Metrics API subscription in ChartMogul.
type MetricsSubscriptions ¶
type MetricsSubscriptions struct { Entries []*MetricsSubscription `json:"entries"` HasMore bool `json:"has_more"` PerPage uint32 `json:"per_page"` Page uint32 `json:"page"` }
MetricsSubscriptions is the result of listing subscriptions in Metrics API.
type NestedParams ¶ added in v1.5.1
type NestedParams struct { ActivityType string `json:"activity_type,omitempty"` StartDate string `json:"start_date,omitempty"` EndDate string `json:"end_date,omitempty"` }
NestedParams represents the params of the requested type of export.
type NewAttributes ¶
type NewAttributes struct { Tags []string `json:"tags,omitempty"` Custom []*CustomAttribute `json:"custom,omitempty"` }
NewAttributes is subdocument of NewCustomer.
type NewCustomer ¶
type NewCustomer struct { // Obligatory DataSourceUUID string `json:"data_source_uuid"` ExternalID string `json:"external_id,omitempty"` Name string `json:"name,omitempty"` //Optional Email string `json:"email,omitempty"` Attributes *NewAttributes `json:"attributes,omitempty"` // Address Company string `json:"company,omitempty"` Country string `json:"country,omitempty"` State string `json:"state,omitempty"` City string `json:"city,omitempty"` Zip string `json:"zip,omitempty"` // Lead/Trial LeadCreatedAt string `json:"lead_created_at,omitempty"` FreeTrialStartedAt string `json:"free_trial_started_at,omitempty"` }
NewCustomer allows creating customer on a new endpoint.
type Params ¶ added in v1.5.1
type Params struct { Kind string `json:"kind"` Params NestedParams `json:"params,omitempty"` }
Params provides information on the requested export.
type Ping ¶
type Ping struct {
Data string
}
Ping is simple struct for the authentication test endpoint.
type Plan ¶
type Plan struct { UUID string `json:"uuid,omitempty"` DataSourceUUID string `json:"data_source_uuid,omitempty"` ExternalID string `json:"external_id,omitempty"` Name string `json:"name,omitempty"` IntervalCount uint32 `json:"interval_count,omitempty"` IntervalUnit string `json:"interval_unit,omitempty"` Errors Errors `json:"errors,omitempty"` }
Plan represents ChartMogul categorization of subscriptions.
type PlanGroup ¶ added in v1.2.6
type PlanGroup struct { UUID string `json:"uuid,omitempty"` Name string `json:"name,omitempty"` Plans []*string `json:"plans,omitempty"` PlansCount int `json:"plans_count,omitempty"` Errors Errors `json:"errors,omitempty"` }
PlanGroup represents groups of plans in ChartMogul
type PlanGroupPlans ¶ added in v1.2.6
type PlanGroupPlans struct { Plans []*Plan `json:"plans"` TotalPages uint32 `json:"total_pages"` CurrentPage uint32 `json:"current_page"` }
PlanGroupPlans is result of listing: plans + paging for a plan group.
type PlanGroups ¶ added in v1.2.6
type PlanGroups struct { PlanGroups []*PlanGroup `json:"plan_groups"` TotalPages uint32 `json:"total_pages"` CurrentPage uint32 `json:"current_page"` }
PlanGroups is result of listing: plan_groups + page.
type Plans ¶
type Plans struct { Plans []*Plan `json:"plans"` TotalPages uint32 `json:"total_pages"` CurrentPage uint32 `json:"current_page"` }
Plans is result of listing: plans + paging.
type RequestErrors ¶
type RequestErrors interface {
Errors() []error
}
RequestErrors wraps multiple request errors to normal 1 error struct.
type SearchCustomersParams ¶
SearchCustomersParams - just email now.
type Subscription ¶
type Subscription struct { UUID string `json:"uuid,omitempty"` ExternalID string `json:"external_id"` SubscriptionSetExternalID string `json:"subscription_set_external_id,omitempty"` PlanUUID string `json:"plan_uuid,omitempty"` CustomerUUID string `json:"customer_uuid,omitempty"` DataSourceUUID string `json:"data_source_uuid"` CancellationDates []string `json:"cancellation_dates,omitempty"` }
Subscription represents Import API subscription in ChartMogul.
type Subscriptions ¶
type Subscriptions struct { Subscriptions []Subscription `json:"subscriptions"` CustomerUUID string `json:"customer_uuid,omitempty"` TotalPages uint32 `json:"total_pages,omitempty"` CurrentPage uint32 `json:"current_page,omitempty"` }
Subscriptions is the result of listing subscriptions with paging.
type Summary ¶
type Summary struct { Current float64 `json:"current"` Previous float64 `json:"previous"` PercentageChange float64 `json:"percentage-change"` }
Summary represents results of Metrics API.
type TagsByEmail ¶
TagsByEmail = input for AddTagsToCustomersWithEmail
type TagsResult ¶
type TagsResult struct {
Tags []string `json:"tags"`
}
TagsResult is necessary for the the result of AddTags.
type Transaction ¶
type Transaction struct { UUID string `json:"uuid,omitempty"` Date string `json:"date"` ExternalID string `json:"external_id,omitempty"` Result string `json:"result"` Type string `json:"type"` AmountInCents *int `json:"amount_in_cents,omitempty"` Errors Errors `json:"errors,omitempty"` }
Transaction is either payment/refund on an invoice, for its full value.
type UpdateCustomer ¶ added in v1.1.6
type UpdateCustomer struct { Name *string `json:"name,omitempty"` Email *string `json:"email,omitempty"` Company *string `json:"company,omitempty"` Country *string `json:"country,omitempty"` State *string `json:"state,omitempty"` City *string `json:"city,omitempty"` Zip *string `json:"zip,omitempty"` LeadCreatedAt *string `json:"lead_created_at,omitempty"` FreeTrialStartedAt *string `json:"free_trial_started_at,omitempty"` Attributes *Attributes `json:"attributes,omitempty"` }
UpdateCustomer allows updating customer on the update endpoint.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package mock_chartmogul_go is a generated GoMock package.
|
Package mock_chartmogul_go is a generated GoMock package. |