lib

package
v0.3.3 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jul 16, 2021 License: Apache-2.0 Imports: 13 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// type of portfolio, Line of Credit
	PortfolioTypeCredit = "C"
	// type of portfolio, Installment
	PortfolioTypeInstallment = "I"
	// type of portfolio, Mortgage
	PortfolioTypeMortgage = "M"
	// type of portfolio, Open
	PortfolioTypeOpen = "O"
	// type of portfolio, Revolving
	PortfolioTypeRevolving = "R"
	// duration of credit extended, Line of Credit
	TermsDurationCredit = "LOC"
	// duration of credit extended, Open
	TermsDurationOpen = "001"
	// duration of credit extended, Revolving
	TermsDurationRevolving = "REV"
	// frequency for payments due, Deferred (Refer to Note)
	TermsFrequencyDeferred = "D"
	// frequency for payments due, Single Payment Loan
	TermsFrequencyPayment = "P"
	// frequency for payments due, Weekly
	TermsFrequencyWeekly = "W"
	// frequency for payments due, Biweekly
	TermsFrequencyBiweekly = "B"
	// frequency for payments due, Semimonthly
	TermsFrequencySemimonthly = "E"
	// frequency for payments due, Monthly
	TermsFrequencyMonthly = "M"
	// frequency for payments due, Bimonthly
	TermsFrequencyBimonthly = "L"
	// frequency for payments due, Quarterly
	TermsFrequencyQuarterly = "Q"
	// frequency for payments due, Tri-annually
	TermsFrequencyTriAnnually = "T"
	// frequency for payments due, Semiannually
	TermsFrequencySemiannually = "S"
	// frequency for payments due, Annually
	TermsFrequencyAnnually = "Y"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// Current account (0–29 days past the due date)
	PaymentRatingCurrent = "0"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// 30-59 days past the due date
	PaymentRatingPast30 = "1"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// 60-89 days past the due date
	PaymentRatingPast60 = "2"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// 90-119 days past the due date
	PaymentRatingPast90 = "3"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// 120-149 days past the due date
	PaymentRatingPast120 = "4"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// 150-179 days past the due date
	PaymentRatingPast150 = "5"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// 180 or more days past the due date
	PaymentRatingPast180 = "6"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// Collection
	PaymentRatingCollection = "G"
	// code that properly identifies whether the account was current, past due, in collections or charged off
	// Charge-off
	PaymentRatingChargeOff = "L"
	// consecutive payment activity, 0 payments past due (current account)
	PaymentHistoryPast0 = '0'
	// consecutive payment activity, 30 - 59 days past due date
	PaymentHistoryPast30 = '1'
	// consecutive payment activity, 60 - 89 days past due date
	PaymentHistoryPast60 = '2'
	// consecutive payment activity, 90 - 119 days past due date
	PaymentHistoryPast90 = '3'
	// consecutive payment activity, 120 - 149 days past due date
	PaymentHistoryPast120 = '4'
	// consecutive payment activity, 150 - 179 days past due date
	PaymentHistoryPast150 = '5'
	// consecutive payment activity, 180 or more days past due date
	PaymentHistoryPast180 = '6'
	// consecutive payment activity, No payment history available prior to this time
	PaymentHistoryNoPayment = 'B'
	// consecutive payment activity, No payment history available this month.
	PaymentHistoryNoPaymentMonth = 'D'
	// consecutive payment activity, Zero balance and current account
	PaymentHistoryZero = 'E'
	// consecutive payment activity, Collection
	PaymentHistoryCollection = 'G'
	// consecutive payment activity, Foreclosure Completed
	PaymentHistoryForeclosureCompleted = 'H'
	// consecutive payment activity, Voluntary Surrender
	PaymentHistoryVoluntarySurrender = 'J'
	// consecutive payment activity, Repossession
	PaymentHistoryRepossession = 'K'
	// consecutive payment activity, Charge-off
	PaymentHistoryChargeOff = 'L'
	//  status code that properly identifies the current condition of the account, "DF"
	AccountStatusDF = "DF"
	//  status code that properly identifies the current condition of the account, "DA"
	AccountStatusDA = "DA"
	//  status code that properly identifies the current condition of the account, "11"
	AccountStatus11 = "11"
	//  status code that properly identifies the current condition of the account, "61"
	AccountStatus61 = "61"
	//  status code that properly identifies the current condition of the account, "62"
	AccountStatus62 = "62"
	//  status code that properly identifies the current condition of the account, "63"
	AccountStatus63 = "63"
	//  status code that properly identifies the current condition of the account, "64"
	AccountStatus64 = "64"
	//  status code that properly identifies the current condition of the account, "71"
	AccountStatus71 = "71"
	//  status code that properly identifies the current condition of the account, "78"
	AccountStatus78 = "78"
	//  status code that properly identifies the current condition of the account, "80"
	AccountStatus80 = "80"
	//  status code that properly identifies the current condition of the account, "82"
	AccountStatus82 = "82"
	//  status code that properly identifies the current condition of the account, "83"
	AccountStatus83 = "83"
	//  status code that properly identifies the current condition of the account, "84"
	AccountStatus84 = "84"
	//  status code that properly identifies the current condition of the account, "93"
	AccountStatus93 = "93"
	//  status code that properly identifies the current condition of the account, "96"
	AccountStatus96 = "96"
	//  status code that properly identifies the current condition of the account, "97"
	AccountStatus97 = "97"
	//  status code that properly identifies the current condition of the account, "05"
	AccountStatus05 = "05"
	//  status code that properly identifies the current condition of the account, "13"
	AccountStatus13 = "13"
	//  status code that properly identifies the current condition of the account, "65"
	AccountStatus65 = "65"
	//  status code that properly identifies the current condition of the account, "88"
	AccountStatus88 = "88"
	//  status code that properly identifies the current condition of the account, "89"
	AccountStatus89 = "89"
	//  status code that properly identifies the current condition of the account, "94"
	AccountStatus94 = "94"
	//  status code that properly identifies the current condition of the account, "95"
	AccountStatus95 = "95"
	// designates the interest type, Fixed
	InterestIndicatorFixed = "F"
	// designates the interest type, Variable/Adjustable
	InterestIndicatorVariable = "V"
	// Consumer Account Number Change ONLY
	ChangeIndicatorAccountNumber = 1
	// Identification Number Change ONLY
	ChangeIndicatorIdentificationNumber = 2
	// Consumer Account Number AND Identification Number Change
	ChangeIndicatorBothNumber = 3
	// Generation Code Junior
	GenerationCodeJunior = "J"
	// Generation Code Senior
	GenerationCodeSenior = "S"
	// Generation Code 2
	GenerationCode2 = "2"
	// Generation Code 3
	GenerationCode3 = "3"
	// Generation Code 4
	GenerationCode4 = "4"
	// Generation Code 5
	GenerationCode5 = "5"
	// Generation Code 6
	GenerationCode6 = "6"
	// Generation Code 7
	GenerationCode7 = "7"
	// Generation Code 8
	GenerationCode8 = "8"
	// Generation Code 9
	GenerationCode9 = "9"
	// Confirmed/Verified address
	AddressIndicatorConfirmed = "C"
	// Known to be address of associated consumer
	AddressIndicatorKnown = "Y"
	// Not confirmed address
	AddressIndicatorNotConfirmed = "N"
	// Military address
	AddressIndicatorMilitary = "M"
	// Secondary address
	AddressIndicatorSecondary = "S"
	// Business address — not consumer's residence
	AddressIndicatorBusiness = "B"
	// Non-deliverable address/Returned mail
	AddressIndicatorNonDeliverable = "U"
	// Data reporter’s default address
	AddressIndicatorData = "D"
	// Bill Payer Service — not consumer’s residence
	AddressIndicatorBill = "P"
	// Residence Code Owns
	ResidenceCodeOwns = "O"
	// Residence Code Rents
	ResidenceCodeRents = "R"
	// Creditor Classification
	CreditorClassificationRetail = 1
	// Creditor Classification Medical/Health Care
	CreditorClassificationMedical = 2
	// Creditor Classification Oil Company
	CreditorClassificationOil = 3
	// Creditor Classification Government
	CreditorClassificationGovernment = 4
	// Creditor Classification Personal Services
	CreditorClassificationPersonal = 5
	// Creditor Classification Insurance
	CreditorClassificationInsurance = 6
	// Creditor Classification Educational
	CreditorClassificationEducational = 7
	// Creditor Classification Banking
	CreditorClassificationBanking = 8
	// Creditor Classification Rental/Leasing
	CreditorClassificationRental = 9
	// Creditor Classification Utilities
	CreditorClassificationUtilities = 10
	// Creditor Classification Cable/Cellular
	CreditorClassificationCable = 11
	// Creditor Classification Financial
	CreditorClassificationFinancial = 12
	// Creditor Classification Credit Union
	CreditorClassificationCredit = 13
	// Creditor Classification Automotive
	CreditorClassificationAutomotive = 14
	// Creditor Classification Check Guarantee
	CreditorClassificationGuarantee = 15
	// Purchased From Name
	PurchasedIndicatorFromName = 1
	// Sold To Name
	PurchasedIndicatorToName = 2
	// Remove Previously Reported K2 Segment Information
	PurchasedIndicatorRemove = 9
	// Agency Identifier not applicable
	AgencyIdentifierNotApplicable = 0
	// Agency Identifier Fannie Mae
	AgencyIdentifierFannieMae = 1
	// Agency Identifier Freddie Mac
	AgencyIdentifierFreddieMac = 2
	// Specialized Payment Indicator Balloon Payment
	SpecializedBalloonPayment = 1
	// Specialized Payment Indicator Deferred Payment
	SpecializedDeferredPayment = 2
	// ECOA Code Z
	ECOACodeZ = "Z"
)
View Source
const (
	// UnpackedSegmentLength indicates length of unpacked segment
	UnpackedRecordLength = 426
	// PackedSegmentLength indicates length of packed segment
	PackedRecordLength = 366

	// HeaderRecordName indicates name of header record
	HeaderRecordName = "header"
	// BaseSegmentName indicates name of base segment
	BaseSegmentName = "base"
	// TrailerRecordName indicates name of trailer record
	TrailerRecordName = "trailer"
	// PackedHeaderRecordName indicates name of packed header record
	PackedHeaderRecordName = "headerPacked"
	// PackedBaseSegmentName indicates length of name base record
	PackedBaseSegmentName = "basePacked"
	// PackedTrailerRecordName indicates length of name trailer record
	PackedTrailerRecordName = "trailerPacked"
	// TrailerIdentifier indicates record identifier of trailer record
	TrailerIdentifier = "TRAILER"
	// HeaderIdentifier indicates record identifier of header record
	HeaderIdentifier = "HEADER"
)
View Source
const (
	// J1SegmentLength indicates length of J1 segment
	J1SegmentLength = 100
	// J2SegmentLength indicates length of J2 segment
	J2SegmentLength = 200
	// K1SegmentLength indicates length of K1 segment
	K1SegmentLength = 34
	// K2SegmentLength indicates length of K2 segment
	K2SegmentLength = 34
	// K3SegmentLength indicates length of K3 segment
	K3SegmentLength = 40
	// K4SegmentLength indicates length of K4 segment
	K4SegmentLength = 30
	// L1SegmentLength indicates length of L1 segment
	L1SegmentLength = 54
	// N1SegmentLength indicates length of N1 segment
	N1SegmentLength = 146

	// J1SegmentLength indicates name of J1 segment
	J1SegmentName = "j1"
	// J2SegmentLength indicates name of J2 segment
	J2SegmentName = "j2"
	// K1SegmentLength indicates name of K1 segment
	K1SegmentName = "k1"
	// K2SegmentLength indicates name of K2 segment
	K2SegmentName = "k2"
	// K3SegmentLength indicates name of K3 segment
	K3SegmentName = "k3"
	// K4SegmentLength indicates name of K4 segment
	K4SegmentName = "k4"
	// L1SegmentLength indicates name of L1 segment
	L1SegmentName = "l1"
	// N1SegmentLength indicates name of N1 segment
	N1SegmentName = "n1"

	// J1SegmentIdentifier indicates segment identifier of J1 segment
	J1SegmentIdentifier = "J1"
	// J2SegmentIdentifier indicates segment identifier of J2 segment
	J2SegmentIdentifier = "J2"
	// K1SegmentIdentifier indicates segment identifier of K1 segment
	K1SegmentIdentifier = "K1"
	// K2SegmentIdentifier indicates segment identifier of K2 segment
	K2SegmentIdentifier = "K2"
	// K3SegmentIdentifier indicates segment identifier of K3 segment
	K3SegmentIdentifier = "K3"
	// K4SegmentIdentifier indicates segment identifier of K4 segment
	K4SegmentIdentifier = "K4"
	// L1SegmentIdentifier indicates segment identifier of L1 segment
	L1SegmentIdentifier = "L1"
	// N1SegmentIdentifier indicates segment identifier of N1 segment
	N1SegmentIdentifier = "N1"
)

