package config type MSCs struct { Matrix *Global `yaml:"-"` // The MSCs to enable. Supported MSCs include: // 'msc2444': Peeking over federation - https://github.com/matrix-org/matrix-doc/pull/2444 // 'msc2753': Peeking via /sync - https://github.com/matrix-org/matrix-doc/pull/2753 // 'msc2836': Threading - https://github.com/matrix-org/matrix-doc/pull/2836 // 'msc2965': Delegate auth to an OIDC provider https://github.com/matrix-org/matrix-spec-proposals/pull/2965 MSCs []string `yaml:"mscs"` MSC2965 *MSC2965 `yaml:"msc2965,omitempty"` Database DatabaseOptions `yaml:"database,omitempty"` } func (c *MSCs) Defaults(opts DefaultOpts) { if opts.Generate { if !opts.SingleDatabase { c.Database.ConnectionString = "file:mscs.db" } } } // Enabled returns true if the given msc is enabled. Should in the form 'msc12345'. func (c *MSCs) Enabled(msc string) bool { for _, m := range c.MSCs { if m == msc { return true } } return false } func (c *MSCs) Verify(configErrs *ConfigErrors) { if c.Matrix.DatabaseOptions.ConnectionString == "" { checkNotEmpty(configErrs, "mscs.database.connection_string", string(c.Database.ConnectionString)) } if m := c.MSC2965; m != nil { m.Verify(configErrs) } } type MSC2965 struct { Enabled bool `yaml:"enabled"` Issuer string `yaml:"issuer"` ClientID string `yaml:"client_id"` ClientSecret string `yaml:"client_secret"` AdminToken string `yaml:"admin_token"` AccountManagementURL string `yaml:"account_management_url"` } func (m *MSC2965) Verify(configErrs *ConfigErrors) { if !m.Enabled { return } checkNotEmpty(configErrs, "mscs.msc2965.issuer", string(m.Issuer)) checkNotEmpty(configErrs, "mscs.msc2965.client_id", string(m.ClientID)) checkNotEmpty(configErrs, "mscs.msc2965.client_secret", string(m.ClientSecret)) checkNotEmpty(configErrs, "mscs.msc2965.admin_token", string(m.AdminToken)) checkNotEmpty(configErrs, "mscs.msc2965.account_management_url", string(m.AccountManagementURL)) }