Compare commits

...

2 Commits

Author SHA1 Message Date
54417bf436 don't export BearerToken
All checks were successful
continuous-integration/drone/push Build is passing
2024-03-23 19:45:28 -06:00
e35f0ef659 do not export what's not required 2024-03-23 19:00:30 -06:00
3 changed files with 21 additions and 21 deletions

View File

@ -8,7 +8,7 @@ import (
// Reference: https://api.ynab.com/v1#/Accounts/ // Reference: https://api.ynab.com/v1#/Accounts/
type Accounts struct { type accounts struct {
Data struct { Data struct {
Account struct { Account struct {
ID string `json:"id"` ID string `json:"id"`
@ -29,8 +29,8 @@ type Accounts struct {
} `json:"data"` } `json:"data"`
} }
func (c *Client) GetAccount(accountID string) (*Accounts, error) { func (c *Client) getAccount(accountID string) (*accounts, error) {
response := Accounts{} response := accounts{}
err := c.get(fmt.Sprintf("/accounts/%s", accountID), &response, url.Values{}) err := c.get(fmt.Sprintf("/accounts/%s", accountID), &response, url.Values{})
if err != nil { if err != nil {
@ -49,7 +49,7 @@ func (c *Client) SetAccountBalance(accountID string, balance int) error {
return fmt.Errorf("failed to get ynab capital gains transaction ID: %v", err) return fmt.Errorf("failed to get ynab capital gains transaction ID: %v", err)
} }
ynabAccount, err := c.GetAccount(accountID) ynabAccount, err := c.getAccount(accountID)
if err != nil { if err != nil {
return fmt.Errorf("failed to get ynab account with id '%s': %v", accountID, err) return fmt.Errorf("failed to get ynab account with id '%s': %v", accountID, err)
} }

View File

@ -19,7 +19,7 @@ const apiBaseURL = "https://api.ynab.com/v1/budgets/"
// endpoints. It holds the login credentials, http client/transport, // endpoints. It holds the login credentials, http client/transport,
// rate limit information, and the login session timer. // rate limit information, and the login session timer.
type Client struct { type Client struct {
BearerToken string bearerToken string
BudgetID string BudgetID string
httpClient *http.Client httpClient *http.Client
transport *http.Transport transport *http.Transport
@ -32,7 +32,7 @@ func (c *Client) get(endpoint string, out interface{}, query url.Values) error {
if err != nil { if err != nil {
return fmt.Errorf("failed to create new GET request: %v", err) return fmt.Errorf("failed to create new GET request: %v", err)
} }
req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", c.BearerToken)) req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", c.bearerToken))
res, err := c.httpClient.Do(req) res, err := c.httpClient.Do(req)
if err != nil { if err != nil {
@ -58,7 +58,7 @@ func (c *Client) post(endpoint string, out interface{}, body interface{}) error
if err != nil { if err != nil {
return fmt.Errorf("failed to create new POST request: %v", err) return fmt.Errorf("failed to create new POST request: %v", err)
} }
req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", c.BearerToken)) req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", c.bearerToken))
req.Header.Add("Content-Type", "application/json") req.Header.Add("Content-Type", "application/json")
res, err := c.httpClient.Do(req) res, err := c.httpClient.Do(req)
@ -85,7 +85,7 @@ func (c *Client) put(endpoint string, out interface{}, body interface{}) error {
if err != nil { if err != nil {
return fmt.Errorf("failed to create new POST request: %v", err) return fmt.Errorf("failed to create new POST request: %v", err)
} }
req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", c.BearerToken)) req.Header.Add("Authorization", fmt.Sprintf("Bearer %s", c.bearerToken))
req.Header.Add("Content-Type", "application/json") req.Header.Add("Content-Type", "application/json")
res, err := c.httpClient.Do(req) res, err := c.httpClient.Do(req)
@ -140,7 +140,7 @@ func NewClient(budgetID, bearerToken string) (*Client, error) {
// Create a new client // Create a new client
c := &Client{ c := &Client{
BudgetID: budgetID, BudgetID: budgetID,
BearerToken: bearerToken, bearerToken: bearerToken,
httpClient: client, httpClient: client,
transport: transport, transport: transport,
loc: loc, loc: loc,

View File

@ -7,7 +7,7 @@ import (
) )
// Reference: https://api.ynab.com/v1#/Transactions/ // Reference: https://api.ynab.com/v1#/Transactions/
type Transaction struct { type transaction struct {
Type string `json:"type,omitempty"` Type string `json:"type,omitempty"`
ParentTransactionID interface{} `json:"parent_transaction_id,omitempty"` ParentTransactionID interface{} `json:"parent_transaction_id,omitempty"`
ID string `json:"id,omitempty"` ID string `json:"id,omitempty"`
@ -31,31 +31,31 @@ type Transaction struct {
} }
// Used for single transaction requests // Used for single transaction requests
type TransactionRequest struct { type transactionRequest struct {
Transaction Transaction `json:"transaction,omitempty"` Transaction transaction `json:"transaction,omitempty"`
} }
// Used for single transaction responses // Used for single transaction responses
type TransactionResponse struct { type transactionResponse struct {
Data struct { Data struct {
TransactionIDs []string `json:"transaction_ids,omitempty"` TransactionIDs []string `json:"transaction_ids,omitempty"`
Transaction Transaction `json:"transaction"` Transaction transaction `json:"transaction"`
ServerKnowledge int `json:"server_knowledge,omitempty"` ServerKnowledge int `json:"server_knowledge,omitempty"`
} }
} }
// Used for multiple transaction requests / responses // Used for multiple transaction requests / responses
type TransactionsResponse struct { type transactionListResponse struct {
Data struct { Data struct {
Transactions []Transaction `json:"transactions"` Transactions []transaction `json:"transactions"`
ServerKnowledge int `json:"server_knowledge"` ServerKnowledge int `json:"server_knowledge"`
} `json:"data"` } `json:"data"`
} }
// Accepts a YNAB account ID and timestamp and returns all transactions in that account // Accepts a YNAB account ID and timestamp and returns all transactions in that account
// since the date provided // since the date provided
func (c *Client) GetAccountTransactions(accountID string, sinceDate time.Time) (*TransactionsResponse, error) { func (c *Client) GetAccountTransactions(accountID string, sinceDate time.Time) (*transactionListResponse, error) {
response := TransactionsResponse{} response := transactionListResponse{}
urlQuery := url.Values{} urlQuery := url.Values{}
urlQuery.Add("since_date", sinceDate.Format("2006-01-02")) urlQuery.Add("since_date", sinceDate.Format("2006-01-02"))
@ -86,8 +86,8 @@ func (c *Client) getTodayYnabCapitalGainsTransaction(accountID string) (string,
// Accepts a YNAB account ID, transaction ID and transaction amount and updates the YNAB transaction with the matching ID // Accepts a YNAB account ID, transaction ID and transaction amount and updates the YNAB transaction with the matching ID
// If transaction ID is blank, a new transaction is created for the amount specified // If transaction ID is blank, a new transaction is created for the amount specified
func (c *Client) updateTodayYNABCapitalGainsTransaction(accountID string, transactionID string, amount int) error { func (c *Client) updateTodayYNABCapitalGainsTransaction(accountID string, transactionID string, amount int) error {
request := TransactionRequest{ request := transactionRequest{
Transaction: Transaction{ Transaction: transaction{
AccountID: accountID, AccountID: accountID,
Amount: amount, Amount: amount,
Date: time.Now().In(c.loc).Format("2006-01-02"), Date: time.Now().In(c.loc).Format("2006-01-02"),
@ -97,7 +97,7 @@ func (c *Client) updateTodayYNABCapitalGainsTransaction(accountID string, transa
Memo: fmt.Sprintf("Quoted at: %s", time.Now().In(c.loc).Format("2006-01-02 15:04:05")), Memo: fmt.Sprintf("Quoted at: %s", time.Now().In(c.loc).Format("2006-01-02 15:04:05")),
}, },
} }
response := &TransactionResponse{} response := &transactionResponse{}
var err error var err error
if transactionID == "" { // create transaction if transactionID == "" { // create transaction
err = c.post("/transactions", response, request) err = c.post("/transactions", response, request)