Variables

This section is empty.

Functions

This section is empty.

Types

type BaseSegment

type BaseSegment struct {
	// Contains a value equal to the length of the block of data and must be reported when using the packed format or
	// when reporting variable length records.  This value includes the four bytes reserved for this field.
	// Report the standard IBM variable record length conventions.
	//
	// This field is not required when reporting fixed length, fixed block records.
	BlockDescriptorWord int `json:"blockDescriptorWord,omitempty"`

	// Contains a value equal to the length of the physical record.  This value includes the four bytes reserved
	// for this field.
	// The length of each segment should be included in the RDW.
	//
	// For example:
	//  Base Segment =   426
	//  J2 Segment   =   200
	//  K1 Segment   =    34
	//  RDW          =  0660
	//
	// For fixed block, the RDW will remain the same for each record.
	// For variable block, the RDW will change depending on the size of each record.
	RecordDescriptorWord int `json:"recordDescriptorWord" validate:"required"`

	// Report a constant of 1.
	ProcessingIndicator int `json:"processingIndicator"`

	// Contains date and time of actual account information update.
	// Format for packed date is 0MMDDYYYYHHMMSSs — where s is the sign.
	// Format is MMDDYYYYHHMMSS for character date.
	TimeStamp time.Time `json:"timeStamp"`

	// Used to uniquely identify a data furnisher.
	// Report your internal code to identify each branch, office, and/or credit central where information is verified.
	// For accounts reported by servicers, the Identification Number should refer to the current holder of the note.
	//
	// This number must be unique, at least 5 digits long, and should not include embedded blanks or special characters.
	// Entire field should never be zero, blank or 9 filled.
	//
	// This field must be consistent on a month-to-month basis to avoid duplication of information.
	// Notify consumer reporting agencies before adding, deleting, or changing the identifiers in this field.
	IdentificationNumber string `json:"identificationNumber" validate:"required"`

	// Report the internal cycle code for this account.
	// Field is required if reporting by cycles; otherwise blank fill.
	CycleIdentifier string `json:"cycleIdentifier,omitempty"`

	// Report the individual's complete and unique account number as extracted from your file.
	// Do not include embedded blanks or special characters.
	//
	// Do not report the Social Security Number, in whole or in part, within the Consumer Account Number.
	//
	// Account number scrambling and encryption methods for security purposes are permitted.
	// Contact the consumer reporting agencies for information regarding the Metro 2® scrambling techniques.
	ConsumerAccountNumber string `json:"consumerAccountNumber" validate:"required"`

	// Contains the one-character abbreviation for type of portfolio.  Values available:
	//
	//  C = Line of Credit
	//  I = Installment
	//  M = Mortgage
	//  O = Open
	//  R = Revolving
	//
	// Refer to the Glossary of Terms for definitions of each Portfolio Type.
	PortfolioType string `json:"portfolioType"`

	// Report the specific code that identifies the account classification.
	// Exhibit 1 provides a numeric listing of type codes that specify industry usage, and Exhibit 2 provides an alphabetic listing of type codes within their corresponding Portfolio Types.
	AccountType string `json:"accountType" validate:"required"`

	// Report the date the account was originally opened.
	// Retain the original Date Opened regardless of future activity, such as transfer, refinance, lost or stolen card, etc.
	//
	// Valid Dates Opened must be reported – field cannot be zero or blank filled, nor contain a date in the future.
	//
	// For companies who report returned checks, such as collection agencies, report the date of the check.
	//
	// Format for character date is MMDDYYYY.  Format for packed date is 0MMDDYYYYs — where s is the sign.
	// If the day is not available, use 01.
	DateOpened time.Time `json:"dateOpened"`

	// Report the following values in whole dollars only:
	//
	//  Line of Credit = Assigned credit limit*
	//  Installment = Zero fill
	//  Mortgage = Zero fill
	//  Open = Assigned credit limit*, if applicable; otherwise, zero fill
	//  Revolving = Assigned credit limit*
	//
	// * For closed accounts, continue to report the last assigned   credit limit.
	CreditLimit int `json:"creditLimit,omitempty"`

	// Report the following values in whole dollars only:
	//
	//  Line of Credit = Highest amount of credit utilized by the consumer
	//  Installment = Original amount of the loan excluding interest payments
	//  Mortgage = Original amount of the loan excluding interest payments
	//  Open = Highest amount of credit utilized by the consumer, if applicable
	//  Revolving = Highest amount of credit utilized by the consumer
	//
	// For companies who report returned checks, such as collection agencies, report the original amount of the check, excluding fees and interest.
	HighestCredit int `json:"highestCredit" validate:"required"`

	// Contains the duration of credit extended.
	//
	//  Line of Credit = Constant of LOC
	//  Installment = Number of months
	//  Mortgage = Number of years
	//  Open = Constant of 001, One payment as scheduled
	//  Revolving = Constant of REV
	//
	// Exhibit 3 provides the calculations necessary to convert Terms Duration to monthly.
	TermsDuration string `json:"termsDuration" validate:"required"`

	// Report the frequency for payments due.  Values available:
	//
	//  D  = Deferred (Refer to Note)
	//  P  = Single Payment Loan
	//  W  = Weekly
	//  B  = Biweekly
	//  E  = Semimonthly
	//  M   = Monthly
	//  L   = Bimonthly
	//  Q  = Quarterly
	//  T  = Tri-annually
	//  S  = Semiannually
	//  Y  = Annually
	//
	// Exhibit 3 provides definitions of the Terms Frequency Codes.
	// Note: When reporting Deferred loans, report the Deferred  Payment Start Date in the K4 Segment.
	TermsFrequency string `json:"termsFrequency,omitempty"`

	// Report the dollar amount of the scheduled monthly payment due for this reporting period, whether principal, interest only or a combination of the two.
	// When a balloon payment is also due during the reporting period, the balloon payment amount should be included to represent the entire monthly payment amount due.
	//
	// Report in whole dollars only.
	// When the account is paid in full, the Scheduled Monthly Payment Amount should be zero filled.
	//
	//  Line of Credit = Minimum amount due based on balance, not including any amounts past due
	//  Installment = Regular monthly payment
	//  Mortgage = Regular monthly payment, including the principal, interest, and escrow due this month
	//  Open = Zero fill
	//  Revolving = Minimum amount due based on balance, not including any amounts past due
	//
	// Exhibit 3 provides the calculations necessary to convert payment amounts to monthly.
	ScheduledMonthlyPaymentAmount int `json:"scheduledMonthlyPaymentAmount,omitempty"`

	// Report the dollar amount of the monthly payment actually received for this reporting period in whole dollars only.
	// If multiple payments are made during the reporting period, the total amount should be reported.
	ActualPaymentAmount int `json:"actualPaymentAmount,omitempty"`

	// Contains the status code that properly identifies the current condition of the account as of the Date of Account Information
	// Exhibit 4 provides a description of these codes.
	// The Payment Rating (Field 17B) must also be reported when the Account Status Code is 05, 13, 65, 88, 89, 94, or 95.
	// Special Comments (Field 19) may be used in conjunction with the Account Status to further define the account.
	// For examples of how Account Statuses, Payment Ratings and Special Comments interact.
	AccountStatus string `json:"accountStatus" validate:"required"`

	// When the Account Status (Field 17A) contains 05, 13, 65, 88, 89, 94 or 95, this field must also be reported.  The Payment Rating must be blank filled for all other Account Status Codes.
	// The Payment Rating contains a code that properly identifies whether the account was current, past due, in collections or  charged off prior to the status and within the current month’s reporting period.
	//
	// Values available:
	//  0 = Current account (0–29 days past the due date)
	//  1 = 30-59 days past the due date
	//  2 = 60-89 days past the due date
	//  3 = 90-119 days past the due date
	//  4 = 120-149 days past the due date
	//  5 = 150-179 days past the due date
	//  6 = 180 or more days past the due date
	//  G = Collection
	//  L = Charge-off
	//
	// For example, if the account was paid on March 22, 2019, but the consumer was 30 days past the due date on March 10, 2019 prior to paying the account, report Account Status Code = 13 and Payment Rating = 1.
	PaymentRating string `json:"paymentRating,omitempty"`

	// Contains up to 24 months of consecutive payment activity for the previous 24 reporting periods prior to the Date of Account Information (Field 24) being reported.
	// Report one month’s payment history in each byte from the left to right in most recent to least recent order.
	// The first byte should represent the Account Status Code reported in the previous reporting period.  Refer to Exhibit 5 for examples of reporting payment history, which includes examples for month-end reporters, as well as examples for reporters who submit data on other days of the month (e.g., 1st, 15th, etc.).  Values available:
	//
	//  0 = 0 payments past due (current account)
	//  1 = 30 - 59 days past due date
	//  2 =  60 - 89 days past due date
	//  3 =  90 - 119 days past due date
	//  4 =  120 - 149 days past due date
	//  5 =  150 - 179 days past due date
	//  6 =  180 or more days past due date
	//  B =  No payment history available prior to this time – either because the account was not open or because the payment history cannot be furnished.  A “B” may not be embedded within other values.
	//  D =  No payment history available this month.   “D” may be embedded in the payment pattern.
	//  E =  Zero balance and current account           (Applies to Credit Cards and Lines of Credit)
	//  G =  Collection
	//  H =  Foreclosure Completed
	//  J =  Voluntary Surrender
	//  K = Repossession
	//  L =  Charge-off
	//
	// No other values are acceptable in this field.
	// If a full 24 months of history are not available for reporting, the ending positions of this field should be B-filled.
	// The Payment History Profile is intended to be used to report monthly history, regardless of the Terms Frequency.
	// Reporting of the Payment History Profile provides a method for automated correction of erroneously reported history.
	//
	// For important information:
	// • Paid accounts
	// • First-time reporters
	PaymentHistoryProfile string `json:"paymentHistoryProfile" validate:"required"`

	// Used in conjunction with Account Status and Payment Rating (to further define the account (e.g., closed accounts or adjustments pending).
	// The Special Comment Code must be reported each month as long as the condition applies.
	// If more than one Special Comment applies to an account, it is the data furnisher’s decision to report the comment that is deemed most important from a business perspective for the current reporting period.
	//
	// If no Special Comment is applicable, blank fill.
	//
	// Exhibit 6 provides a list of available comments by category within Portfolio Type and Exhibit 7 provides a list of codes in alphabetical sequence.
	// Both exhibits include definitions and usage guidelines.
	//
	// For examples of how Account Statuses, Payment Ratings and Special Comments interact.
	SpecialComment string `json:"specialComment,omitempty"`

	// Allows the reporting of a condition that is required for legal compliance.
	// This condition may refer to accounts closed at consumer’s request, accounts in dispute under the Fair Credit Reporting Act (FCRA), the Fair Debt Collection Practices Act (FDCPA) or the Fair Credit Billing Act (FCBA).
	//
	// The code should be reported one time and will remain on file until another Compliance Condition Code or the XR (Removal code) is reported.  As an option, the code may be reported each month as long as the condition applies.
	// Regardless of the method of reporting, the code will be deleted only when another Compliance Condition Code or the XR (Removal code) is reported.
	//
	// Exhibit 8 provides a list of Compliance Condition Codes and examples that demonstrate how to report these codes.
	// For questions about the use of Compliance Condition Codes or how long to report them, data furnishers should refer to their internal policies and procedures.
	ComplianceConditionCode string `json:"complianceConditionCode,omitempty"`

	// Report the outstanding current balance on the account as of the Date of Account Information.
	//
	// The Current Balance should contain the principal balance including Balloon Payment Amounts (when applicable), as well as applicable interest, late charges, fees, insurance payments and escrow that are due during the current reporting period.
	// The Current Balance may exceed the Highest Credit, Original Loan Amount or Credit Limit.
	//
	// The Current Balance should not include future interest, escrow, fees or insurance payments.
	//
	// This amount, which should be reported in whole dollars only, may increase or decline from month to month.
	// Credit balances (negative balances) should be reported as zero.
	CurrentBalance int `json:"currentBalance" validate:"omitempty"`

	// Report the total amount of payments that are 30 days or more past due in whole dollars only.
	// This field should include late charges and fees, if applicable.
	// Do not include current amount due in this field.
	//
	// Note: If the Account Status is current (Status Code 11), this field should be zero.
	AmountPastDue int `json:"amountPastDue,omitempty"`

	// For Status Codes 64 and 97 (all portfolio types), report the original amount charged to loss, regardless of the declining balance.
	// Report whole dollars only.
	//
	// If payments are received from the consumer, report the outstanding balance in the Current Balance and Amount Past Due fields.
	OriginalChargeOffAmount int `json:"originalChargeOffAmount,omitempty"`

	// All account information in the Base Segment, such as Account Status and Current Balance, must be reported as of the date in this field.
	//
	// For Account Status Codes 11, 71, 78, 80, 82-84, 88, 89, 93-97, DA and DF, report a date within the current month’s reporting period, as noted below:
	//
	// • Cycle Reporters – Report the date of the current month’s billing cycle.  This method is preferred to facilitate accurate and timely reporting of account information.
	// • Monthly Reporters – Report the date within the current month’s reporting period that represents the most recent update to the account, such as mid-month (03/15/2019) or end of month (03/31/2019).  The Date of Account Information may represent the consumer’s billing date as long as the date is within the current month’s reporting period.
	// 						 A historic or future date should not be reported.
	//
	// For Account Status Codes 13 and 61–65, report the date paid, unless the account was closed due to inactivity; then report the date within the current reporting period when the account was closed to further charges.
	// For accounts reported with bankruptcy Consumer Information Indicators, refer to Frequently Asked Questions 27 and 28 for guidelines on reporting the Date of Account Information.
	//
	// Format for character date is MMDDYYYY.  Format for packed date is 0MMDDYYYYs – where s is the sign.
	// Notes: This date must not reflect a future date.
	// For guidelines on reporting paid, closed or inactive accounts, refer to FAQs 39, 40 and 41.
	DateAccountInformation time.Time `json:"dateAccountInformation" validate:"required"`

	// This date is used to ensure compliance with the Fair Credit Reporting Act.
	// The date in the Date of First Delinquency field must be determined each reporting period based on the following hierarchy:
	//
	// 1. For Account Status Codes 61-65, 71, 78, 80, 82-84, 88-89 and 93-97, report the date of the first 30-day delinquency that led to the status being reported.  This date should be 30 days after the Due Date.  If a delinquent account becomes current, the Date of First Delinquency should be zero filled.  Then if the account goes delinquent again, the Date of First Delinquency starts over with the new first delinquency date.
	// 2. For Account Status Codes 05 and 13, if the Payment Rating is 1, 2, 3, 4, 5, 6, G or L, report the date of the first 30-day delinquency that led to the Payment Rating being reported.  This date should be 30 days after the Due Date.
	// 3. For Consumer Information Indicators A-H and Z (Bankruptcies), 1A (Personal Receivership) and V-Y (Reaffirmation of Debt Rescinded with Bankruptcy Chapters), if the account is current (Account Status Code 11 or Account Status Code 05 or 13 with Payment Rating 0), report the date of the bankruptcy/personal receivership petition or notification.  Even though the account is not delinquent, this date is required for purging purposes.
	//    Notes: In hierarchy rule #3, Account Status 13 is included for scenarios when merchandise is redeemed.  Refer to FAQ 31 for further guidance.
	//           Consumer Information Indicators W, X & Y are obsolete as of September 2010 and may no longer be reported.
	//
	// If none of the conditions listed in the above hierarchy apply, the Date of First Delinquency should be zero filled.
	// The Date of First Delinquency is used by the consumer reporting agencies for purging purposes.  Format for character date is MMDDYYYY.  Format for packed date is 0MMDDYYYYs — where s is the sign.
	// Notes:
	// • Refer to Exhibit 9 for detailed reporting instructions, examples and excerpts from the Fair Credit Reporting Act.
	// • First-time reporters should refer to Frequently Asked Question 22 for important information.
	DateFirstDelinquency time.Time `json:"dateFirstDelinquency,omitempty"`

	// For all portfolio types, contains the date the account was closed to further purchases, paid in full, transferred or sold.  For Line of Credit, Open or Revolving accounts, there may be a balance due.
	//
	// Format for character date is MMDDYYYY.
	// Format for packed date is 0MMDDYYYYs — where s is the sign.
	// If not applicable, zero fill.
	DateClosed time.Time `json:"dateClosed,omitempty"`

	// Report the date the most recent payment was received, whether full or partial payment is made.
	//
	// Format for character date is MMDDYYYY.
	// Format for packed date is 0MMDDYYYYs — where s is the sign.
	// If the day is not available, use 01.
	DateLastPayment time.Time `json:"dateLastPayment,omitempty"`

	// Contains one of the following values that designates the interest type:
	//
	//  F = Fixed
	//  V = Variable/Adjustable
	//
	// If indicator not available or unknown, blank fill.
	// Note: Report indicator ‘V’ for loans where the interest rate will be variable at some point, even if the interest rate starts as fixed.
	InterestTypeIndicator string `json:"interestTypeIndicator"`

	// Report the last name of the primary consumer.
	// Titles and prefixes should not be reported.
	//
	// If the surname contains multiple names, such as Paternal Name-Maternal Name, hyphenate the surnames.
	// For example, “SMITH-JONES” or “MARTINEZ-REYES” requires the hyphen.
	//
	// If the surname contains separate words, the hyphen is not required.
	// For example, report “VAN DYKE” or “DE LA CRUZ” with a space between each word.
	//
	// Other than the hyphen, do not report special characters in any of the Consumer Name fields.
	//
	// The Generation Code should be reported in Generation Code.
	//
	// Notes: Do not report minors.
	//        The name fields should not contain messages, such as “Parent of”, “Baby”, “Daughter”, “Child”, etc.
	//        Do not report trustee or estate accounts.
	//        In cases where the debt is included in a revocable trust and  the consumer retains contractual responsibility, report the consumer’s Full Name, Address, Social Security Number, and Date of Birth within the Base Segment fields.
	//        Do not report the name of the trust.
	Surname string `json:"surname" validate:"required"`

	// Report the full first name of the primary consumer.
	// Names should not be abbreviated.
	// Examples: Report first name “JUNIOR” (not “JR”); report “ROBERT” (not “ROBT”).
	//
	// If reporting multiple first names, hyphenate the first names.
	//
	// Note: If a consumer uses only initials for first and middle names (e.g., A.J.), the first name initial should be reported in the First Name field (e.g., A)            and the middle initial should be reported in the            Middle Name field (e.g., J).
	FirstName string `json:"firstName" validate:"required"`

	// Report the middle name or middle initial of the primary consumer, if available.
	//
	// If reporting multiple middle names, hyphenate the middle names.
	MiddleName string `json:"middleName,omitempty"`

	// Used to distinguish Jr., Sr., II, III, etc.  If not applicable, blank fill.
	// Values available:
	//  J = Junior
	//  3 = III
	//  6 = VI
	//  9 = IX
	//  S = Senior
	//  4 = IV
	//  7 = VII
	//  2 = II
	//  5 = V
	//  8 = VIII
	GenerationCode string `json:"generationCode,omitempty"`

	// Report the Social Security Number (SSN) of the primary consumer.
	// Report only valid U.S.-issued SSNs.
	//
	// Reporting of this information is required as the Social Security Number greatly enhances accuracy in matching to the correct consumer.
	// If the consumer does not have a SSN or one is not available for reporting, zero- or 9-fill all positions.
	//
	// Notes:
	//   If the Social Security Number is not reported, the Date of Birth is required to be reported.
	//   Do not report Individual Tax Identification Numbers  (ITINs) in this field.  ITINs do not prove identity outside the tax system and should not be offered or accepted as identification for non-tax purposes, per the Social Security Administration.
	//   Do not report Credit Profile Numbers (CPNs) in this field.  The CPN should not be used for credit reporting purposes and does not replace the Social Security Number.
	SocialSecurityNumber int `json:"socialSecurityNumber" validate:"required"`

	// Report the full Date of Birth of the primary consumer, including the month, day and year.
	// Reporting of this information is required as the Date of Birth greatly enhances accuracy in matching to the correct consumer.
	// Format for character date is MMDDYYYY.  Format for packed date is 0MMDDYYYYs — where s is the sign.
	//
	// Notes:  If the Date of Birth is not reported, the Social Security Number is required to be reported.
	//         When reporting Authorized Users (ECOA Code 3), the full Date of Birth (MMDDYYYY) must be reported for all newly-added Authorized Users on all pre-existing and newly-opened accounts, even if the Social Security Number is reported.
	//         Do not report accounts of consumers who are too young to enter into a binding contract.
	DateBirth time.Time `json:"dateBirth" validate:"required"`

	// Contains the telephone number of the primary consumer (Area Code + 7 digits).
	TelephoneNumber int64 `json:"telephoneNumber"`

	// Defines the relationship of the primary consumer to the account and designates the account as joint, individual, etc., in compliance with the Equal Credit Opportunity Act.
	//
	// Exhibit 10 provides a list of ECOA Codes, their definitions and usage.
	//
	// For important information:
	// • Guidelines on reporting consumers who are personally liable for business accounts.
	// • Usage guidelines on ECOA Codes T (Terminated) and Z (Delete Consumer).
	//
	// Note: Codes 0 (Undesignated), 4 (Joint) and 6 (On-Behalf-Of) are obsolete as of September 2003 and may no longer be reported.
	ECOACode string `json:"ecoaCode" validate:"required"`

	// Contains a value that indicates a special condition of the account that applies to the primary consumer.
	//
	// This special condition may be that a bankruptcy was filed, discharged, dismissed or withdrawn; a debt was reaffirmed; or the consumer cannot be located or is now located.
	//
	// The indicator should be reported one time and will remain on file until another Consumer Information Indicator or a Removal value is reported.
	// As an option, the indicator may be reported each month as long as the condition applies.
	//
	// Regardless of the method of reporting, the indicator will be deleted only when another Consumer Information Indicator or a Removal value (Q, S, U) is reported.
	//
	// Exhibit 11 provides a list of Consumer Information Indicators and examples that demonstrate how to report these codes.
	//
	// For reporting guidelines, refer to Frequently Asked Questions 23 through 32 (bankruptcy) and 61 (personal receivership).
	ConsumerInformationIndicator string `json:"consumerInformationIndicator,omitempty"`

	// Contains the standard two-character country abbreviation.
	//
	// Exhibit 12 provides a list of the Country Codes.
	CountryCode string `json:"countryCode"`

	// Contains billing/mailing address for the primary consumer.
	// If the consumer has a U.S. address and a foreign address, report the U.S. address.
	// If the consumer has never used the U.S. address as a billing/mailing address (e.g., a property address), report the foreign address.
	//
	// If the billing/mailing address does not belong specifically to the consumer, such as a financial counseling site or bill paying service, report the consumer’s home address.
	//
	// The First Line of Address usually includes street number, direction, street name, and type of thoroughfare.
	//
	// If the billing/mailing address is a PO Box or Rural Route, include Box or Route followed by the number (e.g., PO Box 100).
	// Do not report both a street address and a PO Box.
	//
	// If the billing/mailing address is a private mailbox (PMB), the street address should be reported in the First Line of Address (e.g., 5678 Main Street).
	// The PMB number should be reported in the Second Line of Address (e.g., PMB 1234).
	// As an alternative, the entire address can be reported in the First Line of Address; for example, 5678 Main Street PMB 1234.
	//
	// Eliminate internal messages such as: “Do not mail”, “Attorney”, “Charge-off”, “Chapter 13”, “Fraud”, “Trustee”, “Estate of”, “Care of”, “M/R” (Mail Returned), etc.
	//
	// Exhibit 13 provides general rules for address reporting.
	// Do not enter data furnisher's address in this field.
	FirstLineAddress string `json:"firstLineAddress" validate:"required"`

	// Contains second line of address, if needed, such as apartment or unit number, or private mailbox number (PMB).
	//
	// Eliminate internal messages such as: “Do not mail”, “Attorney”, “Charge-off”, “Chapter 13”, “Fraud”, “Trustee”, or “Estate of”, “Care of”, “M/R” (Mail Returned), etc.
	SecondLineAddress string `json:"secondLineAddress,omitempty"`

	// Contains city name for address of primary consumer.
	// Truncate rightmost positions if city name is greater than 20 characters or use standard 13-character U.S. Postal Service city abbreviations.
	City string `json:"city" validate:"required"`

	// Contains the standard U.S. Postal Service state abbreviation for the address of the primary consumer.
	//
	// Exhibit 14 provides a list of State Codes.
	State string `json:"state" validate:"required"`

	// Report the Zip Code of the primary consumer’s address.
	// Use entire field if reporting 9-digit zip codes.
	// Otherwise, leftjustify and blank fill.
	ZipCode string `json:"zipCode" validate:"required"`

	// Contains one of the following values for the address reported in fields 40-44:
	//
	//  C  =  Confirmed/Verified address Note: Value ‘C’ enables reporting a confirmed or verified address after receiving an address discrepancy notification from a consumer reporting agency.  Report ‘C’ one time after the address is confirmed.
	//  Y = Known to be address of primary consumer
	//  N = Not confirmed address
	//  M = Military address
	//  S  =  Secondary Address
	//  B = Business address — not consumer's residence
	//  U = Non-deliverable address/Returned mail
	//  D  = Data reporter’s default address
	//  P  =  Bill Payer Service  — not consumer’s residence
	//
	// If indicator not available or unknown, blank fill.
	AddressIndicator string `json:"addressIndicator"`

	// Contains the one-character residence code of the address reported in fields 40-44.
	//
	//  Values available:
	//    O = Owns
	//    R = Rents
	//
	// If not available or unknown, blank fill.
	ResidenceCode string `json:"residenceCode"`
	// contains filtered or unexported fields
}

