Commit aeaf4e52 authored by Mehmet Emin INAC's avatar Mehmet Emin INAC

Update the `ee_features` docs

parent dbf1f265
...@@ -92,12 +92,36 @@ class User < ActiveRecord::Base ...@@ -92,12 +92,36 @@ class User < ActiveRecord::Base
# ... lots of code here ... # ... lots of code here ...
end end
User.prepend_if_ee('EE::User') User.prepend_ee_mod
``` ```
Do not use methods such as `prepend`, `extend`, and `include`. Instead, use Do not use methods such as `prepend`, `extend`, and `include`. Instead, use
`prepend_if_ee`, `extend_if_ee`, or `include_if_ee`. These methods take a `prepend_ee_mod`, `extend_ee_mod`, or `include_ee_mod`. These methods will try to
_String_ containing the full module name as the argument, not the module itself. find the relevant EE module by the name of the receiver module, for example;
```ruby
module Vulnerabilities
class Finding
#...
end
end
Vulnerabilities::Finding.prepend_ee_mod
```
will prepend the module named `::EE::Vulnerabilities::Finding`.
If the extending module does not follow this naming convention, you can also provide the module name
by using `prepend_if_ee`, `extend_if_ee`, or `include_if_ee`. These methods take a
_String_ containing the full module name as the argument, not the module itself, like so;
```ruby
class User
#...
end
User.prepend_if_ee('::EE::UserExtension')
```
Since the module would require an `EE` namespace, the file should also be Since the module would require an `EE` namespace, the file should also be
put in an `ee/` sub-directory. For example, we want to extend the user model put in an `ee/` sub-directory. For example, we want to extend the user model
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment