fleet/docs/development/contributing-code.md
Mike Arpaia a4d9fe8dfd Documentation Structure (#1101)
Initial structure and content for the Kolide documentation.
2017-01-25 14:51:00 -07:00

2 KiB

Contributing Code

Database Modifications

Adding/Updating tables

Database schemas are managed by a series of migrations defined in go code. We use a customized version of the Goose migrations tool to handle these migrations.

Note: Once committed to the Kolide repo, table migrations should be considered immutable. Any changes to an existing table should take place in a new migration executing ALTERs.

  • From the project root run the following shell commands:
go get github.com/kolide/goose
cd server/datastore/mysql/migrations/tables
goose create AddColumnFooToUsers
  • Find the file you created in the migrations directory and edit it
package migration

import (
	"database/sql"

	"github.com/kolide/goose"
)

func init() {
	goose.AddMigration(Up_20161118212656, Down_20161118212656)
}

func Up_20161118212656(tx *sql.Tx) error {
	_, err := tx.Exec("ALTER TABLE `users` ADD COLUMN `foo` varchar(10) NOT NULL;")
	return err
}

func Down_20161118212656(tx *sql.Tx) error {
	_, err := tx.Exec("ALTER TABLE `users` DROP COLUMN `foo`;")
	return err
}
  • Update the database by running the following shell commands:
make build
build/kolide prepare db

Populating the database with default data

Populating built in data is also performed through migrations. All table migrations are performed before any data migrations.

Note: Data migrations can be mutable. If tables are altered in a way that would render a data migration invalid (columns changed/removed), data migrations should be updated to comply with the new schema. Data migrations will not be re-run when they have already been run against a database, but they must be updated to maintain compatibility with a fresh DB.

  • From the project root run the following shell commands:
go get github.com/kolide/goose
cd server/datastore/mysql/migrations/data
goose create PopulateFoo
  • Proceed as for table migrations, editing and running the newly created migration file.