BaseSegment holds the base segment

func (*BaseSegment) AddApplicableSegment

func (r *BaseSegment) AddApplicableSegment(s Segment) error

AddApplicableSegment will add new applicable segment into record

func (*BaseSegment) BlockSize

func (r *BaseSegment) BlockSize() int

BlockSize returns size of block

func (*BaseSegment) GetSegments

func (r *BaseSegment) GetSegments(name string) []Segment

GetSegments returns list of applicable segments by segment name

func (*BaseSegment) Length

func (r *BaseSegment) Length() int

Length returns size of segment

func (*BaseSegment) MarshalJSON

func (r *BaseSegment) MarshalJSON() ([]byte, error)

MarshalJSON returns JSON blob

func (*BaseSegment) Name

func (r *BaseSegment) Name() string

Name returns name of base segment

func (*BaseSegment) Parse

func (r *BaseSegment) Parse(record string) (int, error)

Parse takes the input record string and parses the base segment values

func (*BaseSegment) String

func (r *BaseSegment) String() string

String writes the base segment struct to a 426 character string.

func (*BaseSegment) UnmarshalJSON

func (r *BaseSegment) UnmarshalJSON(data []byte) error

UnmarshalJSON parses a JSON blob

func (*BaseSegment) Validate

func (r *BaseSegment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*BaseSegment) ValidateIdentificationNumber

