Full Mattermost server source with integrated Community Enterprise features. Includes vendor directory for offline/air-gapped builds. Structure: - enterprise-impl/: Enterprise feature implementations - enterprise-community/: Init files that register implementations - enterprise/: Bridge imports (community_imports.go) - vendor/: All dependencies for offline builds Build (online): go build ./cmd/mattermost Build (offline/air-gapped): go build -mod=vendor ./cmd/mattermost 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
89 lines
3.4 KiB
SQL
89 lines
3.4 KiB
SQL
CREATE TABLE IF NOT EXISTS users (
|
|
id VARCHAR(26) PRIMARY KEY,
|
|
createat bigint,
|
|
updateat bigint,
|
|
deleteat bigint,
|
|
username VARCHAR(64) UNIQUE,
|
|
password VARCHAR(128),
|
|
authdata VARCHAR(128) UNIQUE,
|
|
authservice VARCHAR(32),
|
|
email VARCHAR(128) UNIQUE,
|
|
emailverified boolean,
|
|
nickname VARCHAR(64),
|
|
firstname VARCHAR(64),
|
|
lastname VARCHAR(64),
|
|
roles VARCHAR(256),
|
|
allowmarketing boolean,
|
|
props VARCHAR(4000),
|
|
notifyprops VARCHAR(2000),
|
|
lastpasswordupdate bigint,
|
|
lastpictureupdate bigint,
|
|
failedattempts integer,
|
|
locale VARCHAR(5),
|
|
mfaactive boolean,
|
|
mfasecret VARCHAR(128)
|
|
);
|
|
|
|
ALTER TABLE users DROP COLUMN IF EXISTS lastactivityat;
|
|
ALTER TABLE users DROP COLUMN IF EXISTS lastpingat;
|
|
ALTER TABLE users ADD COLUMN IF NOT EXISTS position VARCHAR(128);
|
|
ALTER TABLE users ADD COLUMN IF NOT EXISTS timezone VARCHAR(256) DEFAULT '{"automaticTimezone":"","manualTimezone":"","useAutomaticTimezone":"true"}';
|
|
ALTER TABLE users ALTER COLUMN position TYPE VARCHAR(128);
|
|
|
|
DO $$
|
|
<< migrate_if_version_below_4100 >>
|
|
DECLARE
|
|
current_db_version VARCHAR(100) := '';
|
|
BEGIN
|
|
SELECT
|
|
value INTO current_db_version
|
|
FROM
|
|
systems
|
|
WHERE
|
|
name = 'Version';
|
|
IF (string_to_array(current_db_version, '.') < string_to_array('4.10.0', '.')) THEN
|
|
UPDATE Users SET AuthData=LOWER(AuthData) WHERE AuthService = 'saml';
|
|
END IF;
|
|
END migrate_if_version_below_4100
|
|
$$;
|
|
|
|
DO $$
|
|
DECLARE
|
|
column_exist boolean := false;
|
|
BEGIN
|
|
SELECT count(*) != 0 INTO column_exist
|
|
FROM information_schema.columns
|
|
WHERE table_name = 'users'
|
|
AND table_schema = current_schema()
|
|
AND column_name = 'roles'
|
|
AND NOT data_type = 'varchar(256)';
|
|
IF column_exist THEN
|
|
ALTER TABLE users ALTER COLUMN roles TYPE varchar(256);
|
|
END IF;
|
|
END $$;
|
|
|
|
CREATE INDEX IF NOT EXISTS idx_users_update_at ON users (updateat);
|
|
CREATE INDEX IF NOT EXISTS idx_users_create_at ON users (createat);
|
|
CREATE INDEX IF NOT EXISTS idx_users_delete_at ON users (deleteat);
|
|
|
|
CREATE INDEX IF NOT EXISTS idx_users_email_lower_textpattern ON users (lower(email) text_pattern_ops);
|
|
CREATE INDEX IF NOT EXISTS idx_users_username_lower_textpattern ON users (lower(username) text_pattern_ops);
|
|
CREATE INDEX IF NOT EXISTS idx_users_nickname_lower_textpattern ON users (lower(nickname) text_pattern_ops);
|
|
CREATE INDEX IF NOT EXISTS idx_users_firstname_lower_textpattern ON users (lower(firstname) text_pattern_ops);
|
|
CREATE INDEX IF NOT EXISTS idx_users_lastname_lower_textpattern ON users (lower(lastname) text_pattern_ops);
|
|
|
|
CREATE INDEX IF NOT EXISTS idx_users_all_txt ON users USING gin(to_tsvector('english', username || ' ' || firstname || ' ' || lastname || ' ' || nickname || ' ' || email));
|
|
CREATE INDEX IF NOT EXISTS idx_users_all_no_full_name_txt ON users USING gin(to_tsvector('english', username || ' ' || nickname || ' ' || email));
|
|
CREATE INDEX IF NOT EXISTS idx_users_names_txt ON users USING gin(to_tsvector('english', username || ' ' || firstname || ' ' || lastname || ' ' || nickname));
|
|
CREATE INDEX IF NOT EXISTS idx_users_names_no_full_name_txt ON users USING gin(to_tsvector('english', username || ' ' || nickname));
|
|
|
|
DROP INDEX IF EXISTS idx_users_email_lower;
|
|
DROP INDEX IF EXISTS idx_users_username_lower;
|
|
DROP INDEX IF EXISTS idx_users_nickname_lower;
|
|
DROP INDEX IF EXISTS idx_users_firstname_lower;
|
|
DROP INDEX IF EXISTS idx_users_lastname_lower;
|
|
|
|
ALTER TABLE users ADD COLUMN IF NOT EXISTS remoteid VARCHAR(26);
|
|
|
|
DROP INDEX IF EXISTS idx_users_email;
|