e3d818a4e8
Allow users to be invited. Addresses private issue https://dev.gitlab.org/gitlab/gitlabhq/issues/2058. The "Add members" panes for both Group Members and Project Members have gained a line of text by the People field. ![Screen_Shot_2015-04-10_at_14.14.32](https://gitlab.com/gitlab-org/gitlab-ce/uploads/fe990e65eccd9203d7324b492941362b/Screen_Shot_2015-04-10_at_14.14.32.png) Entering an email address that is not already a member will give you the option to invite them. ![Screen_Shot_2015-04-10_at_14.14.48](https://gitlab.com/gitlab-org/gitlab-ce/uploads/d6b0d4571ea90f2a2e4af8f5b336e8e1/Screen_Shot_2015-04-10_at_14.14.48.png) Choosing the option will add them to the People field. This works the right way (TM) in combination with adding existing users as members. ![Screen_Shot_2015-04-10_at_14.15.09](https://gitlab.com/gitlab-org/gitlab-ce/uploads/a618e5ec292d79578b16400dca6d4cfe/Screen_Shot_2015-04-10_at_14.15.09.png) The invited member will be shown in the members list as such. The access level can be changed, and the invite can be revoked by deleting the member. ![Screen_Shot_2015-04-10_at_14.15.19](https://gitlab.com/gitlab-org/gitlab-ce/uploads/3695b9a6778d367b275115747579b46e/Screen_Shot_2015-04-10_at_14.15.19.png) The invited user will receive an email with an "Accept invitation" link. ![Screen_Shot_2015-04-10_at_14.17.52](https://gitlab.com/gitlab-org/gitlab-ce/uploads/730121888153117d83c3cd0e4f5c90f6/Screen_Shot_2015-04-10_at_14.17.52.png) If they're not already logged in, clicking this link will redirect them to the sign in/up page with a helpful notice. ![Screen_Shot_2015-04-10_at_14.18.12](https://gitlab.com/gitlab-org/gitlab-ce/uploads/1a26a5fa13321e7ef77ed8b538c8557d/Screen_Shot_2015-04-10_at_14.18.12.png) Signing in or signing up will redirect them back to the invite detail page, where they can actually accept the invitation, which will update the member record in question to point to the user in question. ![Screen_Shot_2015-04-10_at_14.18.48](https://gitlab.com/gitlab-org/gitlab-ce/uploads/7ac33085463a99b8cfa6baa13bfa1235/Screen_Shot_2015-04-10_at_14.18.48.png) Accepting the invitation will redirect them to the group (or project) with an appropriate notice. ![Screen_Shot_2015-04-10_at_14.18.58](https://gitlab.com/gitlab-org/gitlab-ce/uploads/7bf02a2e3bea589a11df401c23e68648/Screen_Shot_2015-04-10_at_14.18.58.png) As currently, they will also receive this information by email. ![Screen_Shot_2015-04-10_at_14.24.00](https://gitlab.com/gitlab-org/gitlab-ce/uploads/b44a342068433a268c0a06ed9e791ffa/Screen_Shot_2015-04-10_at_14.24.00.png) At the same time, the person who initially invited the email address is sent a notification as well, so they know of the new member and to tell them what name the user signed up with. ![Screen_Shot_2015-04-10_at_14.19.07](https://gitlab.com/gitlab-org/gitlab-ce/uploads/b29fea128186f938ec76bd7dec016b83/Screen_Shot_2015-04-10_at_14.19.07.png) The member row on the Members page will now have been updated with the new user account. ![Screen_Shot_2015-04-10_at_14.19.23](https://gitlab.com/gitlab-org/gitlab-ce/uploads/cf503d3d1679614e03acec2e946a28c3/Screen_Shot_2015-04-10_at_14.19.23.png) See merge request !500
525 lines
23 KiB
Ruby
525 lines
23 KiB
Ruby
# encoding: UTF-8
|
|
# This file is auto-generated from the current state of the database. Instead
|
|
# of editing this file, please use the migrations feature of Active Record to
|
|
# incrementally modify your database, and then regenerate this schema definition.
|
|
#
|
|
# Note that this schema.rb definition is the authoritative source for your
|
|
# database schema. If you need to create the application database on another
|
|
# system, you should be using db:schema:load, not running all the migrations
|
|
# from scratch. The latter is a flawed and unsustainable approach (the more migrations
|
|
# you'll amass, the slower it'll run and the greater likelihood for issues).
|
|
#
|
|
# It's strongly recommended that you check this file into your version control system.
|
|
|
|
ActiveRecord::Schema.define(version: 20150413192223) do
|
|
|
|
# These are extensions that must be enabled in order to support this database
|
|
enable_extension "plpgsql"
|
|
|
|
create_table "application_settings", force: true do |t|
|
|
t.integer "default_projects_limit"
|
|
t.boolean "signup_enabled"
|
|
t.boolean "signin_enabled"
|
|
t.boolean "gravatar_enabled"
|
|
t.text "sign_in_text"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "home_page_url"
|
|
t.integer "default_branch_protection", default: 2
|
|
t.boolean "twitter_sharing_enabled", default: true
|
|
t.text "restricted_visibility_levels"
|
|
t.integer "max_attachment_size", default: 10, null: false
|
|
end
|
|
|
|
create_table "broadcast_messages", force: true do |t|
|
|
t.text "message", null: false
|
|
t.datetime "starts_at"
|
|
t.datetime "ends_at"
|
|
t.integer "alert_type"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "color"
|
|
t.string "font"
|
|
end
|
|
|
|
create_table "deploy_keys_projects", force: true do |t|
|
|
t.integer "deploy_key_id", null: false
|
|
t.integer "project_id", null: false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "deploy_keys_projects", ["project_id"], name: "index_deploy_keys_projects_on_project_id", using: :btree
|
|
|
|
create_table "emails", force: true do |t|
|
|
t.integer "user_id", null: false
|
|
t.string "email", null: false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "emails", ["email"], name: "index_emails_on_email", unique: true, using: :btree
|
|
add_index "emails", ["user_id"], name: "index_emails_on_user_id", using: :btree
|
|
|
|
create_table "events", force: true do |t|
|
|
t.string "target_type"
|
|
t.integer "target_id"
|
|
t.string "title"
|
|
t.text "data"
|
|
t.integer "project_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "action"
|
|
t.integer "author_id"
|
|
end
|
|
|
|
add_index "events", ["action"], name: "index_events_on_action", using: :btree
|
|
add_index "events", ["author_id"], name: "index_events_on_author_id", using: :btree
|
|
add_index "events", ["created_at"], name: "index_events_on_created_at", using: :btree
|
|
add_index "events", ["project_id"], name: "index_events_on_project_id", using: :btree
|
|
add_index "events", ["target_id"], name: "index_events_on_target_id", using: :btree
|
|
add_index "events", ["target_type"], name: "index_events_on_target_type", using: :btree
|
|
|
|
create_table "forked_project_links", force: true do |t|
|
|
t.integer "forked_to_project_id", null: false
|
|
t.integer "forked_from_project_id", null: false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "forked_project_links", ["forked_to_project_id"], name: "index_forked_project_links_on_forked_to_project_id", unique: true, using: :btree
|
|
|
|
create_table "identities", force: true do |t|
|
|
t.string "extern_uid"
|
|
t.string "provider"
|
|
t.integer "user_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "identities", ["created_at", "id"], name: "index_identities_on_created_at_and_id", using: :btree
|
|
add_index "identities", ["user_id"], name: "index_identities_on_user_id", using: :btree
|
|
|
|
create_table "issues", force: true do |t|
|
|
t.string "title"
|
|
t.integer "assignee_id"
|
|
t.integer "author_id"
|
|
t.integer "project_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "position", default: 0
|
|
t.string "branch_name"
|
|
t.text "description"
|
|
t.integer "milestone_id"
|
|
t.string "state"
|
|
t.integer "iid"
|
|
end
|
|
|
|
add_index "issues", ["assignee_id"], name: "index_issues_on_assignee_id", using: :btree
|
|
add_index "issues", ["author_id"], name: "index_issues_on_author_id", using: :btree
|
|
add_index "issues", ["created_at", "id"], name: "index_issues_on_created_at_and_id", using: :btree
|
|
add_index "issues", ["created_at"], name: "index_issues_on_created_at", using: :btree
|
|
add_index "issues", ["milestone_id"], name: "index_issues_on_milestone_id", using: :btree
|
|
add_index "issues", ["project_id", "iid"], name: "index_issues_on_project_id_and_iid", unique: true, using: :btree
|
|
add_index "issues", ["project_id"], name: "index_issues_on_project_id", using: :btree
|
|
add_index "issues", ["title"], name: "index_issues_on_title", using: :btree
|
|
|
|
create_table "keys", force: true do |t|
|
|
t.integer "user_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.text "key"
|
|
t.string "title"
|
|
t.string "type"
|
|
t.string "fingerprint"
|
|
t.boolean "public", default: false, null: false
|
|
end
|
|
|
|
add_index "keys", ["created_at", "id"], name: "index_keys_on_created_at_and_id", using: :btree
|
|
add_index "keys", ["user_id"], name: "index_keys_on_user_id", using: :btree
|
|
|
|
create_table "label_links", force: true do |t|
|
|
t.integer "label_id"
|
|
t.integer "target_id"
|
|
t.string "target_type"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "label_links", ["label_id"], name: "index_label_links_on_label_id", using: :btree
|
|
add_index "label_links", ["target_id", "target_type"], name: "index_label_links_on_target_id_and_target_type", using: :btree
|
|
|
|
create_table "labels", force: true do |t|
|
|
t.string "title"
|
|
t.string "color"
|
|
t.integer "project_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "labels", ["project_id"], name: "index_labels_on_project_id", using: :btree
|
|
|
|
create_table "members", force: true do |t|
|
|
t.integer "access_level", null: false
|
|
t.integer "source_id", null: false
|
|
t.string "source_type", null: false
|
|
t.integer "user_id"
|
|
t.integer "notification_level", null: false
|
|
t.string "type"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "created_by_id"
|
|
t.string "invite_email"
|
|
t.string "invite_token"
|
|
t.datetime "invite_accepted_at"
|
|
end
|
|
|
|
add_index "members", ["access_level"], name: "index_members_on_access_level", using: :btree
|
|
add_index "members", ["created_at", "id"], name: "index_members_on_created_at_and_id", using: :btree
|
|
add_index "members", ["invite_token"], name: "index_members_on_invite_token", unique: true, using: :btree
|
|
add_index "members", ["source_id", "source_type"], name: "index_members_on_source_id_and_source_type", using: :btree
|
|
add_index "members", ["type"], name: "index_members_on_type", using: :btree
|
|
add_index "members", ["user_id"], name: "index_members_on_user_id", using: :btree
|
|
|
|
create_table "merge_request_diffs", force: true do |t|
|
|
t.string "state"
|
|
t.text "st_commits"
|
|
t.text "st_diffs"
|
|
t.integer "merge_request_id", null: false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "merge_request_diffs", ["merge_request_id"], name: "index_merge_request_diffs_on_merge_request_id", unique: true, using: :btree
|
|
|
|
create_table "merge_requests", force: true do |t|
|
|
t.string "target_branch", null: false
|
|
t.string "source_branch", null: false
|
|
t.integer "source_project_id", null: false
|
|
t.integer "author_id"
|
|
t.integer "assignee_id"
|
|
t.string "title"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "milestone_id"
|
|
t.string "state"
|
|
t.string "merge_status"
|
|
t.integer "target_project_id", null: false
|
|
t.integer "iid"
|
|
t.text "description"
|
|
t.integer "position", default: 0
|
|
t.datetime "locked_at"
|
|
end
|
|
|
|
add_index "merge_requests", ["assignee_id"], name: "index_merge_requests_on_assignee_id", using: :btree
|
|
add_index "merge_requests", ["author_id"], name: "index_merge_requests_on_author_id", using: :btree
|
|
add_index "merge_requests", ["created_at", "id"], name: "index_merge_requests_on_created_at_and_id", using: :btree
|
|
add_index "merge_requests", ["created_at"], name: "index_merge_requests_on_created_at", using: :btree
|
|
add_index "merge_requests", ["milestone_id"], name: "index_merge_requests_on_milestone_id", using: :btree
|
|
add_index "merge_requests", ["source_branch"], name: "index_merge_requests_on_source_branch", using: :btree
|
|
add_index "merge_requests", ["source_project_id"], name: "index_merge_requests_on_source_project_id", using: :btree
|
|
add_index "merge_requests", ["target_branch"], name: "index_merge_requests_on_target_branch", using: :btree
|
|
add_index "merge_requests", ["target_project_id", "iid"], name: "index_merge_requests_on_target_project_id_and_iid", unique: true, using: :btree
|
|
add_index "merge_requests", ["title"], name: "index_merge_requests_on_title", using: :btree
|
|
|
|
create_table "milestones", force: true do |t|
|
|
t.string "title", null: false
|
|
t.integer "project_id", null: false
|
|
t.text "description"
|
|
t.date "due_date"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "state"
|
|
t.integer "iid"
|
|
end
|
|
|
|
add_index "milestones", ["created_at", "id"], name: "index_milestones_on_created_at_and_id", using: :btree
|
|
add_index "milestones", ["due_date"], name: "index_milestones_on_due_date", using: :btree
|
|
add_index "milestones", ["project_id", "iid"], name: "index_milestones_on_project_id_and_iid", unique: true, using: :btree
|
|
add_index "milestones", ["project_id"], name: "index_milestones_on_project_id", using: :btree
|
|
|
|
create_table "namespaces", force: true do |t|
|
|
t.string "name", null: false
|
|
t.string "path", null: false
|
|
t.integer "owner_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "type"
|
|
t.string "description", default: "", null: false
|
|
t.string "avatar"
|
|
end
|
|
|
|
add_index "namespaces", ["created_at", "id"], name: "index_namespaces_on_created_at_and_id", using: :btree
|
|
add_index "namespaces", ["name"], name: "index_namespaces_on_name", unique: true, using: :btree
|
|
add_index "namespaces", ["owner_id"], name: "index_namespaces_on_owner_id", using: :btree
|
|
add_index "namespaces", ["path"], name: "index_namespaces_on_path", unique: true, using: :btree
|
|
add_index "namespaces", ["type"], name: "index_namespaces_on_type", using: :btree
|
|
|
|
create_table "notes", force: true do |t|
|
|
t.text "note"
|
|
t.string "noteable_type"
|
|
t.integer "author_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "project_id"
|
|
t.string "attachment"
|
|
t.string "line_code"
|
|
t.string "commit_id"
|
|
t.integer "noteable_id"
|
|
t.boolean "system", default: false, null: false
|
|
t.text "st_diff"
|
|
end
|
|
|
|
add_index "notes", ["author_id"], name: "index_notes_on_author_id", using: :btree
|
|
add_index "notes", ["commit_id"], name: "index_notes_on_commit_id", using: :btree
|
|
add_index "notes", ["created_at", "id"], name: "index_notes_on_created_at_and_id", using: :btree
|
|
add_index "notes", ["created_at"], name: "index_notes_on_created_at", using: :btree
|
|
add_index "notes", ["noteable_id", "noteable_type"], name: "index_notes_on_noteable_id_and_noteable_type", using: :btree
|
|
add_index "notes", ["noteable_type"], name: "index_notes_on_noteable_type", using: :btree
|
|
add_index "notes", ["project_id", "noteable_type"], name: "index_notes_on_project_id_and_noteable_type", using: :btree
|
|
add_index "notes", ["project_id"], name: "index_notes_on_project_id", using: :btree
|
|
add_index "notes", ["updated_at"], name: "index_notes_on_updated_at", using: :btree
|
|
|
|
create_table "oauth_access_grants", force: true do |t|
|
|
t.integer "resource_owner_id", null: false
|
|
t.integer "application_id", null: false
|
|
t.string "token", null: false
|
|
t.integer "expires_in", null: false
|
|
t.text "redirect_uri", null: false
|
|
t.datetime "created_at", null: false
|
|
t.datetime "revoked_at"
|
|
t.string "scopes"
|
|
end
|
|
|
|
add_index "oauth_access_grants", ["token"], name: "index_oauth_access_grants_on_token", unique: true, using: :btree
|
|
|
|
create_table "oauth_access_tokens", force: true do |t|
|
|
t.integer "resource_owner_id"
|
|
t.integer "application_id"
|
|
t.string "token", null: false
|
|
t.string "refresh_token"
|
|
t.integer "expires_in"
|
|
t.datetime "revoked_at"
|
|
t.datetime "created_at", null: false
|
|
t.string "scopes"
|
|
end
|
|
|
|
add_index "oauth_access_tokens", ["refresh_token"], name: "index_oauth_access_tokens_on_refresh_token", unique: true, using: :btree
|
|
add_index "oauth_access_tokens", ["resource_owner_id"], name: "index_oauth_access_tokens_on_resource_owner_id", using: :btree
|
|
add_index "oauth_access_tokens", ["token"], name: "index_oauth_access_tokens_on_token", unique: true, using: :btree
|
|
|
|
create_table "oauth_applications", force: true do |t|
|
|
t.string "name", null: false
|
|
t.string "uid", null: false
|
|
t.string "secret", null: false
|
|
t.text "redirect_uri", null: false
|
|
t.string "scopes", default: "", null: false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "owner_id"
|
|
t.string "owner_type"
|
|
end
|
|
|
|
add_index "oauth_applications", ["owner_id", "owner_type"], name: "index_oauth_applications_on_owner_id_and_owner_type", using: :btree
|
|
add_index "oauth_applications", ["uid"], name: "index_oauth_applications_on_uid", unique: true, using: :btree
|
|
|
|
create_table "projects", force: true do |t|
|
|
t.string "name"
|
|
t.string "path"
|
|
t.text "description"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.integer "creator_id"
|
|
t.boolean "issues_enabled", default: true, null: false
|
|
t.boolean "wall_enabled", default: true, null: false
|
|
t.boolean "merge_requests_enabled", default: true, null: false
|
|
t.boolean "wiki_enabled", default: true, null: false
|
|
t.integer "namespace_id"
|
|
t.string "issues_tracker", default: "gitlab", null: false
|
|
t.string "issues_tracker_id"
|
|
t.boolean "snippets_enabled", default: true, null: false
|
|
t.datetime "last_activity_at"
|
|
t.string "import_url"
|
|
t.integer "visibility_level", default: 0, null: false
|
|
t.boolean "archived", default: false, null: false
|
|
t.string "avatar"
|
|
t.string "import_status"
|
|
t.float "repository_size", default: 0.0
|
|
t.integer "star_count", default: 0, null: false
|
|
t.string "import_type"
|
|
t.string "import_source"
|
|
t.text "import_data"
|
|
end
|
|
|
|
add_index "projects", ["created_at", "id"], name: "index_projects_on_created_at_and_id", using: :btree
|
|
add_index "projects", ["creator_id"], name: "index_projects_on_creator_id", using: :btree
|
|
add_index "projects", ["last_activity_at"], name: "index_projects_on_last_activity_at", using: :btree
|
|
add_index "projects", ["namespace_id"], name: "index_projects_on_namespace_id", using: :btree
|
|
add_index "projects", ["star_count"], name: "index_projects_on_star_count", using: :btree
|
|
|
|
create_table "protected_branches", force: true do |t|
|
|
t.integer "project_id", null: false
|
|
t.string "name", null: false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.boolean "developers_can_push", default: false, null: false
|
|
end
|
|
|
|
add_index "protected_branches", ["project_id"], name: "index_protected_branches_on_project_id", using: :btree
|
|
|
|
create_table "services", force: true do |t|
|
|
t.string "type"
|
|
t.string "title"
|
|
t.integer "project_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.boolean "active", default: false, null: false
|
|
t.text "properties"
|
|
t.boolean "template", default: false
|
|
t.boolean "push_events", default: true
|
|
t.boolean "issues_events", default: true
|
|
t.boolean "merge_requests_events", default: true
|
|
t.boolean "tag_push_events", default: true
|
|
t.boolean "note_events", default: true, null: false
|
|
end
|
|
|
|
add_index "services", ["created_at", "id"], name: "index_services_on_created_at_and_id", using: :btree
|
|
add_index "services", ["project_id"], name: "index_services_on_project_id", using: :btree
|
|
|
|
create_table "snippets", force: true do |t|
|
|
t.string "title"
|
|
t.text "content"
|
|
t.integer "author_id", null: false
|
|
t.integer "project_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "file_name"
|
|
t.datetime "expires_at"
|
|
t.string "type"
|
|
t.integer "visibility_level", default: 0, null: false
|
|
end
|
|
|
|
add_index "snippets", ["author_id"], name: "index_snippets_on_author_id", using: :btree
|
|
add_index "snippets", ["created_at", "id"], name: "index_snippets_on_created_at_and_id", using: :btree
|
|
add_index "snippets", ["created_at"], name: "index_snippets_on_created_at", using: :btree
|
|
add_index "snippets", ["expires_at"], name: "index_snippets_on_expires_at", using: :btree
|
|
add_index "snippets", ["project_id"], name: "index_snippets_on_project_id", using: :btree
|
|
add_index "snippets", ["visibility_level"], name: "index_snippets_on_visibility_level", using: :btree
|
|
|
|
create_table "subscriptions", force: true do |t|
|
|
t.integer "user_id"
|
|
t.integer "subscribable_id"
|
|
t.string "subscribable_type"
|
|
t.boolean "subscribed"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "subscriptions", ["subscribable_id", "subscribable_type", "user_id"], name: "subscriptions_user_id_and_ref_fields", unique: true, using: :btree
|
|
|
|
create_table "taggings", force: true do |t|
|
|
t.integer "tag_id"
|
|
t.integer "taggable_id"
|
|
t.string "taggable_type"
|
|
t.integer "tagger_id"
|
|
t.string "tagger_type"
|
|
t.string "context"
|
|
t.datetime "created_at"
|
|
end
|
|
|
|
add_index "taggings", ["tag_id"], name: "index_taggings_on_tag_id", using: :btree
|
|
add_index "taggings", ["taggable_id", "taggable_type", "context"], name: "index_taggings_on_taggable_id_and_taggable_type_and_context", using: :btree
|
|
|
|
create_table "tags", force: true do |t|
|
|
t.string "name"
|
|
end
|
|
|
|
create_table "users", force: true do |t|
|
|
t.string "email", default: "", null: false
|
|
t.string "encrypted_password", default: "", null: false
|
|
t.string "reset_password_token"
|
|
t.datetime "reset_password_sent_at"
|
|
t.datetime "remember_created_at"
|
|
t.integer "sign_in_count", default: 0
|
|
t.datetime "current_sign_in_at"
|
|
t.datetime "last_sign_in_at"
|
|
t.string "current_sign_in_ip"
|
|
t.string "last_sign_in_ip"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "name"
|
|
t.boolean "admin", default: false, null: false
|
|
t.integer "projects_limit", default: 10
|
|
t.string "skype", default: "", null: false
|
|
t.string "linkedin", default: "", null: false
|
|
t.string "twitter", default: "", null: false
|
|
t.string "authentication_token"
|
|
t.integer "theme_id", default: 1, null: false
|
|
t.string "bio"
|
|
t.integer "failed_attempts", default: 0
|
|
t.datetime "locked_at"
|
|
t.string "username"
|
|
t.boolean "can_create_group", default: true, null: false
|
|
t.boolean "can_create_team", default: true, null: false
|
|
t.string "state"
|
|
t.integer "color_scheme_id", default: 1, null: false
|
|
t.integer "notification_level", default: 1, null: false
|
|
t.datetime "password_expires_at"
|
|
t.integer "created_by_id"
|
|
t.datetime "last_credential_check_at"
|
|
t.string "avatar"
|
|
t.string "confirmation_token"
|
|
t.datetime "confirmed_at"
|
|
t.datetime "confirmation_sent_at"
|
|
t.string "unconfirmed_email"
|
|
t.boolean "hide_no_ssh_key", default: false
|
|
t.string "website_url", default: "", null: false
|
|
t.string "github_access_token"
|
|
t.string "gitlab_access_token"
|
|
t.string "notification_email"
|
|
t.boolean "hide_no_password", default: false
|
|
t.boolean "password_automatically_set", default: false
|
|
t.string "bitbucket_access_token"
|
|
t.string "bitbucket_access_token_secret"
|
|
t.string "location"
|
|
t.string "public_email", default: "", null: false
|
|
end
|
|
|
|
add_index "users", ["admin"], name: "index_users_on_admin", using: :btree
|
|
add_index "users", ["authentication_token"], name: "index_users_on_authentication_token", unique: true, using: :btree
|
|
add_index "users", ["confirmation_token"], name: "index_users_on_confirmation_token", unique: true, using: :btree
|
|
add_index "users", ["created_at", "id"], name: "index_users_on_created_at_and_id", using: :btree
|
|
add_index "users", ["current_sign_in_at"], name: "index_users_on_current_sign_in_at", using: :btree
|
|
add_index "users", ["email"], name: "index_users_on_email", unique: true, using: :btree
|
|
add_index "users", ["name"], name: "index_users_on_name", using: :btree
|
|
add_index "users", ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true, using: :btree
|
|
add_index "users", ["username"], name: "index_users_on_username", using: :btree
|
|
|
|
create_table "users_star_projects", force: true do |t|
|
|
t.integer "project_id", null: false
|
|
t.integer "user_id", null: false
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
end
|
|
|
|
add_index "users_star_projects", ["project_id"], name: "index_users_star_projects_on_project_id", using: :btree
|
|
add_index "users_star_projects", ["user_id", "project_id"], name: "index_users_star_projects_on_user_id_and_project_id", unique: true, using: :btree
|
|
add_index "users_star_projects", ["user_id"], name: "index_users_star_projects_on_user_id", using: :btree
|
|
|
|
create_table "web_hooks", force: true do |t|
|
|
t.string "url"
|
|
t.integer "project_id"
|
|
t.datetime "created_at"
|
|
t.datetime "updated_at"
|
|
t.string "type", default: "ProjectHook"
|
|
t.integer "service_id"
|
|
t.boolean "push_events", default: true, null: false
|
|
t.boolean "issues_events", default: false, null: false
|
|
t.boolean "merge_requests_events", default: false, null: false
|
|
t.boolean "tag_push_events", default: false
|
|
end
|
|
|
|
add_index "web_hooks", ["created_at", "id"], name: "index_web_hooks_on_created_at_and_id", using: :btree
|
|
add_index "web_hooks", ["project_id"], name: "index_web_hooks_on_project_id", using: :btree
|
|
|
|
end
|