func (r *BaseSegment) ValidateIdentificationNumber() error

func (*BaseSegment) ValidateInterestTypeIndicator

func (r *BaseSegment) ValidateInterestTypeIndicator() error

func (*BaseSegment) ValidatePaymentHistoryProfile

func (r *BaseSegment) ValidatePaymentHistoryProfile() error

func (*BaseSegment) ValidatePaymentRating

func (r *BaseSegment) ValidatePaymentRating() error

func (*BaseSegment) ValidatePortfolioType

func (r *BaseSegment) ValidatePortfolioType() error

func (*BaseSegment) ValidateTelephoneNumber

func (r *BaseSegment) ValidateTelephoneNumber() error

func (*BaseSegment) ValidateTermsDuration

func (r *BaseSegment) ValidateTermsDuration() error

func (*BaseSegment) ValidateTermsFrequency

func (r *BaseSegment) ValidateTermsFrequency() error

type HeaderRecord

type HeaderRecord struct {
	// Contains a value equal to the length of the block of data and must be reported when using the packed format or
	// when reporting variable length records.  This value includes the four bytes reserved for this field.
	// Report the standard IBM variable record length conventions.
	//
	// This field is not required when reporting fixed length, fixed block records.
	BlockDescriptorWord int `json:"blockDescriptorWord,omitempty"`

	// Contains a value equal to the length of the physical record.
	// This value includes the four bytes reserved for this field.
	// The recording technique is Numeric for the 426 format and Binary for the 366 format.
	//
	//  • Numeric: The entire four bytes are used. Example: F0F4F2F6.
	//  • Binary: The hexadecimal value should be in the first two bytes of the field and the last two bytes should contain binary zeros. Example: 016E0000.
	//
	// If fixed-length records are being reported, the Header Record should be the same length as all the data records.
	// The Header Record should be padded with blanks to fill the needed number of positions.
	RecordDescriptorWord int `json:"recordDescriptorWord" validate:"required"`

	// Contains a constant of HEADER, which is used to identify this record.
	RecordIdentifier string `json:"recordIdentifier" validate:"required"`

	// Contains the cycle identifier for the information being reported, if reporting by cycles.
	// If data contains more than	one cycle, report the first cycle identifier found on the data.
	CycleIdentifier string `json:"cycleIdentifier,omitempty"`

	// Contains a unique identification number assigned by this consumer reporting agency.
	InnovisProgramIdentifier string `json:"innovisProgramIdentifier,omitempty"`

	// Contains a unique identification number assigned by this consumer reporting agency.
	EquifaxProgramIdentifier string `json:"equifaxProgramIdentifier,omitempty"`

	// Contains a unique identification number assigned by this consumer reporting agency.
	ExperianProgramIdentifier string `json:"experianProgramIdentifier,omitempty"`

	// Contains a unique identification number assigned by this consumer reporting agency.
	TransUnionProgramIdentifier string `json:"transUnionProgramIdentifier,omitempty"`

	// Signifies date of most recent update to accounts.
	// If accounts are updated on different dates, use most recent.
	// A future date should not be reported.
	// Format is MMDDYYYY.
	ActivityDate time.Time `json:"activityDate" validate:"required"`

	// Contains the date the media was generated.
	// A future date should not be reported.
	// Format is MMDDYYYY.
	DateCreated time.Time `json:"dateCreated" validate:"required"`

	// Contains the date your reporting format was developed.
	// Format is MMDDYYYY.
	// If the day is not available, use 01.
	ProgramDate time.Time `json:"programDate"`

	// Contains the last date your reporting format was revised.
	// Format is MMDDYYYY.
	// If the day is not available, use 01.
	ProgramRevisionDate time.Time `json:"programRevisionDate"`

	// Contains the name of the processing company sending the data; i.e., data furnisher or processor.
	// If multiple Header Records are provided, the Reporter Name on the second and subsequent Headers may be repeated or blank filled.
	ReporterName string `json:"reporterName" validate:"required"`

	// Contains the complete mailing address of the processing company; i.e., street address, city, state and zip code.
	ReporterAddress string `json:"reporterAddress" validate:"required"`

	// Contains the telephone number (Area Code + number) of the company sending the data; i.e., data furnisher or processor.
	ReporterTelephoneNumber int64 `json:"reporterTelephoneNumber"`

	// Contains the name of the software vendor that provided the Metro 2® Format software.
	SoftwareVendorName string `json:"softwareVendorName,omitempty"`

	// Contains the version number of the Metro 2® Format software.
	SoftwareVersionNumber string `json:"softwareVersionNumber,omitempty"`

	// Contains a unique identification number assigned by this consumer reporting agency.
	PRBCProgramIdentifier string `json:"prbcProgramIdentifier,omitempty"`
	// contains filtered or unexported fields
}

HeaderRecord holds the header record

func (*HeaderRecord) AddApplicableSegment

func (r *HeaderRecord) AddApplicableSegment(s Segment) error

AddApplicableSegment will add new applicable segment into record

func (*HeaderRecord) BlockSize

func (r *HeaderRecord) BlockSize() int

BlockSize returns size of block

func (*HeaderRecord) GetSegments

func (r *HeaderRecord) GetSegments(string) []Segment

GetSegments returns list of applicable segments by segment name

func (*HeaderRecord) Length

func (r *HeaderRecord) Length() int

Length returns size of segment

func (*HeaderRecord) Name

func (r *HeaderRecord) Name() string

Name returns name of header record

func (*HeaderRecord) Parse

func (r *HeaderRecord) Parse(record string) (int, error)

Parse takes the input record string and parses the header record values

func (*HeaderRecord) String

func (r *HeaderRecord) String() string

String writes the header record struct to a 426 character string.

func (*HeaderRecord) Validate

func (r *HeaderRecord) Validate() error

Validate performs some checks on the record and returns an error if not Validated

type J1Segment

type J1Segment struct {
	// Contains a constant of J1.
	SegmentIdentifier string `json:"segmentIdentifier"  validate:"required"`

	// Report the last name of the associated consumer. Titles and prefixes should not be reported.
	// If the surname contains multiple names, such as Paternal Name-Maternal Name, hyphenate the surnames.
	// For example, “SMITH-JONES” or “MARTINEZ-REYES” requires the hyphen.
	// If the surname contains separate words, the hyphen is not required.
	// For example, report “VAN DYKE” or “DE LA CRUZ” with a space between each word.
	// Other than the hyphen, do not report special characters in any of the Consumer Name fields.
	// The Generation Code should be reported in Field 6.
	// Notes: Do not report minors. The name fields should not
	//  contain messages, such as “Parent of”, “Baby”,
	//  “Daughter”, “Child”, etc.
	//  Do not report trustee or estate accounts. In cases
	//  where the debt is included in a revocable trust and
	//  the consumer retains contractual responsibility,
	//  report the consumer’s Full Name, Address, Social
	//  Security Number, and Date of Birth within the J1
	//  Segment fields. Do not report the name of the
	//  trust.
	Surname string `json:"surname"  validate:"required"`

	// Report the full first name of the associated consumer. Names should not be abbreviated.
	// Examples: Report first name “JUNIOR” (not “JR”); report “ROBERT” (not “ROBT”).
	// If reporting multiple first names, hyphenate the first names.
	// Note: If a consumer uses only initials for first and
	//  middle names (e.g., A.J.), the first name initial
	//  should be reported in the First Name field
	//  (e.g., A) and the middle initial should be reported
	//  in the Middle Name field (e.g., J).
	FirstName string `json:"firstName"  validate:"required"`

	// Report the middle name or middle initial of the associated consumer, if available.
	// If reporting multiple middle names, hyphenate the middle names.
	MiddleName string `json:"middleName,omitempty"`

	// Used to distinguish Junior, Senior, II, III, IV, etc.
	// If not applicable, blank fill.
	// Values available:
	//  J = Junior 3 = III 6 = VI 9 = IX
	//  S = Senior 4 = IV 7 = VII
	//  2 = II 5 = V 8 = VIII
	GenerationCode string `json:"generationCode,omitempty"`

	// Report the Social Security Number (SSN) of the associated consumer. Report only valid U.S.-issued SSNs.
	// Reporting of this information is required as the Social Security Number greatly enhances accuracy in matching to the correct consumer.
	// If the consumer does not have a SSN or one is not available for reporting, zero- or 9-fill all positions.
	// Notes:
	//  If the Social Security Number is not reported, the Date of Birth is required to be reported.
	//  Do not report Individual Tax Identification Numbers (ITINs) in this field.
	//  ITINs do not prove identity outside the tax system and should not be offered or accepted as identification for non-tax purposes,
	//   per the Social Security Administration.
	//  Do not report Credit Profile Numbers (CPNs) in this field.
	//  The CPN should not be used for credit reporting purposes and does not replace the Social Security Number.
	SocialSecurityNumber int `json:"socialSecurityNumber"  validate:"required"`

	// Report the full Date of Birth of the associated consumer, including the month, day and year.
	// Reporting of this information is required as the Date of Birth greatly enhances accuracy in matching to the correct consumer.
	// Format is MMDDYYYY.
	// Notes:
	//  If the Date of Birth is not reported, the Social Security Number is required to be reported.
	//  When reporting Authorized Users (ECOA Code 3), the full Date of Birth (MMDDYYYY) must be reported for all newly-added
	//  Authorized Users on all pre-existing and newly-opened accounts, even if the Social Security Number is reported.
	//  Do not report accounts of consumers who are too young to enter into a binding contract.
	DateBirth time.Time `json:"dateBirth"  validate:"required"`

	// Contains the telephone number of the associated consumer (Area Code + 7 digits).
	TelephoneNumber int64 `json:"telephoneNumber"`

	// Defines the relationship of the associated consumer to the account and designates the account as joint, individual, etc.,
	// in compliance with the Equal Credit Opportunity Act.
	// Exhibit 10 provides a list of ECOA Codes, their definitions and usage.
	// For important information:
	// • Guidelines on reporting consumers who are personally liable for business accounts
	// • Usage guidelines on ECOA Codes T (Terminated) and Z (Delete Consumer)
	// Note:
	//   Codes 0 (Undesignated), 4 (Joint) and 6 (On-Behalf-Of) are obsolete as of September 2003 and may no longer be reported.
	ECOACode string `json:"ecoaCode"  validate:"required"`

	// Contains a value that indicates a special condition of the account that applies to the associated consumer.
	// This special condition may be that a bankruptcy was filed, discharged, dismissed or withdrawn; a debt was reaffirmed; or the consumer cannot be located or is now located.
	// The indicator should be reported one time and will remain on file until another Consumer Information Indicator or a Removal value is reported.
	// As an option, the indicator may be reported each month as long as the condition applies.
	// Regardless of the method of reporting, the indicator will be deleted only when another Consumer Information Indicator or a Removal value (Q, S, U) is reported.
	// Exhibit 11 provides a list of Consumer Information Indicators and examples that demonstrate how to report these codes.
	ConsumerInformationIndicator string `json:"consumerInformationIndicator,omitempty"`
	// contains filtered or unexported fields
}

J1Segment holds the j1 segment

func (*J1Segment) Length

func (s *J1Segment) Length() int

Length returns size of segment

func (*J1Segment) Name

func (s *J1Segment) Name() string

Name returns name of j1 segment

func (*J1Segment) Parse

func (s *J1Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the j1 segment values

func (*J1Segment) String

func (s *J1Segment) String() string

String writes the j1 segment struct to a 100 character string.

func (*J1Segment) Validate

func (s *J1Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*J1Segment) ValidateGenerationCode

func (s *J1Segment) ValidateGenerationCode() error

validation of generation code

func (*J1Segment) ValidateTelephoneNumber

func (s *J1Segment) ValidateTelephoneNumber() error

validation of telephone number

type J2Segment

type J2Segment struct {
	// Contains a constant of J2.
	SegmentIdentifier string `json:"segmentIdentifier" validate:"required"`

	// Report the last name of the associated consumer. Titles and prefixes should not be reported.
	// If the surname contains multiple names, such as Paternal Name-Maternal Name, hyphenate the surnames.
	// For example, “SMITH-JONES” or “MARTINEZ-REYES” requires the hyphen.
	// If the surname contains separate words, the hyphen is not required.
	// For example, report “VAN DYKE” or “DE LA CRUZ” with a space between each word.
	// Other than the hyphen, do not report special characters in any of the Consumer Name fields.
	// The Generation Code should be reported in Field 6.
	// Notes: Do not report minors. The name fields should not
	//  contain messages, such as “Parent of”, “Baby”,
	//  “Daughter”, “Child”, etc.
	//  Do not report trustee or estate accounts. In cases
	//  where the debt is included in a revocable trust and
	//  the consumer retains contractual responsibility,
	//  report the consumer’s Full Name, Address, Social
	//  Security Number, and Date of Birth within the J2
	//  Segment fields. Do not report the name of the
	//  trust.
	Surname string `json:"surname" validate:"required"`

	// Report the full first name of the associated consumer. Names should not be abbreviated.
	// Examples: Report first name “JUNIOR” (not “JR”); report “ROBERT” (not “ROBT”).
	// If reporting multiple first names, hyphenate the first names.
	// Note: If a consumer uses only initials for first and
	//  middle names (e.g., A.J.), the first name initial
	//  should be reported in the First Name field
	//  (e.g., A) and the middle initial should be reported
	//  in the Middle Name field (e.g., J).
	FirstName string `json:"firstName" validate:"required"`

	// Report the middle name or middle initial of the associated consumer, if available.
	// If reporting multiple middle names, hyphenate the middle names.
	MiddleName string `json:"middleName,omitempty"`

	// Used to distinguish Junior, Senior, II, III, IV, etc.
	// If not applicable, blank fill.
	// Values available:
	//  J = Junior 3 = III 6 = VI 9 = IX
	//  S = Senior 4 = IV 7 = VII
	//  2 = II 5 = V 8 = VIII
	GenerationCode string `json:"generationCode,omitempty"`

	// Report the Social Security Number (SSN) of the associated consumer. Report only valid U.S.-issued SSNs.
	// Reporting of this information is required as the Social Security Number greatly enhances accuracy in matching to the correct consumer.
	// If the consumer does not have a SSN or one is not available for reporting, zero- or 9-fill all positions.
	// Notes:
	//  If the Social Security Number is not reported, the Date of Birth is required to be reported.
	//  Do not report Individual Tax Identification Numbers (ITINs) in this field.
	//  ITINs do not prove identity outside the tax system and should not be offered or accepted as identification for non-tax purposes,
	//   per the Social Security Administration.
	//  Do not report Credit Profile Numbers (CPNs) in this field.
	//  The CPN should not be used for credit reporting purposes and does not replace the Social Security Number.
	SocialSecurityNumber int `json:"socialSecurityNumber" validate:"required"`

	// Report the full Date of Birth of the associated consumer, including the month, day and year.
	// Reporting of this information is required as the Date of Birth greatly enhances accuracy in matching to the correct consumer.
	// Format is MMDDYYYY.
	// Notes:
	//  If the Date of Birth is not reported, the Social Security Number is required to be reported.
	//  When reporting Authorized Users (ECOA Code 3), the full Date of Birth (MMDDYYYY) must be reported for all newly-added
	//  Authorized Users on all pre-existing and newly-opened accounts, even if the Social Security Number is reported.
	//  Do not report accounts of consumers who are too young to enter into a binding contract.
	DateBirth time.Time `json:"dateBirth" validate:"required"`

	// Contains the telephone number of the associated consumer (Area Code + 7 digits).
	TelephoneNumber int64 `json:"telephoneNumber"`

	// Defines the relationship of the associated consumer to the account and designates the account as joint, individual, etc.,
	// in compliance with the Equal Credit Opportunity Act.
	// Exhibit 10 provides a list of ECOA Codes, their definitions and usage.
	// For important information:
	// • Guidelines on reporting consumers who are personally liable for business accounts
	// • Usage guidelines on ECOA Codes T (Terminated) and Z (Delete Consumer)
	// Note:
	//   Codes 0 (Undesignated), 4 (Joint) and 6 (On-Behalf-Of) are obsolete as of September 2003 and may no longer be reported.
	ECOACode string `json:"ecoaCode" validate:"required"`

	// Contains a value that indicates a special condition of the account that applies to the associated consumer.
	// This special condition may be that a bankruptcy was filed, discharged, dismissed or withdrawn; a debt was reaffirmed; or the consumer cannot be located or is now located.
	// The indicator should be reported one time and will remain on file until another Consumer Information Indicator or a Removal value is reported.
	// As an option, the indicator may be reported each month as long as the condition applies.
	// Regardless of the method of reporting, the indicator will be deleted only when another Consumer Information Indicator or a Removal value (Q, S, U) is reported.
	// Exhibit 11 provides a list of Consumer Information Indicators and examples that demonstrate how to report these codes.
	ConsumerInformationIndicator string `json:"consumerInformationIndicator,omitempty"`

	// Contains the standard two-character country abbreviation.
	CountryCode string `json:"countryCode"`

	// Contains billing/mailing address for the associated consumer.
	// If the consumer has a U.S. address and a foreign address, report the U.S. address. If the consumer has never used the U.S.
	// address as a billing/mailing address (e.g., a property address), report the foreign address.
	// If the billing/mailing address does not belong specifically to the consumer, such as a financial counseling site or bill paying service, report the consumer’s home address.
	// The First Line of Address usually includes street number, direction, street name, and type of thoroughfare.
	// If the billing/mailing address is a PO Box or Rural Route, include Box or Route followed by the number (e.g., PO Box 100).
	// Do not report both a street address and a PO Box.
	// If the billing/mailing address is a private mailbox (PMB), the street address should be reported in the First Line of Address (e.g., 5678 Main Street).
	// The PMB number should be reported in the Second Line of Address (e.g., PMB 1234).
	// As an alternative, the entire address can be reported in the First Line of Address; for example, 5678 Main Street PMB 1234.
	// Eliminate internal messages such as: “Do not mail”, “Attorney”, “Charge-off”, “Chapter 13”, “Fraud”, “Trustee”, “Estate of”, “Care of”, “M/R” (Mail Returned), etc.
	// Do not enter data furnisher's address in this field.
	FirstLineAddress string `json:"firstLineAddress" validate:"required"`

	// Contains second line of address, if needed, such as apartment or unit number, or private mailbox number (PMB).
	// Eliminate internal messages such as: “Do not mail”, “Attorney”, “Charge-off”, “Chapter 13”, “Fraud”, “Trustee”, “Estate of”, “Care of”, “M/R” (Mail Returned), etc.
	SecondLineAddress string `json:"secondLineAddress,omitempty"`

	// Contains city name for address of associated consumer.
	// Truncate rightmost positions if city name is greater than 20 characters or use standard 13-character U.S. Postal Service city abbreviations.
	City string `json:"city"  validate:"required"`

	// Contains the standard U.S. Postal Service state abbreviation for the address of the associated consumer.
	State string `json:"state"  validate:"required"`

	// Report the Zip Code of the associated consumer’s address.
	// Use entire field if reporting 9-digit zip codes. Otherwise, leftjustify and blank fill.
	ZipCode string `json:"zipCode"  validate:"required"`

	// Contains one of the following values for the address
	// C = Confirmed/Verified address
	// Note:
	//  Value ‘C’ enables reporting a confirmed or verified address after receiving an address discrepancy notification from a consumer reporting agency.
	//  Report ‘C’ one time after the address is confirmed.
	//
	// Y = Known to be address of associated consumer
	// N = Not confirmed address
	// M = Military address
	// S = Secondary address
	// B = Business address — not consumer's residence
	// U = Non-deliverable address/Returned mail
	// D = Data reporter’s default address
	// P = Bill Payer Service — not consumer’s residence
	//
	//If indicator not available or unknown, blank fill.
	AddressIndicator string `json:"addressIndicator"`

	// Contains the one-character residence code of the address reported in fields 13-17. Values available:
	//  O = Owns
	//  R = Rents
	// If not available or unknown, blank fill.
	ResidenceCode string `json:"residenceCode"`
	// contains filtered or unexported fields
}

J2Segment holds the j2 segment

func (*J2Segment) Length

func (s *J2Segment) Length() int

Length returns size of segment

func (*J2Segment) Name

func (s *J2Segment) Name() string

Name returns name of j2 segment

func (*J2Segment) Parse

func (s *J2Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the j2 segment values

func (*J2Segment) String

func (s *J2Segment) String() string

String writes the j2 segment struct to a 200 character string.

func (*J2Segment) Validate

func (s *J2Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*J2Segment) ValidateAddressIndicator

func (s *J2Segment) ValidateAddressIndicator() error

validation of address indicator

func (*J2Segment) ValidateGenerationCode

func (s *J2Segment) ValidateGenerationCode() error

validation of generation code

func (*J2Segment) ValidateResidenceCode

func (s *J2Segment) ValidateResidenceCode() error

validation of residence code

func (*J2Segment) ValidateTelephoneNumber

func (s *J2Segment) ValidateTelephoneNumber() error

validation of telephone number

type K1Segment

type K1Segment struct {
	// Contains a constant of K1.
	SegmentIdentifier string `json:"segmentIdentifier"  validate:"required"`

	// This field is required and the content is dependent on the type of reporter.
	// Collection Agencies: Report the name of the company/creditor, including any partnering affinity name1, that originally opened the account for the consumer,
	//  even if the account had been turned over to multiple collection agencies.
	// Debt Buyers: Report the name of the company/creditor, including any partnering affinity name1, that originally opened the account for the consumer,
	//  even if the account had been sold multiple times to different debt buyers.
	// Refer to the K2 Segment for “purchased from” information.
	// Companies Reporting Returned Checks: Report the name of the payee; i.e., name of company to which the check was written.
	// Refer to Frequently Asked Question 15 for additional guidelines on reporting returned checks.
	// Student Loan Guarantors/U.S. Department of Education: Report the name of the original student loan lender.
	// U.S. Treasury: Report the name of the government agency that is the original creditor.
	// One of the following three options should be used when reporting a creditor’s name that would reveal sensitive information about the consumer.
	// 1. Report the name of the institution, but do not include reference to the type of service.
	//    For example, use the hospital name without identifying that it was the psychiatric unit that provided care. If a hospital’s name reveals sensitive information, abbreviate the name.
	// 2. Use the corporate name if it is different from the commercial name of a mental institution or drug rehabilitation center.
	// 3. Do not report the account if either of the above two options would not sufficiently protect the consumer’s privacy
	OriginalCreditorName string `json:"originalCreditorName"  validate:"required"`

	// Contains a code which must be reported to indicate the general type of business for the Original Creditor Name.
	// Values available:
	//  01 = Retail
	//  02 = Medical/Health Care Required when reporting medical debts and returned checks from providers of medical services, products or devices
	//  03 = Oil Company
	//  04 = Government
	//  05 = Personal Services
	//  06 = Insurance
	//  07 = Educational
	//  08 = Banking
	//  09 = Rental/Leasing
	//  10 = Utilities
	//  11 = Cable/Cellular
	//  12 = Financial (other non-banking financial institutions)
	//  13 = Credit Union
	//  14 = Automotive
	//  15 = Check Guarantee
	CreditorClassification int `json:"creditorClassification"  validate:"required"`
	// contains filtered or unexported fields
}

K1Segment holds the k1 segment

func (*K1Segment) Length

func (s *K1Segment) Length() int

Length returns size of segment

func (*K1Segment) Name

func (s *K1Segment) Name() string

Name returns name of K1 segment

func (*K1Segment) Parse

func (s *K1Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the k1 segment values

func (*K1Segment) String

func (s *K1Segment) String() string

String writes the k1 segment struct to a 34 character string.

func (*K1Segment) Validate

func (s *K1Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*K1Segment) ValidateCreditorClassification

func (s *K1Segment) ValidateCreditorClassification() error

validation of creditor classification

type K2Segment

type K2Segment struct {
	// Contains a constant of K2.
	SegmentIdentifier string `json:"segmentIdentifier"  validate:"required"`

	// Contains a code representing the type of information being reported. Values available:
	// 1 = Purchased From Name
	// 2 = Sold To Name
	// 9 = Remove Previously Reported K2 Segment Information
	PurchasedIndicator int `json:"purchasedIndicator"  validate:"required"`

	// Contains the name of the company from which the account was purchased or to which the account was sold.
	// If field 2 = 9, this field should be blank filled.
	PurchasedName string `json:"purchasedName"  validate:"required"`
	// contains filtered or unexported fields
}

K2Segment holds the k2 segment

func (*K2Segment) Length

func (s *K2Segment) Length() int

Length returns size of segment

func (*K2Segment) Name

func (s *K2Segment) Name() string

Name returns name of K2 segment

func (*K2Segment) Parse

func (s *K2Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the k2 segment values

func (*K2Segment) String

func (s *K2Segment) String() string

String writes the k2 segment struct to a 34 character string.

func (*K2Segment) Validate

func (s *K2Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*K2Segment) ValidatePurchasedIndicator

func (s *K2Segment) ValidatePurchasedIndicator() error

validation of purchased indicator

func (*K2Segment) ValidatePurchasedName

func (s *K2Segment) ValidatePurchasedName() error

validation of purchased name

type K3Segment

type K3Segment struct {
	// Contains a constant of K3.
	SegmentIdentifier string `json:"segmentIdentifier"  validate:"required"`

	// Contains a code indicating which secondary marketing agency has interest in this loan. Values available:
	// 00 = Agency Identifier not applicable (Used when reporting MIN only)
	// 01 = Fannie Mae
	// 02 = Freddie Mac
	AgencyIdentifier int `json:"agencyIdentifier,omitempty"`

	// Contains the account number as assigned by the secondary marketing agency. Do not include embedded blanks or special characters.
	// If field 2 = 00, this field should be blank filled.
	AccountNumber string `json:"accountNumber,omitempty"`

	// Contains the Mortgage Identification Number assigned to a mortgage loan. Do not include embedded blanks or special characters.
	// The MIN indicates that the loan is registered with the Mortgage Electronic Registration Systems, Inc.
	// (MERS), the electronic registry for tracking the ownership of mortgage rights.
	// For more information, see http://www.mersinc.org.
	MortgageIdentificationNumber string `json:"mortgageIdentificationNumber"`
	// contains filtered or unexported fields
}

K3Segment holds the k3 segment

func (*K3Segment) Length

func (s *K3Segment) Length() int

Length returns size of segment

func (*K3Segment) Name

func (s *K3Segment) Name() string

Name returns name of K3 segment

func (*K3Segment) Parse

func (s *K3Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the k3 segment values

func (*K3Segment) String

func (s *K3Segment) String() string

String writes the k3 segment struct to a 40 character string.

func (*K3Segment) Validate

func (s *K3Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*K3Segment) ValidateAccountNumber

func (s *K3Segment) ValidateAccountNumber() error

validation of account number

func (*K3Segment) ValidateAgencyIdentifier

func (s *K3Segment) ValidateAgencyIdentifier() error

validation of agency identifier

type K4Segment

type K4Segment struct {
	// Contains a constant of K4.
	SegmentIdentifier string `json:"segmentIdentifier"  validate:"required"`

	// Contains a code describing the specialized payment arrangements.
	// Values available:
	// 01 = Balloon Payment
	// 02 = Deferred Payment
	SpecializedPaymentIndicator int `json:"specializedPaymentIndicator"  validate:"required"`

	// Report the date the first payment is due for deferred loans.
	// Format is MMDDYYYY. If the day is not available, use 01.
	DeferredPaymentStartDate time.Time `json:"deferredPaymentStartDate,omitempty"`

	// Report the date the balloon payment is due, if applicable.
	// Format is MMDDYYYY. If the day is not available, use 01.
	BalloonPaymentDueDate time.Time `json:"balloonPaymentDueDate,omitempty"`

	// Report the amount of the balloon payment in whole dollars only.
	BalloonPaymentAmount int `json:"balloonPaymentAmount"`
	// contains filtered or unexported fields
}

K4Segment holds the k4 segment

func (*K4Segment) Length

func (s *K4Segment) Length() int

Length returns size of segment

func (*K4Segment) Name

func (s *K4Segment) Name() string

Name returns name of K4 segment

func (*K4Segment) Parse

func (s *K4Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the k4 segment values

func (*K4Segment) String

func (s *K4Segment) String() string

String writes the k4 segment struct to a 30 character string.

func (*K4Segment) Validate

func (s *K4Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*K4Segment) ValidateSpecializedPaymentIndicator

func (s *K4Segment) ValidateSpecializedPaymentIndicator() error

validation of specialized payment indicator

type L1Segment

type L1Segment struct {
	// Contains a constant of L1.
	SegmentIdentifier string `json:"segmentIdentifier"  validate:"required"`

	// Contains a code representing the change being reported.
	// Values available:
	//  1 = Consumer Account Number Change ONLY
	//  2 = Identification Number Change ONLY
	//  3 = Consumer Account Number AND Identification Number Change
	ChangeIndicator int `json:"changeIndicator"  validate:"required"`

	// Contains the new Account Number assigned to this account.
	// Do not include embedded blanks or special characters.
	// If field 2 = 2, this field should be blank filled.
	NewConsumerAccountNumber string `json:"newConsumerAccountNumber,omitempty"`

	// Contains the new Identification Number assigned to this account.
	// Do not include embedded blanks or special characters.
	// If field 2 = 1, this field should be blank filled.
	NewIdentificationNumber string `json:"balloonPaymentDueDate,omitempty"`
	// contains filtered or unexported fields
}

L1Segment holds the l1 segment

func (*L1Segment) Length

func (s *L1Segment) Length() int

Length returns size of segment

func (*L1Segment) Name

func (s *L1Segment) Name() string

Name returns name of L1 segment

func (*L1Segment) Parse

func (s *L1Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the l1 segment values

func (*L1Segment) String

func (s *L1Segment) String() string

String writes the l1 segment struct to a 54 character string.

func (*L1Segment) Validate

func (s *L1Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*L1Segment) ValidateChangeIndicator

func (s *L1Segment) ValidateChangeIndicator() error

validation of change indicator

func (*L1Segment) ValidateNewConsumerAccountNumber

func (s *L1Segment) ValidateNewConsumerAccountNumber() error

validation of new consumer account number

func (*L1Segment) ValidateNewIdentificationNumber

func (s *L1Segment) ValidateNewIdentificationNumber() error

validation of new identification number

type N1Segment

type N1Segment struct {
	// Contains a constant of N1.
	SegmentIdentifier string `json:"segmentIdentifier"  validate:"required"`

	// Report the name of the employer for the consumer reported in the Base Segment.
	EmployerName string `json:"employerName"  validate:"required"`

	// Contains the mailing address for the employer in Field 2 and usually includes street number, direction, street name and type of thoroughfare.
	FirstLineEmployerAddress string `json:"firstLineEmployerAddress"`

	// Contains second line of employer’s address, if needed.
	SecondLineEmployerAddress string `json:"secondLineEmployerAddress"`

	// Contains city name for employer’s address.
	// Truncate rightmost positions if city name is greater than 20 characters or use standard 13-character U.S.
	// Postal Service city abbreviations.
	EmployerCity string `json:"employerCity"`

	// Contains the standard U.S. Postal Service state abbreviation for the address of the employer.
	EmployerState string `json:"employerState"`

	// Report the zip code of the employer’s address.
	// Use entire field if reporting 9-digit zip codes. Otherwise, left-justify and blank fill.
	ZipCode string `json:"zipCode"`

	// Report title or position for consumer reported in the Base Segment (the employee).
	Occupation string `json:"occupation"`
	// contains filtered or unexported fields
}

N1Segment holds the n1 segment

func (*N1Segment) Length

func (s *N1Segment) Length() int

Length returns size of segment

func (*N1Segment) Name

func (s *N1Segment) Name() string

Name returns name of N1 segment

func (*N1Segment) Parse

func (s *N1Segment) Parse(record string) (int, error)

Parse takes the input record string and parses the n1 segment values

func (*N1Segment) String

func (s *N1Segment) String() string

String writes the n1 segment struct to a 146 character string.

func (*N1Segment) Validate

func (s *N1Segment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

type PackedBaseSegment

type PackedBaseSegment BaseSegment

PackedBaseSegment holds the packed base segment

func (*PackedBaseSegment) AddApplicableSegment

func (r *PackedBaseSegment) AddApplicableSegment(s Segment) error

AddApplicableSegment will add new applicable segment into record

func (*PackedBaseSegment) BlockSize

func (r *PackedBaseSegment) BlockSize() int

BlockSize returns size of block

func (*PackedBaseSegment) GetSegments

func (r *PackedBaseSegment) GetSegments(name string) []Segment

GetSegments returns list of applicable segments by segment name

func (*PackedBaseSegment) Length

func (r *PackedBaseSegment) Length() int

Length returns size of segment

func (*PackedBaseSegment) MarshalJSON

func (r *PackedBaseSegment) MarshalJSON() ([]byte, error)

MarshalJSON returns JSON blob

func (*PackedBaseSegment) Name

func (r *PackedBaseSegment) Name() string

Name returns name of packed base segment

func (*PackedBaseSegment) Parse

func (r *PackedBaseSegment) Parse(record string) (int, error)

Parse takes the input record string and parses the packed base segment values

func (*PackedBaseSegment) String

func (r *PackedBaseSegment) String() string

String writes the packed base segment struct to a 426 character string.

func (*PackedBaseSegment) UnmarshalJSON

func (r *PackedBaseSegment) UnmarshalJSON(data []byte) error

UnmarshalJSON parses a JSON blob

func (*PackedBaseSegment) Validate

func (r *PackedBaseSegment) Validate() error

Validate performs some checks on the record and returns an error if not Validated

func (*PackedBaseSegment) ValidateIdentificationNumber

func (r *PackedBaseSegment) ValidateIdentificationNumber() error

func (*PackedBaseSegment) ValidateInterestTypeIndicator

func (r *PackedBaseSegment) ValidateInterestTypeIndicator() error

func (*PackedBaseSegment) ValidatePaymentHistoryProfile

func (r *PackedBaseSegment) ValidatePaymentHistoryProfile() error

func (*PackedBaseSegment) ValidatePaymentRating

func (r *PackedBaseSegment) ValidatePaymentRating() error

func (*PackedBaseSegment) ValidatePortfolioType

func (r *PackedBaseSegment) ValidatePortfolioType() error

func (*PackedBaseSegment) ValidateTelephoneNumber

func (r *PackedBaseSegment) ValidateTelephoneNumber() error

func (*PackedBaseSegment) ValidateTermsDuration

func (r *PackedBaseSegment) ValidateTermsDuration() error

func (*PackedBaseSegment) ValidateTermsFrequency

func (r *PackedBaseSegment) ValidateTermsFrequency() error

type PackedHeaderRecord

type PackedHeaderRecord HeaderRecord

PackedHeaderRecord holds the packed header record

func (*PackedHeaderRecord) AddApplicableSegment

func (r *PackedHeaderRecord) AddApplicableSegment(s Segment) error

AddApplicableSegment will add new applicable segment into record

func (*PackedHeaderRecord) BlockSize

func (r *PackedHeaderRecord) BlockSize() int

BlockSize returns size of block

func (*PackedHeaderRecord) GetSegments

func (r *PackedHeaderRecord) GetSegments(string) []Segment

GetSegments returns list of applicable segments by segment name

func (*PackedHeaderRecord) Length

func (r *PackedHeaderRecord) Length() int

Length returns size of segment

func (*PackedHeaderRecord) Name

func (r *PackedHeaderRecord) Name() string

Name returns name of packed header record

func (*PackedHeaderRecord) Parse

func (r *PackedHeaderRecord) Parse(record string) (int, error)

Parse takes the input record string and parses the packed header record values

func (*PackedHeaderRecord) String

func (r *PackedHeaderRecord) String() string

String writes the packed header record struct to a 426 character string.

func (*PackedHeaderRecord) Validate

func (r *PackedHeaderRecord) Validate() error

Validate performs some checks on the record and returns an error if not Validated

type PackedTrailerRecord

type PackedTrailerRecord TrailerRecord

PackedTrailerRecord holds the packed trailer record

func (*PackedTrailerRecord) AddApplicableSegment

func (r *PackedTrailerRecord) AddApplicableSegment(s Segment) error

AddApplicableSegment will add new applicable segment into record

func (*PackedTrailerRecord) BlockSize

func (r *PackedTrailerRecord) BlockSize() int

BlockSize returns size of block

func (*PackedTrailerRecord) GetSegments

func (r *PackedTrailerRecord) GetSegments(string) []Segment

GetSegments returns list of applicable segments by segment name

func (*PackedTrailerRecord) Length

func (r *PackedTrailerRecord) Length() int

Length returns size of record

func (*PackedTrailerRecord) Name

func (r *PackedTrailerRecord) Name() string

Name returns name of packed trailer record

func (*PackedTrailerRecord) Parse

func (r *PackedTrailerRecord) Parse(record string) (int, error)

Parse takes the input record string and parses the packed trailer record values

func (*PackedTrailerRecord) String

func (r *PackedTrailerRecord) String() string

String writes the trailer record struct to a 426 character string.

func (*PackedTrailerRecord) Validate

func (r *PackedTrailerRecord) Validate() error

Validate performs some checks on the record and returns an error if not Validated

type Record

type Record interface {
	Name() string
	Parse(string) (int, error)
	String() string
	Validate() error
	Length() int
	BlockSize() int
	AddApplicableSegment(Segment) error
	GetSegments(string) []Segment
}

General record interface

func NewBaseSegment

func NewBaseSegment() Record

NewBaseSegment returns a new base segment

func NewHeaderRecord

func NewHeaderRecord() Record

NewHeaderRecord returns a new header record

func NewPackedBaseSegment

func NewPackedBaseSegment() Record

NewPackedBaseSegment returns a new packed base segment

func NewPackedHeaderRecord

func NewPackedHeaderRecord() Record

NewPackedHeaderRecord returns a new packed header record

func NewPackedTrailerRecord

func NewPackedTrailerRecord() Record

NewPackedTrailerRecord returns a new packed trailer record

func NewTrailerRecord

func NewTrailerRecord() Record

NewTrailerRecord returns a new trailer record

type Segment

type Segment interface {
	Name() string
	Parse(string) (int, error)
	String() string
	Validate() error
	Length() int
}

General segment interface

func NewJ1Segment

func NewJ1Segment() Segment

NewJ1Segment returns a new j1 segment

func NewJ2Segment

func NewJ2Segment() Segment

NewJ2Segment returns a new j1 segment

func NewK1Segment

func NewK1Segment() Segment

NewK1Segment returns a new k1 segment

func NewK2Segment

func NewK2Segment() Segment

NewK2Segment returns a new k2 segment

func NewK3Segment

func NewK3Segment() Segment

NewK3Segment returns a new k3 segment

func NewK4Segment

func NewK4Segment() Segment

NewK4Segment returns a new k4 segment

func NewL1Segment

func NewL1Segment() Segment

NewL1Segment returns a new l1 segment

func NewN1Segment

func NewN1Segment() Segment

NewN1Segment returns a new n1 segment

type TrailerInformation

type TrailerInformation TrailerRecord

type TrailerRecord

type TrailerRecord struct {

	// Contains a value equal to the length of the physical record. This value includes the four bytes reserved for this field.
	// If fixed-length records are being reported, the Trailer Record should be the same length as all the data records.
	// The Trailer Record should be padded with blanks to fill the needed number of positions.
	RecordDescriptorWord int `json:"recordDescriptorWord" validate:"required"`

	// Contains a constant of TRAILER, which is used to identify this record.
	RecordIdentifier string `json:"recordIdentifier" validate:"required"`

	// Contains the total number of Base Segments being reported.
	TotalBaseRecords int `json:"totalBaseRecords" validate:"required"`

	// Contains the total number of Base Segments with Status Code DF.
	TotalStatusCodeDF int `json:"totalStatusCodeDF"`

	// Contains the total number of J1 Segments being reported. Do not count blank- or 9-filled segments.
	TotalConsumerSegmentsJ1 int `json:"totalConsumerSegmentsJ1,omitempty"`

	// Contains the total number of J2 Segments being reported. Do not count blank- or 9-filled segments.
	TotalConsumerSegmentsJ2 int `json:"totalConsumerSegmentsJ2,omitempty"`

	// Contains the number of blocks on the file, if applicable.
	BlockCount int `json:"blockCount"`

	// Contains the total number of Base Segments with Status Code DA.
	TotalStatusCodeDA int `json:"totalStatusCodeDA"`

	// Contains the total number of Base Segments with Status Code 05.
	TotalStatusCode05 int `json:"totalStatusCode05"`

	// Contains the total number of Base Segments with Status Code 11.
	TotalStatusCode11 int `json:"totalStatusCode11"`

	// Contains the total number of Base Segments with Status Code 13.
	TotalStatusCode13 int `json:"totalStatusCode13"`

	// Contains the total number of Base Segments with Status Code 61.
	TotalStatusCode61 int `json:"totalStatusCode61"`

	// Contains the total number of Base Segments with Status Code 62.
	TotalStatusCode62 int `json:"totalStatusCode62"`

	// Contains the total number of Base Segments with Status Code 63.
	TotalStatusCode63 int `json:"totalStatusCode63"`

	// Contains the total number of Base Segments with Status Code 64.
	TotalStatusCode64 int `json:"totalStatusCode64"`

	// Contains the total number of Base Segments with Status Code 65.
	TotalStatusCode65 int `json:"totalStatusCode65"`

	// Contains the total number of Base Segments with Status Code 71.
	TotalStatusCode71 int `json:"totalStatusCode71"`

	// Contains the total number of Base Segments with Status Code 78.
	TotalStatusCode78 int `json:"totalStatusCode78"`

	// Contains the total number of Base Segments with Status Code 80.
	TotalStatusCode80 int `json:"totalStatusCode80"`

	// Contains the total number of Base Segments with Status Code 82.
	TotalStatusCode82 int `json:"totalStatusCode82"`

	// Contains the total number of Base Segments with Status Code 83.
	TotalStatusCode83 int `json:"totalStatusCode83"`

	// Contains the total number of Base Segments with Status Code 84.
	TotalStatusCode84 int `json:"totalStatusCode84"`

	// Contains the total number of Base Segments with Status Code 88.
	TotalStatusCode88 int `json:"totalStatusCode88"`

	// Contains the total number of Base Segments with Status Code 89.
	TotalStatusCode89 int `json:"totalStatusCode89"`

	// Contains the total number of Base Segments with Status Code 93.
	TotalStatusCode93 int `json:"totalStatusCode93"`

	// Contains the total number of Base Segments with Status Code 94.
	TotalStatusCode94 int `json:"totalStatusCode94"`

	// Contains the total number of Base Segments with Status Code 95.
	TotalStatusCode95 int `json:"totalStatusCode95"`

	// Contains the total number of Base Segments with Status Code 96.
	TotalStatusCode96 int `json:"totalStatusCode96"`

	// Contains the total number of Base Segments with Status Code 97.
	TotalStatusCode97 int `json:"totalStatusCode97"`

	// Contains the total number of records with ECOA Code Z being reported in the Base Segment, in the J1 Segment and in the J2 Segment.
	TotalECOACodeZ int `json:"totalECOACodeZ"`

	// Contains the total number of records with employment being reported in the N1 Segment.
	TotalEmploymentSegments int `json:"totalEmploymentSegments"`

	// Contains the total number of records with Original Creditors being reported in the K1 Segment.
	TotalOriginalCreditorSegments int `json:"totalOriginalCreditorSegments"`

	// Contains the total number of records with Purchased From/Sold To being reported in the K2 Segment.
	TotalPurchasedToSegments int `json:"totalPurchasedToSegments"`

	// Contains the total number of records with Mortgage Information being reported in the K3 Segment.
	TotalMortgageInformationSegments int `json:"totalMortgageInformationSegments"`

	// Contains the total number of records with Specialized Payment Information being reported in the K4 Segment.
	TotalPaymentInformationSegments int `json:"totalPaymentInformationSegments"`

	// Contains the total number of Consumer Account Number and/or Identification Number changes being reported in the L1 Segment.
	TotalChangeSegments int `json:"totalChangeSegments"`

	// Contains the total number of valid Social Security Numbers reported in the Base Segment, in the J1 Segment and in  the J2 Segment.
	// Do not count zero- or 9-filled SSNs.
	TotalSocialNumbersAllSegments int `json:"totalSocialNumbersAllSegments"`

	// Contains the total number of valid Social Security Numbers reported in the Base Segment. Do not count zero- or 9-filled SSNs.
	TotalSocialNumbersBaseSegments int `json:"totalSocialNumbersBaseSegments"`

	// Contains the total number of valid Social Security Numbers reported in the J1 Segment. Do not count zero- or 9-filled SSNs.
	TotalSocialNumbersJ1Segments int `json:"totalSocialNumbersJ1Segments"`

	// Contains the total number of valid Social Security Numbers reported in the J2 Segment. Do not count zero- or 9-filled SSNs.
	TotalSocialNumbersJ2Segments int `json:"totalSocialNumbersJ2Segments"`

	// Contains the total number of valid Dates of Birth reported in the Base Segment, in the J1 Segment and in the J2 Segment.
	// Do not count zero-filled Dates of Birth.
	TotalDatesBirthAllSegments int `json:"totalDatesBirthAllSegments"`

	// Contains the total number of valid Dates of Birth reported in the Base Segment. Do not count zero-filled Dates of Birth.
	TotalDatesBirthBaseSegments int `json:"totalDatesBirthBaseSegments"`

	// Contains the total number of valid Dates of Birth reported in the J1 Segment. Do not count zero-filled Dates of Birth.
	TotalDatesBirthJ1Segments int `json:"totalDatesBirthJ1Segments"`

	// Contains the total number of valid Dates of Birth reported in the J2 Segment. Do not count zero-filled Dates of Birth.
	TotalDatesBirthJ2Segments int `json:"totalDatesBirthJ2Segments"`

	// Contains the total number of valid Telephone Numbers reported in the Base Segment, in the J1 Segment and in the J2 Segment.
	// Do not count zero-filled Telephone Numbers.
	TotalTelephoneNumbersAllSegments int `json:"totalTelephoneNumbersAllSegments"`
	// contains filtered or unexported fields
}

TrailerRecord holds the trailer record

func (*TrailerRecord) AddApplicableSegment

func (r *TrailerRecord) AddApplicableSegment(s Segment) error

AddApplicableSegment will add new applicable segment into record

func (*TrailerRecord) BlockSize

func (r *TrailerRecord) BlockSize() int

BlockSize returns size of block

func (*TrailerRecord) GetSegments

func (r *TrailerRecord) GetSegments(string) []Segment

GetSegments returns list of applicable segments by segment name

func (*TrailerRecord) Length

func (r *TrailerRecord) Length() int

Length returns size of record

func (*TrailerRecord) Name

func (r *TrailerRecord) Name() string

Name returns name of trailer record

func (*TrailerRecord) Parse

func (r *TrailerRecord) Parse(record string) (int, error)

Parse takes the input record string and parses the trailer record values

func (*TrailerRecord) String

func (r *TrailerRecord) String() string

String writes the trailer record struct to a 426 character string.

func (*TrailerRecord) Validate

func (r *TrailerRecord) Validate() error

Validate performs some checks on the record and returns an error if not Validated

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL