86 Commits

Author SHA1 Message Date
Logan Fick
ccc3f11bff Merged pull request #58. 2019-04-02 17:40:20 -04:00
Tadhg
2fd545ae92 Merge pull request #1 from Aberdeener/Aberdeener-patch-1
Changed to Search All Threads
2019-04-02 14:35:48 -07:00
Tadhg
94108c1b14 Changed to Search All Threads 2019-04-02 14:35:14 -07:00
Logan Fick
6ef42dc331 Merged pull request #57. 2019-03-01 12:56:10 -05:00
Futseh
52659dd446 You can now update a profile even if the discord field is empty 2019-03-01 18:47:45 +01:00
Futseh
b8c862c43b Removed the regex validation for discord name 2019-03-01 18:23:27 +01:00
Logan Fick
32e7b99b6d Merged pull request #56. 2019-02-24 13:01:53 -05:00
Futseh
2fe1cead68 Added an extra layer of security towards not deleting threads 2019-02-24 18:55:33 +01:00
Futseh
d52bf6d586 This got removed for some reason, will look into it 2019-02-24 18:27:09 +01:00
Futseh
f6cb866b85 Can disable the oppurtunity to delete threads in the forums 2019-02-24 18:17:46 +01:00
Futseh
20ef79278f Doesn't work yet, but are close 2019-02-24 18:14:34 +01:00
Logan Fick
244a047cad Merged pull request #55. 2019-02-23 13:56:59 -05:00
Logan Fick
293e86ee67 Merged pull request #54. 2019-02-23 13:53:18 -05:00
Futseh
9870b0e4a9 Merge pull request #3 from Futseh/changes_to_users
Changed the colour of the resend mail button to better fit our theme
2019-02-22 19:25:19 +01:00
Futseh
6bfdf30f07 Changed the colour of the resend mail button to better fit our theme 2019-02-22 19:23:42 +01:00
Futseh
87d620fc41 Merge pull request #2 from Futseh/changes_to_users
Validates that the discord name is valid
2019-02-22 19:09:09 +01:00
Futseh
1c9f62fb97 Validates that the discord name is valid 2019-02-22 19:07:34 +01:00
Futseh
0b9f49e491 Merge pull request #1 from Futseh/changes_to_users
Removed skype added discord for users
2019-02-22 16:48:45 +01:00
Futseh
b3a3473923 Removed skype field and added Discord on users. Also dropped unused table 2019-02-22 16:44:25 +01:00
Logan Fick
7bae0042a0 Licensed redstoner.com under Creative Commons Zero v1.0 Universal. 2019-02-12 09:22:28 -05:00
Logan Fick
a4535e6565 Fixed Linguist detecting repository language as HTML. 2019-02-12 09:09:16 -05:00
Minenash
7316f07b88 Update donate.html.erb 2019-01-30 11:53:16 -05:00
Logan Fick
ef1997ac90 Updated multiple gems. 2018-11-20 17:29:25 -05:00
Logan Fick
ed7ef61c64 Merged pull request #53. 2018-11-11 16:27:00 -05:00
Minenash
10e10a72be Updated donor name. 2018-11-11 13:11:36 -05:00
Logan Fick
0f52de4e63 Updated multiple gems. 2018-11-04 21:13:50 -05:00
Logan Fick
4942e85e97 Updated Capistrano version lock. 2018-10-08 19:12:15 -04:00
Logan Fick
895d99300a Removed Slack image from footer. 2018-10-08 19:09:15 -04:00
Logan Fick
41bec1341d Updated multiple gems. 2018-10-08 19:06:40 -04:00
Logan Fick
7d6f7fcb07 Fixed issue #52. 2018-10-08 18:47:49 -04:00
Logan Fick
0de6b08b4e Removed hostnames from user profiles. 2018-09-13 20:48:24 -04:00
Logan Fick
f3908410c8 Updated paths for online players and banned players JSON files. 2018-07-26 11:53:37 -04:00
Logan Fick
5054ec209d Fixed usage of old logging directory. 2018-07-25 22:26:33 -04:00
Logan Fick
004152dcbd Fixed usage of incorrect Ruby version number. 2018-07-25 22:25:35 -04:00
Logan Fick
fa7b5dc3bd Upgraded Ruby and moved installation directory. 2018-07-25 15:38:27 -04:00
Logan Fick
a363862d38 Added Discord link to footer. 2018-07-22 18:30:26 -04:00
Logan Fick
9b3ae8b399 Removed warnings from website settings. 2018-06-10 21:31:26 -04:00
Logan Fick
37be5f56b6 Merged pull request #50. 2018-06-10 21:08:22 -04:00
Logan Fick
09e3312cca Made formatting more consistent. 2018-06-09 13:02:43 -04:00
Logan Fick
12efb76930 Added enforcement for requirement of staff members having 2FA enabled. 2018-06-09 12:56:06 -04:00
Logan Fick
8158520bcc Made login settings page title and buttons leading to it consistent. 2018-06-07 22:11:58 -04:00
Logan Fick
e8038a5416 Fixed 2FA enforcement on login screen. 2018-06-07 21:51:54 -04:00
Logan Fick
e3eaccd430 Added ability to configure 2FA settings in login settings. 2018-06-07 21:45:02 -04:00
Logan Fick
4a49bae011 Fixed name inconsistency between migration and schema. 2018-06-07 20:47:28 -04:00
Logan Fick
ce8cb6f4ae Renamed TOTP secret column in schema. 2018-06-07 20:43:51 -04:00
Logan Fick
1d1b66f4a0 Fixed incorrect function name. 2018-06-07 20:37:58 -04:00
Logan Fick
6d22462d7a Added TOTP field to login screen. 2018-06-07 20:31:11 -04:00
Logan Fick
a241749ee3 Added TOTP toggle status to schema. 2018-06-07 20:27:13 -04:00
Logan Fick
201e59964e Cleaned up schema. 2018-06-06 18:44:31 -04:00
Logan Fick
7eeccbc006 Installed TOTP gem and added TOTP column to schema. 2018-06-06 18:38:28 -04:00
Logan Fick
3d8199c9f9 Reverted messy attempt at switch to Puma as app server. 2018-05-27 18:09:46 -04:00
Logan Fick
8f16fd709d Changed location that Puma binds to. 2018-05-27 16:23:51 -04:00
Logan Fick
e1bfa25e09 Added missing items in Puma config file. 2018-05-27 16:19:36 -04:00
Logan Fick
4f4d3834d2 Made Capistrano use Puma tasks. 2018-05-19 12:30:28 -04:00
Logan Fick
8e534e3330 Switched to using Puma as the app server. 2018-05-19 12:15:20 -04:00
Logan Fick
0d9663e70b Updated multiple gems. 2018-04-27 17:05:40 -04:00
Logan Fick
240d7e1e58 Fixed syntax error. 2018-04-23 21:41:23 -04:00
Logan Fick
f7206dc888 Changed the sender name for emails. 2018-04-23 21:20:55 -04:00
Logan Fick
806dbba92c Changed the contact email address in emails. 2018-04-21 12:08:42 -04:00
Logan Fick
87778aded5 Changed the from and reply to email addresses. 2018-04-21 12:00:30 -04:00
Logan Fick
e9f46813de Moved SMTP settings to environment variables. 2018-04-21 11:52:21 -04:00
Logan Fick
14dfc4c1cd Reverted back to regular logo and server name. 2018-04-01 18:01:26 -04:00
Logan Fick
4810065e58 Fixed use of incorrect new logo on home page. 2018-03-31 20:05:21 -04:00
Logan Fick
5852ef06ff Fixed inconsistent logos on dual logo image. 2018-03-31 20:01:05 -04:00
Logan Fick
5b97df57c8 Fixed use of incorrect logo and server name. 2018-03-31 19:54:48 -04:00
Logan Fick
d7ad2b04a5 Made Gemfile stop using fork of jquery-textcomplete-rails. 2018-03-21 11:03:19 -04:00
Logan Fick
8db1eb0b9b Fixed dependency version issues. 2018-03-21 10:51:04 -04:00
Logan Fick
5a3b330493 Updated multiple gems. 2018-03-21 10:32:31 -04:00
Logan Fick
16a2b0fa18 Made many buttons and titles more consistent. 2018-03-12 19:26:55 -04:00
Logan Fick
5eadded99c Reverted protocol upgrade. 2018-02-24 20:45:24 -05:00
Logan Fick
1df6347195 Upgraded protocol used to fetch gems from GitHub repositories. 2018-02-24 20:10:23 -05:00
Logan Fick
f6770ed275 Updated multiple gems. 2018-02-24 19:56:41 -05:00
Logan Fick
bc216cb5b9 Updated Ruby. 2018-02-24 19:30:09 -05:00
Logan Fick
e9d007b942 Updated Redcarpet. 2018-01-26 17:45:59 -05:00
Logan Fick
37557f6684 Updated Capistrano version lock. 2018-01-26 16:52:45 -05:00
Logan Fick
b9ad336ba9 Fixed dependency version issues. 2018-01-26 16:46:03 -05:00
Logan Fick
27aad9a486 Updated multiple gems. 2018-01-26 16:19:50 -05:00
Logan Fick
6c59e08d21 Updated nokogiri. 2018-01-26 09:45:41 -05:00
Logan Fick
df84114af2 Fixed rare circumstances causing internal server error when trying to sign up. 2017-12-17 14:05:13 -05:00
Logan Fick
3d260f9de0 Merge pull request #49. 2017-12-10 16:20:13 -05:00
Logan Fick
b40f85fe51 Changed capitalization of atom feed title. 2017-12-10 13:15:05 -05:00
Minenash
39fdd402f0 Update show.atom.builder 2017-12-10 12:59:13 -05:00
Logan Fick
9ec0a40027 Lowered amount of threads shown on forums atom feed. 2017-11-24 22:17:05 -05:00
Logan Fick
8796b3a415 Made user profile page show hostname of user's IP address. 2017-11-24 22:01:37 -05:00
Logan Fick
12baf8d5d7 Merge pull request #48. 2017-11-19 16:04:25 -05:00
Logan Fick
777ebca7f2 Added atom feed to forums. 2017-11-11 21:11:59 -05:00
57 changed files with 530 additions and 272 deletions

1
.gitattributes vendored Normal file
View File

@@ -0,0 +1 @@
public/* linguist-vendored

View File

@@ -7,16 +7,17 @@ gem 'jquery-rails'
gem 'bcrypt' # To use ActiveModel's has_secure_password gem 'bcrypt' # To use ActiveModel's has_secure_password
gem 'sanitize' gem 'sanitize'
gem 'strip_attributes' gem 'strip_attributes'
gem 'redcarpet', '~> 3.2.3' gem 'redcarpet'
gem 'hirb' # pretty console output gem 'hirb' # pretty console output
gem 'rb-readline' gem 'rb-readline'
gem 'rest-client' gem 'rest-client'
gem 'activerecord-session_store' gem 'activerecord-session_store'
gem 'highlight_js-rails', github: 'RedstonerServer/highlight_js-rails' gem 'highlight_js-rails', github: 'RedstonerServer/highlight_js-rails'
gem 'kaminari', github: 'jomo/kaminari', branch: 'patch-2' # pagination gem 'kaminari', github: 'jomo/kaminari', branch: 'patch-2' # pagination
gem 'jquery-textcomplete-rails', github: 'RedstonerServer/jquery-textcomplete-rails' # @mentions gem 'jquery-textcomplete-rails' # @mentions
gem 'actionpack-action_caching', github: 'antulik/actionpack-action_caching', ref: '8c6e52c69315d67437f480da5dce4b7c8737fb32' gem 'actionpack-action_caching', github: 'antulik/actionpack-action_caching', ref: '8c6e52c69315d67437f480da5dce4b7c8737fb32'
gem 'mail-gpg', github: 'jomo/mail-gpg', ref: 'a666b48ee866dfa3eaa700f9c5edf4d195d0f8c9' gem 'mail-gpg', github: 'jomo/mail-gpg', ref: 'a666b48ee866dfa3eaa700f9c5edf4d195d0f8c9'
gem 'totp'
# Gems used only for assets and not required # Gems used only for assets and not required
# in production environments by default. # in production environments by default.

View File

@@ -5,15 +5,6 @@ GIT
highlight_js-rails (8.4) highlight_js-rails (8.4)
rails (>= 3.1.1) rails (>= 3.1.1)
GIT
remote: git://github.com/RedstonerServer/jquery-textcomplete-rails.git
revision: 8bf23af2d8fa1c5226c2b6889c7796adfe1f8772
specs:
jquery-textcomplete-rails (0.1.4)
coffee-rails (>= 3.2.0)
railties (>= 3.2.0)
sass-rails (>= 3.2.0)
GIT GIT
remote: git://github.com/antulik/actionpack-action_caching.git remote: git://github.com/antulik/actionpack-action_caching.git
revision: 8c6e52c69315d67437f480da5dce4b7c8737fb32 revision: 8c6e52c69315d67437f480da5dce4b7c8737fb32
@@ -42,202 +33,224 @@ GIT
GIT GIT
remote: git://github.com/rails/rails.git remote: git://github.com/rails/rails.git
revision: 2c8f567e53580872d8c6dfe61201e58793ca131e revision: 22aec58a2565a76e0f55d05d045b7a45715c5bb9
branch: 4-2-stable branch: 4-2-stable
specs: specs:
actionmailer (4.2.5.1) actionmailer (4.2.10)
actionpack (= 4.2.5.1) actionpack (= 4.2.10)
actionview (= 4.2.5.1) actionview (= 4.2.10)
activejob (= 4.2.5.1) activejob (= 4.2.10)
mail (~> 2.5, >= 2.5.4) mail (~> 2.5, >= 2.5.4)
rails-dom-testing (~> 1.0, >= 1.0.5) rails-dom-testing (~> 1.0, >= 1.0.5)
actionpack (4.2.5.1) actionpack (4.2.10)
actionview (= 4.2.5.1) actionview (= 4.2.10)
activesupport (= 4.2.5.1) activesupport (= 4.2.10)
rack (~> 1.6) rack (~> 1.6)
rack-test (~> 0.6.2) rack-test (~> 0.6.2)
rails-dom-testing (~> 1.0, >= 1.0.5) rails-dom-testing (~> 1.0, >= 1.0.5)
rails-html-sanitizer (~> 1.0, >= 1.0.2) rails-html-sanitizer (~> 1.0, >= 1.0.2)
actionview (4.2.5.1) actionview (4.2.10)
activesupport (= 4.2.5.1) activesupport (= 4.2.10)
builder (~> 3.1) builder (~> 3.1)
erubis (~> 2.7.0) erubis (~> 2.7.0)
rails-dom-testing (~> 1.0, >= 1.0.5) rails-dom-testing (~> 1.0, >= 1.0.5)
rails-html-sanitizer (~> 1.0, >= 1.0.2) rails-html-sanitizer (~> 1.0, >= 1.0.3)
activejob (4.2.5.1) activejob (4.2.10)
activesupport (= 4.2.5.1) activesupport (= 4.2.10)
globalid (>= 0.3.0) globalid (>= 0.3.0)
activemodel (4.2.5.1) activemodel (4.2.10)
activesupport (= 4.2.5.1) activesupport (= 4.2.10)
builder (~> 3.1) builder (~> 3.1)
activerecord (4.2.5.1) activerecord (4.2.10)
activemodel (= 4.2.5.1) activemodel (= 4.2.10)
activesupport (= 4.2.5.1) activesupport (= 4.2.10)
arel (~> 6.0) arel (~> 6.0)
activesupport (4.2.5.1) activesupport (4.2.10)
i18n (~> 0.7) i18n (~> 0.7)
json (~> 1.7, >= 1.7.7)
minitest (~> 5.1) minitest (~> 5.1)
thread_safe (~> 0.3, >= 0.3.4) thread_safe (~> 0.3, >= 0.3.4)
tzinfo (~> 1.1) tzinfo (~> 1.1)
rails (4.2.5.1) rails (4.2.10)
actionmailer (= 4.2.5.1) actionmailer (= 4.2.10)
actionpack (= 4.2.5.1) actionpack (= 4.2.10)
actionview (= 4.2.5.1) actionview (= 4.2.10)
activejob (= 4.2.5.1) activejob (= 4.2.10)
activemodel (= 4.2.5.1) activemodel (= 4.2.10)
activerecord (= 4.2.5.1) activerecord (= 4.2.10)
activesupport (= 4.2.5.1) activesupport (= 4.2.10)
bundler (>= 1.3.0, < 2.0) bundler (>= 1.3.0, < 2.0)
railties (= 4.2.5.1) railties (= 4.2.10)
sprockets-rails sprockets-rails
railties (4.2.5.1) railties (4.2.10)
actionpack (= 4.2.5.1) actionpack (= 4.2.10)
activesupport (= 4.2.5.1) activesupport (= 4.2.10)
rake (>= 0.8.7) rake (>= 0.8.7)
thor (>= 0.18.1, < 2.0) thor (>= 0.18.1, < 2.0)
GEM GEM
remote: https://rubygems.org/ remote: https://rubygems.org/
specs: specs:
activerecord-session_store (0.1.2) activerecord-session_store (1.1.1)
actionpack (>= 4.0.0, < 5) actionpack (>= 4.0)
activerecord (>= 4.0.0, < 5) activerecord (>= 4.0)
railties (>= 4.0.0, < 5) multi_json (~> 1.11, >= 1.11.2)
arel (6.0.3) rack (>= 1.5.2, < 3)
bcrypt (3.1.10) railties (>= 4.0)
better_errors (2.1.1) airbrussh (1.3.1)
sshkit (>= 1.6.1, != 1.7.0)
arel (6.0.4)
base32 (0.3.2)
bcrypt (3.1.12)
better_errors (2.5.0)
coderay (>= 1.0.0) coderay (>= 1.0.0)
erubis (>= 2.6.6) erubi (>= 1.0.0)
rack (>= 0.9.0) rack (>= 0.9.0)
binding_of_caller (0.7.2) binding_of_caller (0.8.0)
debug_inspector (>= 0.0.1) debug_inspector (>= 0.0.1)
builder (3.2.2) builder (3.2.3)
capistrano (3.4.0) capistrano (3.11.0)
airbrussh (>= 1.0.0)
i18n i18n
rake (>= 10.0.0) rake (>= 10.0.0)
sshkit (~> 1.3) sshkit (>= 1.9.0)
capistrano-bundler (1.1.4) capistrano-bundler (1.1.4)
capistrano (~> 3.1) capistrano (~> 3.1)
sshkit (~> 1.2) sshkit (~> 1.2)
capistrano-rails (1.1.6) capistrano-rails (1.1.8)
capistrano (~> 3.1) capistrano (~> 3.1)
capistrano-bundler (~> 1.1) capistrano-bundler (~> 1.1)
capistrano-rbenv (2.0.4) capistrano-rbenv (2.1.4)
capistrano (~> 3.1) capistrano (~> 3.1)
sshkit (~> 1.3) sshkit (~> 1.3)
choice (0.2.0) choice (0.2.0)
coderay (1.1.0) coderay (1.1.2)
coffee-rails (4.1.1) coffee-rails (4.2.2)
coffee-script (>= 2.2.0) coffee-script (>= 2.2.0)
railties (>= 4.0.0, < 5.1.x) railties (>= 4.0.0)
coffee-script (2.4.1) coffee-script (2.4.1)
coffee-script-source coffee-script-source
execjs execjs
coffee-script-source (1.10.0) coffee-script-source (1.12.2)
concurrent-ruby (1.0.0) concurrent-ruby (1.1.3)
crass (1.0.2) crass (1.0.4)
debug_inspector (0.0.2) debug_inspector (0.0.3)
domain_name (0.5.25) domain_name (0.5.20180417)
unf (>= 0.0.5, < 1.0.0) unf (>= 0.0.5, < 1.0.0)
erubi (1.7.1)
erubis (2.7.0) erubis (2.7.0)
execjs (2.6.0) execjs (2.7.0)
globalid (0.3.6) ffi (1.9.25)
activesupport (>= 4.1.0) globalid (0.4.1)
gpgme (2.0.11) activesupport (>= 4.2.0)
mini_portile (>= 0.5.0) gpgme (2.0.16)
mini_portile2 (~> 2.3)
hirb (0.7.3) hirb (0.7.3)
http-cookie (1.0.2) http-cookie (1.0.3)
domain_name (~> 0.5) domain_name (~> 0.5)
i18n (0.7.0) i18n (0.9.5)
jquery-rails (4.1.0) concurrent-ruby (~> 1.0)
rails-dom-testing (~> 1.0) jquery-rails (4.3.3)
rails-dom-testing (>= 1, < 3)
railties (>= 4.2.0) railties (>= 4.2.0)
thor (>= 0.14, < 2.0) thor (>= 0.14, < 2.0)
json (1.8.3) jquery-textcomplete-rails (0.1.5)
kgio (2.10.0) coffee-rails (>= 3.2.0)
loofah (2.0.3) railties (>= 3.2.0)
sass-rails (>= 3.2.0)
kgio (2.11.2)
loofah (2.2.3)
crass (~> 1.0.2)
nokogiri (>= 1.5.9) nokogiri (>= 1.5.9)
mail (2.6.3) mail (2.7.1)
mime-types (>= 1.16, < 3) mini_mime (>= 0.1.1)
mime-types (2.99) mime-types (3.2.2)
mini_portile (0.6.2) mime-types-data (~> 3.2015)
mini_portile2 (2.0.0) mime-types-data (3.2018.0812)
minitest (5.8.4) mini_mime (1.0.1)
mysql2 (0.4.2) mini_portile2 (2.3.0)
minitest (5.11.3)
multi_json (1.13.1)
mysql2 (0.5.2)
net-scp (1.2.1) net-scp (1.2.1)
net-ssh (>= 2.6.5) net-ssh (>= 2.6.5)
net-ssh (3.0.2) net-ssh (5.0.2)
netrc (0.11.0) netrc (0.11.0)
nokogiri (1.6.7.2) nokogiri (1.8.5)
mini_portile2 (~> 2.0.0.rc2) mini_portile2 (~> 2.3.0)
nokogumbo (1.4.7) nokogumbo (2.0.1)
nokogiri nokogiri (~> 1.8, >= 1.8.4)
rack (1.6.4) rack (1.6.11)
rack-test (0.6.3) rack-test (0.6.3)
rack (>= 1.0) rack (>= 1.0)
rails-deprecated_sanitizer (1.0.3) rails-deprecated_sanitizer (1.0.3)
activesupport (>= 4.2.0.alpha) activesupport (>= 4.2.0.alpha)
rails-dom-testing (1.0.7) rails-dom-testing (1.0.9)
activesupport (>= 4.2.0.beta, < 5.0) activesupport (>= 4.2.0, < 5.0)
nokogiri (~> 1.6.0) nokogiri (~> 1.6)
rails-deprecated_sanitizer (>= 1.0.1) rails-deprecated_sanitizer (>= 1.0.1)
rails-erd (1.4.5) rails-erd (1.5.2)
activerecord (>= 3.2) activerecord (>= 3.2)
activesupport (>= 3.2) activesupport (>= 3.2)
choice (~> 0.2.0) choice (~> 0.2.0)
ruby-graphviz (~> 1.2) ruby-graphviz (~> 1.2)
rails-html-sanitizer (1.0.3) rails-html-sanitizer (1.0.4)
loofah (~> 2.0) loofah (~> 2.2, >= 2.2.2)
raindrops (0.15.0) raindrops (0.19.0)
rake (10.5.0) rake (12.3.2)
rb-readline (0.5.3) rb-fsevent (0.10.3)
redcarpet (3.2.3) rb-inotify (0.9.10)
rest-client (1.8.0) ffi (>= 0.5.0, < 2)
rb-readline (0.5.5)
redcarpet (3.4.0)
rest-client (2.0.2)
http-cookie (>= 1.0.2, < 2.0) http-cookie (>= 1.0.2, < 2.0)
mime-types (>= 1.16, < 3.0) mime-types (>= 1.16, < 4.0)
netrc (~> 0.7) netrc (~> 0.8)
ruby-graphviz (1.2.2) ruby-graphviz (1.2.4)
sanitize (4.0.1) sanitize (5.0.0)
crass (~> 1.0.2) crass (~> 1.0.2)
nokogiri (>= 1.4.4) nokogiri (>= 1.8.0)
nokogumbo (~> 1.4.1) nokogumbo (~> 2.0)
sass (3.4.21) sass (3.7.2)
sass-rails (5.0.4) sass-listen (~> 4.0.0)
railties (>= 4.0.0, < 5.0) sass-listen (4.0.0)
rb-fsevent (~> 0.9, >= 0.9.4)
rb-inotify (~> 0.9, >= 0.9.7)
sass-rails (5.0.7)
railties (>= 4.0.0, < 6)
sass (~> 3.1) sass (~> 3.1)
sprockets (>= 2.8, < 4.0) sprockets (>= 2.8, < 4.0)
sprockets-rails (>= 2.0, < 4.0) sprockets-rails (>= 2.0, < 4.0)
tilt (>= 1.1, < 3) tilt (>= 1.1, < 3)
sprockets (3.5.2) sprockets (3.7.2)
concurrent-ruby (~> 1.0) concurrent-ruby (~> 1.0)
rack (> 1, < 3) rack (> 1, < 3)
sprockets-rails (3.0.0) sprockets-rails (3.2.1)
actionpack (>= 4.0) actionpack (>= 4.0)
activesupport (>= 4.0) activesupport (>= 4.0)
sprockets (>= 3.0.0) sprockets (>= 3.0.0)
sqlite3 (1.3.11) sqlite3 (1.3.13)
sshkit (1.8.1) sshkit (1.18.0)
net-scp (>= 1.1.2) net-scp (>= 1.1.2)
net-ssh (>= 2.8.0) net-ssh (>= 2.8.0)
strip_attributes (1.7.1) strip_attributes (1.8.0)
activemodel (>= 3.0, < 5.0) activemodel (>= 3.0, < 6.0)
thor (0.19.1) thor (0.20.3)
thread_safe (0.3.5) thread_safe (0.3.6)
tilt (2.0.2) tilt (2.0.8)
tzinfo (1.2.2) totp (1.0.0)
base32
tzinfo (1.2.5)
thread_safe (~> 0.1) thread_safe (~> 0.1)
uglifier (2.7.2) uglifier (4.1.20)
execjs (>= 0.3.0) execjs (>= 0.3.0, < 3)
json (>= 1.8.0)
unf (0.1.4) unf (0.1.4)
unf_ext unf_ext
unf_ext (0.0.7.1) unf_ext (0.0.7.5)
unicorn (5.0.1) unicorn (5.4.1)
kgio (~> 2.6) kgio (~> 2.6)
rack
raindrops (~> 0.7) raindrops (~> 0.7)
webrick (1.3.1) webrick (1.4.2)
PLATFORMS PLATFORMS
ruby ruby
@@ -254,23 +267,24 @@ DEPENDENCIES
highlight_js-rails! highlight_js-rails!
hirb hirb
jquery-rails jquery-rails
jquery-textcomplete-rails! jquery-textcomplete-rails
kaminari! kaminari!
mail-gpg! mail-gpg!
mysql2 mysql2
rails! rails!
rails-erd rails-erd
rb-readline rb-readline
redcarpet (~> 3.2.3) redcarpet
rest-client rest-client
sanitize sanitize
sass-rails sass-rails
sqlite3 sqlite3
strip_attributes strip_attributes
totp
tzinfo-data tzinfo-data
uglifier uglifier
unicorn unicorn
webrick webrick
BUNDLED WITH BUNDLED WITH
1.11.2 1.17.3

116
LICENSE.txt Normal file
View File

@@ -0,0 +1,116 @@
CC0 1.0 Universal
Statement of Purpose
The laws of most jurisdictions throughout the world automatically confer
exclusive Copyright and Related Rights (defined below) upon the creator and
subsequent owner(s) (each and all, an "owner") of an original work of
authorship and/or a database (each, a "Work").
Certain owners wish to permanently relinquish those rights to a Work for the
purpose of contributing to a commons of creative, cultural and scientific
works ("Commons") that the public can reliably and without fear of later
claims of infringement build upon, modify, incorporate in other works, reuse
and redistribute as freely as possible in any form whatsoever and for any
purposes, including without limitation commercial purposes. These owners may
contribute to the Commons to promote the ideal of a free culture and the
further production of creative, cultural and scientific works, or to gain
reputation or greater distribution for their Work in part through the use and
efforts of others.
For these and/or other purposes and motivations, and without any expectation
of additional consideration or compensation, the person associating CC0 with a
Work (the "Affirmer"), to the extent that he or she is an owner of Copyright
and Related Rights in the Work, voluntarily elects to apply CC0 to the Work
and publicly distribute the Work under its terms, with knowledge of his or her
Copyright and Related Rights in the Work and the meaning and intended legal
effect of CC0 on those rights.
1. Copyright and Related Rights. A Work made available under CC0 may be
protected by copyright and related or neighboring rights ("Copyright and
Related Rights"). Copyright and Related Rights include, but are not limited
to, the following:
i. the right to reproduce, adapt, distribute, perform, display, communicate,
and translate a Work;
ii. moral rights retained by the original author(s) and/or performer(s);
iii. publicity and privacy rights pertaining to a person's image or likeness
depicted in a Work;
iv. rights protecting against unfair competition in regards to a Work,
subject to the limitations in paragraph 4(a), below;
v. rights protecting the extraction, dissemination, use and reuse of data in
a Work;
vi. database rights (such as those arising under Directive 96/9/EC of the
European Parliament and of the Council of 11 March 1996 on the legal
protection of databases, and under any national implementation thereof,
including any amended or successor version of such directive); and
vii. other similar, equivalent or corresponding rights throughout the world
based on applicable law or treaty, and any national implementations thereof.
2. Waiver. To the greatest extent permitted by, but not in contravention of,
applicable law, Affirmer hereby overtly, fully, permanently, irrevocably and
unconditionally waives, abandons, and surrenders all of Affirmer's Copyright
and Related Rights and associated claims and causes of action, whether now
known or unknown (including existing as well as future claims and causes of
action), in the Work (i) in all territories worldwide, (ii) for the maximum
duration provided by applicable law or treaty (including future time
extensions), (iii) in any current or future medium and for any number of
copies, and (iv) for any purpose whatsoever, including without limitation
commercial, advertising or promotional purposes (the "Waiver"). Affirmer makes
the Waiver for the benefit of each member of the public at large and to the
detriment of Affirmer's heirs and successors, fully intending that such Waiver
shall not be subject to revocation, rescission, cancellation, termination, or
any other legal or equitable action to disrupt the quiet enjoyment of the Work
by the public as contemplated by Affirmer's express Statement of Purpose.
3. Public License Fallback. Should any part of the Waiver for any reason be
judged legally invalid or ineffective under applicable law, then the Waiver
shall be preserved to the maximum extent permitted taking into account
Affirmer's express Statement of Purpose. In addition, to the extent the Waiver
is so judged Affirmer hereby grants to each affected person a royalty-free,
non transferable, non sublicensable, non exclusive, irrevocable and
unconditional license to exercise Affirmer's Copyright and Related Rights in
the Work (i) in all territories worldwide, (ii) for the maximum duration
provided by applicable law or treaty (including future time extensions), (iii)
in any current or future medium and for any number of copies, and (iv) for any
purpose whatsoever, including without limitation commercial, advertising or
promotional purposes (the "License"). The License shall be deemed effective as
of the date CC0 was applied by Affirmer to the Work. Should any part of the
License for any reason be judged legally invalid or ineffective under
applicable law, such partial invalidity or ineffectiveness shall not
invalidate the remainder of the License, and in such case Affirmer hereby
affirms that he or she will not (i) exercise any of his or her remaining
Copyright and Related Rights in the Work or (ii) assert any associated claims
and causes of action with respect to the Work, in either case contrary to
Affirmer's express Statement of Purpose.
4. Limitations and Disclaimers.
a. No trademark or patent rights held by Affirmer are waived, abandoned,
surrendered, licensed or otherwise affected by this document.
b. Affirmer offers the Work as-is and makes no representations or warranties
of any kind concerning the Work, express, implied, statutory or otherwise,
including without limitation warranties of title, merchantability, fitness
for a particular purpose, non infringement, or the absence of latent or
other defects, accuracy, or the present or absence of errors, whether or not
discoverable, all to the greatest extent permissible under applicable law.
c. Affirmer disclaims responsibility for clearing rights of other persons
that may apply to the Work or any use thereof, including without limitation
any person's Copyright and Related Rights in the Work. Further, Affirmer
disclaims responsibility for obtaining any necessary consents, permissions
or other rights required for any use of the Work.
d. Affirmer understands and acknowledges that Creative Commons is not a
party to this document and has no duty or obligation with respect to this
CC0 or use of the Work.
For more information, please see
<http://creativecommons.org/publicdomain/zero/1.0/>

Binary file not shown.

After

Width:  |  Height:  |  Size: 315 B

View File

@@ -1,6 +1,6 @@
class ApplicationController < ActionController::Base class ApplicationController < ActionController::Base
protect_from_forgery protect_from_forgery
before_filter :update_ip, :update_seen, :check_banned before_filter :update_ip, :update_seen, :check_banned, :check_2fa
# TODO: use SSL # TODO: use SSL
@@ -41,6 +41,14 @@ class ApplicationController < ActionController::Base
end end
end end
def check_2fa
# Over complicated way of asking if the user is logged in as a mod without TOTP enabled while they are not on their login settings screen, logging out, or updating their login settings.
if current_user && current_user.mod? && !current_user.totp_enabled? && !(controller_name == "users" && action_name == "edit_login") && !(controller_name == "sessions" && action_name == "destroy") && !(controller_name == "users" && action_name == "update_login")
flash[:alert] = "Due to your staff rank, you are required to enable 2FA."
redirect_to :controller => "users", :action => "edit_login", :id => current_user.id
end
end
#roles #roles
def disabled? def disabled?

View File

@@ -89,7 +89,7 @@ class ForumsController < ApplicationController
end end
def forum_params(add = []) def forum_params(add = [])
a = [:name, :position, :role_read_id, :role_write_id, :necro_length] + add a = [:name, :position, :role_read_id, :role_write_id, :necro_length, :disable_deletion] + add
params.require(:forum).permit(a) params.require(:forum).permit(a)
end end
end end

View File

@@ -10,6 +10,7 @@ class ForumthreadsController < ApplicationController
@threads = Forumthread.filter(current_user, params[:title].try(:slice, 0..255), params[:content].try(:slice, 0..255), params[:reply].try(:slice, 0..255), params[:label], User.find_by(ign: params[:author].to_s.strip) || params[:author], params[:query].try(:slice, 0..255), Forum.find_by(id: params[:forum])) @threads = Forumthread.filter(current_user, params[:title].try(:slice, 0..255), params[:content].try(:slice, 0..255), params[:reply].try(:slice, 0..255), params[:label], User.find_by(ign: params[:author].to_s.strip) || params[:author], params[:query].try(:slice, 0..255), Forum.find_by(id: params[:forum]))
.page(params[:page]).per(30) .page(params[:page]).per(30)
end end
def show def show
if params[:reverse] == "true" if params[:reverse] == "true"
@replies = @thread.replies.order(id: :desc).page(params[:page]) @replies = @thread.replies.order(id: :desc).page(params[:page])
@@ -72,7 +73,7 @@ class ForumthreadsController < ApplicationController
end end
def destroy def destroy
if mod? || @thread.author.is?(current_user) if mod? || (@thread.author.is?(current_user) && !@thread.forum.disable_deletion)
if @thread.destroy if @thread.destroy
flash[:notice] = "Thread deleted!" flash[:notice] = "Thread deleted!"
else else

View File

@@ -21,6 +21,10 @@ class SessionsController < ApplicationController
flash[:alert] = "Your account has been disabled!" flash[:alert] = "Your account has been disabled!"
elsif user.banned? elsif user.banned?
flash[:alert] = "You are banned!" flash[:alert] = "You are banned!"
elsif user.totp_enabled && !TOTP.valid?(user.totp_secret, params[:totp_code].to_i)
flash[:alert] = "You're doing it wrong!"
render action: 'new'
return
else else
session[:user_id] = user.id session[:user_id] = user.id
flash[:notice] = "Logged in!" flash[:notice] = "Logged in!"
@@ -110,4 +114,4 @@ class SessionsController < ApplicationController
redirect_to login_path redirect_to login_path
end end
end end
end end

View File

@@ -20,7 +20,7 @@ class StaticsController < ApplicationController
@players = [] @players = []
@count = 0 @count = 0
begin begin
json = JSON.parse(File.read("/etc/minecraft/redstoner/plugins/ModuleLoader/players.json")) json = JSON.parse(File.read("/etc/minecraft/info/players.json"))
rescue rescue
flash.now[:alert] = "The server is currently offline." flash.now[:alert] = "The server is currently offline."
else else

View File

@@ -17,7 +17,7 @@ class UsersController < ApplicationController
def show def show
begin begin
@ban_json = JSON.parse(File.read("/etc/minecraft/redstoner/banned-players.json")).detect {|u| u["uuid"].tr("-", "") == @user.uuid} @ban_json = JSON.parse(File.read("/etc/minecraft/info/banned-players.json")).detect {|u| u["uuid"].tr("-", "") == @user.uuid}
rescue rescue
flash.now[:alert] = "An error occured while checking if this user is banned from the server!" flash.now[:alert] = "An error occured while checking if this user is banned from the server!"
@ban_json = nil @ban_json = nil
@@ -87,6 +87,12 @@ class UsersController < ApplicationController
@user.uuid = user_profile["id"] @user.uuid = user_profile["id"]
@user.ign = user_profile["name"] # correct case @user.ign = user_profile["name"] # correct case
if User.find_by(uuid: @user.uuid)
flash[:alert] = "You already have a Redstoner account associated with this Minecraft account. Please log in instead."
redirect_to login_path
return
end
if validate_token(@user.uuid, @user.email, params[:registration_token]) if validate_token(@user.uuid, @user.email, params[:registration_token])
destroy_token(params[:email]) destroy_token(params[:email])
@user.last_ip = request.remote_ip # showing in mail @user.last_ip = request.remote_ip # showing in mail
@@ -143,9 +149,9 @@ class UsersController < ApplicationController
def update def update
if (mod? && current_user.role >= @user.role ) || (@user.is?(current_user) && confirmed?) if (mod? && current_user.role >= @user.role ) || (@user.is?(current_user) && confirmed?)
if mod? if mod?
userdata = user_params([:name, :skype, :youtube, :twitter, :about, :role, :badge, :confirmed, :header_scroll, :utc_time, :dark]) userdata = user_params([:name, :discord, :youtube, :twitter, :about, :role, :badge, :confirmed, :header_scroll, :utc_time, :dark])
else else
userdata = user_params([:name, :skype, :youtube, :twitter, :about, :header_scroll, :utc_time, :dark]) userdata = user_params([:name, :discord, :youtube, :twitter, :about, :header_scroll, :utc_time, :dark])
end end
if User.find_by(name: userdata[:name]) && User.find_by(name: userdata[:name]) != @user if User.find_by(name: userdata[:name]) && User.find_by(name: userdata[:name]) != @user
flash[:alert] = "You have entered a name that belongs to someone else. Please try another." flash[:alert] = "You have entered a name that belongs to someone else. Please try another."
@@ -229,6 +235,11 @@ class UsersController < ApplicationController
unless @user.is?(current_user) || admin? && current_user.role > @user.role || superadmin? unless @user.is?(current_user) || admin? && current_user.role > @user.role || superadmin?
flash[:alert] = "You are not allowed to edit this user's login details!" flash[:alert] = "You are not allowed to edit this user's login details!"
redirect_to @user redirect_to @user
return
end
if !@user.totp_enabled
@user.update(totp_secret: TOTP.secret)
end end
end end
@@ -251,6 +262,18 @@ class UsersController < ApplicationController
@user.email_token = SecureRandom.hex(16) if mail_changed @user.email_token = SecureRandom.hex(16) if mail_changed
@user.confirmed = !mail_changed @user.confirmed = !mail_changed
if params[:user][:totp_enabled] == "1" && !@user.totp_enabled
if TOTP.valid?(@user.totp_secret, params[:totp_code].to_i)
@user.totp_enabled = true
else
flash[:alert] = "Wrong TOTP code!"
render action: "edit_login"
return
end
elsif params[:user][:totp_enabled] == "0" && @user.totp_enabled
@user.totp_enabled = false
end
# checking here for password so we can send back changes to the view # checking here for password so we can send back changes to the view
if authenticated if authenticated
if @user.save if @user.save
@@ -358,7 +381,7 @@ class UsersController < ApplicationController
end end
def user_params(add = []) def user_params(add = [])
a = [:ign, :email, :password, :password_confirmation, :mail_own_thread_reply, :mail_other_thread_reply, :mail_own_blogpost_comment, :mail_other_blogpost_comment, :mail_mention, :public_key] + add a = [:ign, :email, :password, :password_confirmation, :mail_own_thread_reply, :mail_other_thread_reply, :mail_own_blogpost_comment, :mail_other_blogpost_comment, :mail_mention, :public_key, :totp_code] + add
params.require(:user).permit(a) params.require(:user).permit(a)
end end
end end

View File

@@ -51,5 +51,4 @@ module UsersHelper
return nil return nil
end end
end end
end end

View File

@@ -1,8 +1,8 @@
class RedstonerMailer < ActionMailer::Base class RedstonerMailer < ActionMailer::Base
add_template_helper(ApplicationHelper) add_template_helper(ApplicationHelper)
default from: "info@redstoner.com" default from: "\"Redstoner\" <noreply@redstoner.com>"
default reply_to: "redstonerserver+website@gmail.com" default reply_to: "staff@redstoner.com"
def register_mail(user, uses_mc_pass) def register_mail(user, uses_mc_pass)
@user = user @user = user

View File

@@ -21,6 +21,7 @@ class User < ActiveRecord::Base
validates :email, uniqueness: {case_sensitive: false}, format: {with: /\A.+@(.+\..{2,}|\[(IPv6)?[0-9a-f:.]+\])\z/i, message: "That doesn't look like an email address."} validates :email, uniqueness: {case_sensitive: false}, format: {with: /\A.+@(.+\..{2,}|\[(IPv6)?[0-9a-f:.]+\])\z/i, message: "That doesn't look like an email address."}
validates :ign, uniqueness: {case_sensitive: false}, format: {with: /\A[a-z\d_]+\z/i, message: "Username is invalid (a-z, 0-9, _)."} validates :ign, uniqueness: {case_sensitive: false}, format: {with: /\A[a-z\d_]+\z/i, message: "Username is invalid (a-z, 0-9, _)."}
validates :discord, uniqueness: {case_sensitive: false}, format: {with: /\A^(?!everyone|here|discordtag|.*```.*)([^@#:]{2,32}#[0-9]{4})$\z/i, message: "Discord name is invalid."}, allow_blank: true
validates :public_key, format: {with: /\A(-----BEGIN PGP PUBLIC KEY BLOCK-----((.|\n)*?)-----END PGP PUBLIC KEY BLOCK-----)?\z/i, message: "That doesn't look like a PGP formatted public key."} validates :public_key, format: {with: /\A(-----BEGIN PGP PUBLIC KEY BLOCK-----((.|\n)*?)-----END PGP PUBLIC KEY BLOCK-----)?\z/i, message: "That doesn't look like a PGP formatted public key."}
@@ -168,7 +169,7 @@ class User < ActiveRecord::Base
self.ign.strip! if self.ign self.ign.strip! if self.ign
self.email.strip! if self.email self.email.strip! if self.email
self.about.strip! if self.about self.about.strip! if self.about
self.skype.strip! if self.skype self.discord.strip! if self.discord
self.youtube.strip! if self.youtube self.youtube.strip! if self.youtube
self.twitter.strip! if self.twitter self.twitter.strip! if self.twitter
end end

View File

@@ -1,10 +1,10 @@
<% title "Edit News: #{@post.title}" %> <% title "Edit Post: #{@post.title}" %>
<h1>Edit post</h1> <h1>Edit Post: #{@post.title}</h1>
<%= form_for @post do |f|%> <%= form_for @post do |f|%>
<%= f.text_field :title %> <%= f.text_field :title %>
<%= render partial: "md_editor", locals: {name: "blogpost[content]", content: @post.content} %> <%= render partial: "md_editor", locals: {name: "blogpost[content]", content: @post.content} %>
<p><%= f.submit "Update Post", class: "btn blue left" %></p> <p><%= f.submit "Update Post", class: "btn blue left" %></p>
<% end %> <% end %>
<p><%= button_to "Delete post", @post, method: "delete", data: {confirm: "Delete post & comments forever?"}, class: "btn red right" %></p> <p><%= button_to "Delete Post", @post, method: "delete", data: {confirm: "Delete post & comments forever?"}, class: "btn red right" %></p>
<div class="clear"></div> <div class="clear"></div>

View File

@@ -1,7 +1,7 @@
<% title "News" %> <% title "News" %>
<h1>News</h1> <h1>News</h1>
<%= link_to 'Make new Post', new_blogpost_path, class: "btn blue" if mod? %> <%= link_to 'New Post', new_blogpost_path, class: "btn blue" if mod? %>
<div id="posts"> <div id="posts">
<% @posts.each do |p| %> <% @posts.each do |p| %>
<div class="item-group with-avatar" id="post-<%= p.id %>"> <div class="item-group with-avatar" id="post-<%= p.id %>">

View File

@@ -1,5 +1,5 @@
<h3>New comment</h3> <h3>New Comment</h3>
<%= form_for [@post, @comment] do |f| %> <%= form_for [@post, @comment] do |f| %>
<%= render partial: "md_editor", locals: {name: "comment[content]", content: @comment.content} %> <%= render partial: "md_editor", locals: {name: "comment[content]", content: @comment.content} %>
<p><%= f.submit class: "btn blue" %></p> <p><%= f.submit class: "btn blue" %></p>
<% end %> <% end %>

View File

@@ -1,10 +1,10 @@
<% title "Edit Comment: #{@comment.blogpost.title}" %> <% title "Edit Comment: #{@comment.blogpost.title}" %>
<h1>Edit comment</h1> <h1>Edit Comment</h1>
<%= form_for [@comment.blogpost, @comment] do |f| %> <%= form_for [@comment.blogpost, @comment] do |f| %>
<%= render partial: "md_editor", locals: {name: "comment[content]", content: @comment.content} %> <%= render partial: "md_editor", locals: {name: "comment[content]", content: @comment.content} %>
<p><%= f.submit "Update Comment", class: "btn blue left" %></p> <p><%= f.submit "Update Comment", class: "btn blue left" %></p>
<% end %> <% end %>
<p><%= button_to "Delete comment", [@comment.blogpost, @comment] , method: "delete", data: {confirm: "Delete comment forever?"}, class: "btn red right" %></p> <p><%= button_to "Delete Comment", [@comment.blogpost, @comment] , method: "delete", data: {confirm: "Delete comment forever?"}, class: "btn red right" %></p>
<div class="clear"></div> <div class="clear"></div>

View File

@@ -34,7 +34,7 @@
<td><%= f.select :role_write_id, role_selection, include_blank: false %></td> <td><%= f.select :role_write_id, role_selection, include_blank: false %></td>
</tr> </tr>
</table> </table>
<p><%= f.submit "Update group", class: "btn blue left" %></p> <p><%= f.submit "Update Group", class: "btn blue left" %></p>
<% end %> <% end %>
<p><%= button_to "Delete group", @group, :method => "delete", data: {confirm: "Delete group?\nForums + Threads will not be accessible!"}, class: "btn red right" %></p> <p><%= button_to "Delete Group", @group, :method => "delete", data: {confirm: "Delete group?\nForums + Threads will not be accessible!"}, class: "btn red right" %></p>
<div class="clear"></div> <div class="clear"></div>

View File

@@ -1,6 +1,6 @@
<% title "New Forum: #{@group.name}" %> <% title "New Forum: #{@group.name}" %>
<h1>New forum group</h1> <h1>New Forum Group</h1>
<% role_selection = Role.all_from_to(:normal, :admin).collect{|p|[p.name, p.id]} %> <% role_selection = Role.all_from_to(:normal, :admin).collect{|p|[p.name, p.id]} %>
<%= form_for @group do |f|%> <%= form_for @group do |f|%>
<table> <table>
@@ -21,6 +21,6 @@
<td><%= f.select :role_write_id, role_selection, include_blank: false %></td> <td><%= f.select :role_write_id, role_selection, include_blank: false %></td>
</tr> </tr>
</table> </table>
<p><%= f.submit "Create group", class: "btn blue left" %></p> <p><%= f.submit "Create Group", class: "btn blue left" %></p>
<div class="clear"></div> <div class="clear"></div>
<% end %> <% end %>

View File

@@ -25,8 +25,12 @@
<td><%= f.label :necro_length, "Necropost warning delay (in days)" %></td> <td><%= f.label :necro_length, "Necropost warning delay (in days)" %></td>
<td><%= f.number_field :necro_length, placeholder: "Warning Delay (leave blank for no warning)" %></td> <td><%= f.number_field :necro_length, placeholder: "Warning Delay (leave blank for no warning)" %></td>
</tr> </tr>
<tr>
<td><%= f.label :disable_deletion, "Disable deletion of threads for non-staff" %></td>
<td><%= f.check_box :disable_deletion %></td>
</tr>
</table> </table>
<p><%= f.submit "Update forum", class: "btn blue left" %></p> <p><%= f.submit "Update Forum", class: "btn blue left" %></p>
<% end %> <% end %>
<p><%= button_to "Delete forum", @forum, method: "delete", data: {confirm: "Delete forum forever?\nThreads won't be accessible!"}, class: "btn red right" %></p> <p><%= button_to "Delete Forum", @forum, method: "delete", data: {confirm: "Delete forum forever?\nThreads won't be accessible!"}, class: "btn red right" %></p>
<div class="clear"></div> <div class="clear"></div>

View File

@@ -1,6 +1,6 @@
<% title "Forums" %> <% title "Forums" %>
<%= link_to "All threads", forumthreads_path, class: "btn blue right" %> <%= link_to "Search All Threads", forumthreads_path, class: "btn blue right" %>
<br> <br>
<div id="forum_groups"> <div id="forum_groups">
<% @groups.each do |group| %> <% @groups.each do |group| %>

View File

@@ -25,8 +25,12 @@
<td><%= f.label :necro_length, "Necropost warning delay (in days)" %></td> <td><%= f.label :necro_length, "Necropost warning delay (in days)" %></td>
<td><%= f.number_field :necro_length, placeholder: "Warning Delay (leave blank for no warning)" %></td> <td><%= f.number_field :necro_length, placeholder: "Warning Delay (leave blank for no warning)" %></td>
</tr> </tr>
<tr>
<td><%= f.label :disable_deletion %></td>
<td><%= f.check_box :disable_deletion %></td>
</tr>
</table> </table>
<%= f.hidden_field :forumgroup_id %> <%= f.hidden_field :forumgroup_id %>
<p><%= f.submit "Create forum", class: "btn blue left" %></p> <p><%= f.submit "Create Forum", class: "btn blue left" %></p>
<div class="clear"></div> <div class="clear"></div>
<% end %> <% end %>

View File

@@ -0,0 +1,19 @@
atom_feed do |feed|
feed.title @forum.name + "'s Latest Threads"
feed.updated Time.now
@threads.limit(10).each do |thread|
unless thread.sticky?
feed.entry thread do |entry|
entry.updated thread.updated_at
entry.author do |a|
a.name thread.author.name
a.uri user_url(thread.author)
end
entry.url forumthread_url(thread)
entry.title thread.title
entry.content render_md(thread.content).html_safe, :type => 'html'
end
end
end
end

View File

@@ -6,7 +6,7 @@
</h1> </h1>
<% if @forum.can_write?(current_user) %> <% if @forum.can_write?(current_user) %>
<p> <p>
<%= link_to "New thread", new_forumthread_path(forum: @forum), class: "btn blue" %> <%= link_to "New Thread", new_forumthread_path(forum: @forum), class: "btn blue" %>
</p> </p>
<% end %> <% end %>

View File

@@ -11,7 +11,9 @@
end end
%> %>
<h1>Edit thread</h1> <% forum = Forum.find(@thread.forum_id) %>
<h1>Edit Thread</h1>
<%= link_to @thread.forum.group, forumgroup_path(@thread.forum.group) %> → <%= link_to @thread.forum, @thread.forum %> → <%= link_to @thread, @thread %> → Edit thread <%= link_to @thread.forum.group, forumgroup_path(@thread.forum.group) %> → <%= link_to @thread.forum, @thread.forum %> → <%= link_to @thread, @thread %> → Edit thread
<%= form_for @thread do |f|%> <%= form_for @thread do |f|%>
<table> <table>
@@ -35,7 +37,9 @@
<%= f.text_field :title, placeholder: "Title" %> <%= f.text_field :title, placeholder: "Title" %>
</div> </div>
<%= render partial: "md_editor", locals: {name: "forumthread[content]", content: @thread.content} %> <%= render partial: "md_editor", locals: {name: "forumthread[content]", content: @thread.content} %>
<p><%= f.submit "Update thread", class: "btn blue left" %></p> <p><%= f.submit "Update Thread", class: "btn blue left" %></p>
<% end %> <% end %>
<%= button_to "Delete thread", @thread, :method => "delete", data: {confirm: "Delete thread & comments forever?"}, class: "btn red right" %> <% if mod? || !forum.disable_deletion %>
<div class="clear"></div> <%= button_to "Delete Thread", @thread, :method => "delete", data: {confirm: "Delete thread & comments forever?"}, class: "btn red right" %>
<% end %>
<div class="clear"></div>

View File

@@ -10,14 +10,14 @@
if params[:forum] if params[:forum]
text = "forum '#{Forum.find(params[:forum]).name}'" text = "forum '#{Forum.find(params[:forum]).name}'"
if params_list.except(:forum).any? if params_list.except(:forum).any?
text = "Search results in #{text} (#{@threads.total_count})" text = "Search Results in #{text} (#{@threads.total_count})"
else else
text = text.capitalize text = text.capitalize
end end
elsif params_list.any? elsif params_list.any?
text = "Search results (#{@threads.total_count})" text = "Search Results (#{@threads.total_count})"
else else
text = "All threads" text = "All Threads"
end end
%> %>
<%= title text %> <%= title text %>

View File

@@ -8,7 +8,7 @@
%> %>
<%= link_to @thread.forum.group, forumgroup_path(@thread.forum.group) %> → <%= link_to @thread.forum, @thread.forum %> → New thread <%= link_to @thread.forum.group, forumgroup_path(@thread.forum.group) %> → <%= link_to @thread.forum, @thread.forum %> → New thread
<h1>New thread</h1> <h1>New Thread</h1>
<%= form_for @thread do |f|%> <%= form_for @thread do |f|%>
<table> <table>
<% if mod? %> <% if mod? %>
@@ -30,6 +30,6 @@
</div> </div>
<%= render partial: "md_editor", locals: {name: "forumthread[content]", content: @thread.content} %> <%= render partial: "md_editor", locals: {name: "forumthread[content]", content: @thread.content} %>
<%= f.hidden_field :forum_id %> <%= f.hidden_field :forum_id %>
<p><%= f.submit "Create thread", class: "btn blue left" %></p> <p><%= f.submit "Create Thread", class: "btn blue left" %></p>
<div class="clear"></div> <div class="clear"></div>
<% end %> <% end %>

View File

@@ -17,13 +17,8 @@
<%= link_to "https://mstdn.io/@RedstonerServer", title: "Redstoner on Mastodon" do %> <%= link_to "https://mstdn.io/@RedstonerServer", title: "Redstoner on Mastodon" do %>
Mastodon <%= image_tag("mastodon.png") %> Mastodon <%= image_tag("mastodon.png") %>
<% end %> | <% end %> |
<%= link_to "http://rdstnr4biap5nao2.onion", title: "Redstoner over Tor" do %> <%= link_to "https://discord.gg/QjfcPEJ", title: "Redstoner's Official Discord" do %>
Onion Service <%= image_tag("tor.png") %> Discord <%= image_tag("discord.png") %>
<% end %>
<% if current_user %>
| <%= link_to "/slack/?" + {mail: current_user.try(:email)}.to_param do %>
Join us on <img src="/slack/badge.svg" alt="Slack">
<% end %>
<% end %> <% end %>
</div> </div>
</div> </div>

View File

@@ -10,7 +10,7 @@
<% end %> <% end %>
<%= csrf_meta_tags %> <%= csrf_meta_tags %>
<%= favicon_link_tag "favicon.ico" %> <%= favicon_link_tag "favicon.ico" %>
<%= javascript_include_tag "https://cdn.rawgit.com/jomo/ago.js/v0.0.1/ago.min.js", crossorigin: :anonymous, integrity: "sha256-xw0JUUdbuZQCVO+QScoxrlEsD4nZGCjMRh9PP8GLhcY=" %> <%= javascript_include_tag "https://cdn.jsdelivr.net/gh/jomo/ago.js@0.0.1/ago.min.js", crossorigin: :anonymous, integrity: "sha256-xw0JUUdbuZQCVO+QScoxrlEsD4nZGCjMRh9PP8GLhcY=" %>
<%= javascript_include_tag "application" %> <%= javascript_include_tag "application" %>
<link type="application/atom+xml" rel="alternate" href="<%= blogposts_path(:atom) %>"> <link type="application/atom+xml" rel="alternate" href="<%= blogposts_path(:atom) %>">
<%= yield(:site_headers) %> <%= yield(:site_headers) %>

View File

@@ -26,7 +26,7 @@
<%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Email", "mailto:redstonerserver+website@gmail.com", style: "text-decoration: none; color: #4096EE;" %> <%= link_to "Email", "mailto:staff@redstoner.com", style: "text-decoration: none; color: #4096EE;" %>
</p> </p>
</div> </div>
</div> </div>

View File

@@ -25,7 +25,7 @@
<%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Email", "mailto:redstonerserver+website@gmail.com", style: "text-decoration: none; color: #4096EE;" %> <%= link_to "Email", "mailto:staff@redstoner.com", style: "text-decoration: none; color: #4096EE;" %>
</p> </p>
</div> </div>
</div> </div>

View File

@@ -22,7 +22,7 @@
<%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Email", "mailto:redstonerserver+website@gmail.com", style: "text-decoration: none; color: #4096EE;" %> <%= link_to "Email", "mailto:staff@redstoner.com", style: "text-decoration: none; color: #4096EE;" %>
</p> </p>
</div> </div>
</div> </div>

View File

@@ -24,7 +24,7 @@
<%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Email", "mailto:redstonerserver+website@gmail.com", style: "text-decoration: none; color: #4096EE;" %> <%= link_to "Email", "mailto:staff@redstoner.com", style: "text-decoration: none; color: #4096EE;" %>
</p> </p>
</div> </div>
</div> </div>

View File

@@ -27,7 +27,7 @@
<%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Email", "mailto:redstonerserver+website@gmail.com", style: "text-decoration: none; color: #4096EE;" %> <%= link_to "Email", "mailto:staff@redstoner.com", style: "text-decoration: none; color: #4096EE;" %>
</p> </p>
</div> </div>
</div> </div>

View File

@@ -38,7 +38,7 @@
<%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Website", root_url, style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Twitter", "https://twitter.com/RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> | <%= link_to "Mastodon", "https://mstdn.io/@RedstonerServer", style: "text-decoration: none; color: #4096EE;" %> |
<%= link_to "Email", "mailto:redstonerserver+website@gmail.com", style: "text-decoration: none; color: #4096EE;" %> <%= link_to "Email", "mailto:staff@redstoner.com", style: "text-decoration: none; color: #4096EE;" %>
</p> </p>
</div> </div>
</div> </div>

View File

@@ -1,6 +1,6 @@
<% title "Log in" %> <% title "Log In" %>
<h1>Log in</h1> <h1>Log In</h1>
<p>Not a member? <%= link_to "Join us", signup_path %>!</p> <p>Not a member? <%= link_to "Join us", signup_path %>!</p>
<%= form_tag login_path do |f| %> <%= form_tag login_path do |f| %>
<table> <table>
@@ -16,6 +16,14 @@
<td></td> <td></td>
<td><%= link_to "Lost your password?", lost_password_users_path %></td> <td><%= link_to "Lost your password?", lost_password_users_path %></td>
</tr> </tr>
<tr>
<td><%= label_tag :totp_code %></td>
<td><%= text_field_tag :totp_code, nil, placeholder: "123456", required: false %></td>
</tr>
<tr>
<td></td>
<td>Leave this field blank if you do not have 2FA enabled.</td>
</tr>
</table> </table>
<p><%= submit_tag "Log in", class: "btn blue" %></p> <p><%= submit_tag "Log in", class: "btn blue" %></p>
<% end %> <% end %>

View File

@@ -19,6 +19,7 @@
<ul> <ul>
<li>The warm feeling of donating for a good thing, plus a huge "<b>thank you</b>"! <li>The warm feeling of donating for a good thing, plus a huge "<b>thank you</b>"!
<li>You can have a nickname. See <%= link_to "our nickname guidelines", info_path("12-nickname-guidelines") %> <li>You can have a nickname. See <%= link_to "our nickname guidelines", info_path("12-nickname-guidelines") %>
<li>You can chat in <font color="red">color</font> in-game.</i>
<li>A "$" next to your name <i>(Including website)</i> <li>A "$" next to your name <i>(Including website)</i>
<li><i>Donator+</i> has access to the in-game command <code>/lol id</code></li> <li><i>Donator+</i> has access to the in-game command <code>/lol id</code></li>
</ul> </ul>
@@ -26,11 +27,11 @@
<div class="donations"> <div class="donations">
<div class="donation"> <div class="donation">
<div class="left"> <div class="left">
<img src="https://crafatar.com/renders/body/97a4928198f045998e0e7a97eabae6ae?overlay=true&scale=3" alt="sponsor's skin" class="body"> <img src="https://crafatar.com/renders/body/d2693e91-93e1-4e3f-929f-f38e1ce8df03?overlay=true&scale=3" alt="sponsor's skin" class="body">
</div> </div>
<div> <div>
<h1>Donate to our server sponsor</h1> <h1>Donate to our server sponsor</h1>
<h4>PotatoKek pays for the server hardware. You can help him by donating here.</h4> <h4>Pepich1851 pays for the server hardware. You can help him by donating here.</h4>
<form target="_blank" method="post" action="https://www.paypal.com/cgi-bin/webscr"> <form target="_blank" method="post" action="https://www.paypal.com/cgi-bin/webscr">
<% if current_user %> <% if current_user %>
<input name="custom" type="hidden" placeholder="Your Minecraft name" value="<%= current_user.ign %>"> <input name="custom" type="hidden" placeholder="Your Minecraft name" value="<%= current_user.ign %>">

View File

@@ -1,4 +1,4 @@
<% title "Edit Thread Reply: #{@reply.thread.title}" %> <% title "Edit Reply: #{@reply.thread.title}" %>
<% <%
position = @reply.thread.replies.order(:id).index(@reply) position = @reply.thread.replies.order(:id).index(@reply)
@@ -6,10 +6,10 @@
%> %>
<%= link_to @reply.thread.forum.group, forumgroup_path(@reply.thread.forum.group) %> → <%= link_to @reply.thread.forum, @reply.thread.forum %> → <%= link_to @reply.thread, forumthread_path(@reply.thread, page: page) + "#reply-#{@reply.id}" %> → Edit reply <%= link_to @reply.thread.forum.group, forumgroup_path(@reply.thread.forum.group) %> → <%= link_to @reply.thread.forum, @reply.thread.forum %> → <%= link_to @reply.thread, forumthread_path(@reply.thread, page: page) + "#reply-#{@reply.id}" %> → Edit reply
<h1>Edit reply</h1> <h1>Edit Reply</h1>
<%= form_for [@reply.thread, @reply] do |f| %> <%= form_for [@reply.thread, @reply] do |f| %>
<%= render partial: "md_editor", locals: {name: "threadreply[content]", content: @reply.content} %> <%= render partial: "md_editor", locals: {name: "threadreply[content]", content: @reply.content} %>
<p><%= f.submit "Reply", class: "btn blue left" %></p> <p><%= f.submit "Reply", class: "btn blue left" %></p>
<% end %> <% end %>
<p><%= button_to "Delete reply", [@reply.thread, @reply], method: "delete", data: {confirm: "Delete reply forever?"}, class: "btn red right" %></p> <p><%= button_to "Delete Reply", [@reply.thread, @reply], method: "delete", data: {confirm: "Delete reply forever?"}, class: "btn red right" %></p>
<div class="clear"></div> <div class="clear"></div>

View File

@@ -1,10 +1,10 @@
<% title "Change Password" %> <% title "Change Password" %>
<h1>Change password</h1> <h1>Change Password</h1>
<%= form_for @user do |f| %> <%= form_for @user do |f| %>
<%= f.text_field :current_password %> <%= f.text_field :current_password %>
<%= f.text_field :email %> <%= f.text_field :email %>
<%= f.text_field :password %> <%= f.text_field :password %>
<%= f.text_field :password_confirmation %> <%= f.text_field :password_confirmation %>
<% end %> <% end %>

View File

@@ -7,7 +7,7 @@
%> %>
<%= link_to @user.name, @user %> → Edit <%= link_to @user.name, @user %> → Edit
<h1>Edit profile</h1> <h1>Edit Profile</h1>
<%= form_for @user do |f| %> <%= form_for @user do |f| %>
<table> <table>
@@ -43,9 +43,9 @@
</tr> </tr>
<% end %> <% end %>
<tr> <tr>
<td>Skype username</td> <td>Discord username</td>
<td> <td>
<%= f.text_field :skype, placeholder: "Skype username", disabled: !can_edit? %> <%= f.text_field :discord, placeholder: "Discord username", disabled: !can_edit? %>
</td> </td>
</tr> </tr>
<tr> <tr>
@@ -69,11 +69,11 @@
</tbody> </tbody>
</table> </table>
<p><%= f.submit "Save profile", class: "btn variable-size left", disabled: (!@user.confirmed? && @user.is?(current_user)) %></p> <p><%= f.submit "Save Profile", class: "btn variable-size left", disabled: (!@user.confirmed? && @user.is?(current_user)) %></p>
<p> <p>
<%= link_to "Edit login details", edit_login_user_path(@user), class: "btn variable-size right" %> <%= link_to "Login Settings", edit_login_user_path(@user), class: "btn variable-size right" %>
<%= link_to "Notification settings", edit_notifications_user_path(@user), class: "btn variable-size right" %> <%= link_to "Notification Settings", edit_notifications_user_path(@user), class: "btn variable-size right" %>
<%= link_to "Website settings", edit_website_settings_user_path(@user), class: "btn variable-size right" %> <%= link_to "Website Settings", edit_website_settings_user_path(@user), class: "btn variable-size right" %>
</p> </p>
<div class="clear"></div> <div class="clear"></div>

View File

@@ -1,7 +1,7 @@
<% title "Edit Login Credentials: #{@user.name}" %> <% title "Edit Login Credentials: #{@user.name}" %>
<%= link_to @user.name, @user %> → Edit Login credentials <%= link_to @user.name, @user %> → Edit Login settings
<h1>Edit Login credentials</h1> <h1>Edit Login Settings</h1>
<%= form_for @user, url: update_login_user_path(@user), method: :put do |f| %> <%= form_for @user, url: update_login_user_path(@user), method: :put do |f| %>
@@ -25,14 +25,51 @@
<%= f.password_field :password_confirmation %> <%= f.password_field :password_confirmation %>
</td> </td>
</tr> </tr>
</tbody>
</table>
<hr>
<table>
<tbody>
<tr>
<td>2FA Enabled</td>
<td>
<%= f.check_box :totp_enabled %>
</td>
</tr>
<tr>
<td>TOTP Secret</td>
<td>
<% if !@user.totp_enabled? %>
<%= f.text_field :totp_secret, :readonly => true %>
<% else %>
<i>2FA is currently enabled. Disable 2FA to generate a new secret.</i>
<% end %>
</td>
</tr>
</tbody>
</table>
<hr>
<table>
<tbody>
<tr> <tr>
<td>Current password</td> <td>Current password</td>
<td> <td>
<%= password_field_tag :current_password, nil, disabled: !@user.is?(current_user) %> <%= password_field_tag :current_password, nil, disabled: !@user.is?(current_user) %>
</td> </td>
</tr> </tr>
<% if !@user.totp_enabled? %>
<tr>
<td>TOTP Code</td>
<td>
<%= text_field_tag :totp_code, nil, disabled: !@user.is?(current_user) %>
</td>
</tr>
<tr>
<td></td>
<td><i>Leave this field blank if you are not enabling 2FA.</i></td>
<% end %>
</tbody> </tbody>
</table> </table>
<p><%= f.submit "Save changes", class: "btn blue left" %></p> <p><%= f.submit "Save Changes", class: "btn blue left" %></p>
<div class="clear"></div> <div class="clear"></div>
<% end %> <% end %>

View File

@@ -48,6 +48,6 @@
<h3>Public Key</h1> <h3>Public Key</h1>
<p>All notification emails will be encrypted with this key if you supply it.</p> <p>All notification emails will be encrypted with this key if you supply it.</p>
<%= f.text_area :public_key, placeholder: "-----BEGIN PGP PUBLIC KEY BLOCK-----" %> <%= f.text_area :public_key, placeholder: "-----BEGIN PGP PUBLIC KEY BLOCK-----" %>
<p><%= f.submit "Save changes", class: "btn blue left" %></p> <p><%= f.submit "Save Changes", class: "btn blue left" %></p>
<div class="clear"></div> <div class="clear"></div>
<% end %> <% end %>

View File

@@ -8,7 +8,7 @@
<table> <table>
<tbody> <tbody>
<tr> <tr>
<td>Header moves with scrolling (Experimental - do not report bugs)</td> <td>Header moves with scrolling</td>
<td> <td>
<%= f.check_box :header_scroll %> <%= f.check_box :header_scroll %>
</td> </td>
@@ -20,15 +20,13 @@
</td> </td>
</tr> </tr>
<tr> <tr>
<td>Dark theme*</td> <td>Dark theme</td>
<td> <td>
<%= f.check_box :dark %> <%= f.check_box :dark %>
</td> </td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
<p><%= f.submit "Save changes", class: "btn blue left" %></p> <p><%= f.submit "Save Changes", class: "btn blue left" %></p>
<div class="clear"></div> <div class="clear"></div>
<% end %> <% end %>
<br><br><br>
*Warning: If as a result to enabling this style your eyes get infected with a severe case of eye cancer, we are not reliable for any damage. Please contact your doctor in advance to ensure that in case of infection you will be treated accordingly. Quality theme brought to you by Redempt™.

View File

@@ -1,6 +1,6 @@
<% title "Reset password" %> <% title "Reset Password" %>
<h1>Reset password</h1> <h1>Reset Password</h1>
<p>You lost your password? Don't do that!</p> <p>You lost your password? Don't do that!</p>
<p>Luckily for you, you can reset your password. Please use the command <code>/gettoken &lt;your email address&gt;</code>, then fill in the form below:</p> <p>Luckily for you, you can reset your password. Please use the command <code>/gettoken &lt;your email address&gt;</code>, then fill in the form below:</p>
<%= form_tag reset_password_users_path do |f| %> <%= form_tag reset_password_users_path do |f| %>
@@ -22,5 +22,5 @@
<td><%= password_field_tag :new_password, nil, placeholder: "secret", required: true, pattern: ".{8,}", title: "minimum 8 characters", "x-moz-errormessage" => "minimum 8 characters" %></td> <td><%= password_field_tag :new_password, nil, placeholder: "secret", required: true, pattern: ".{8,}", title: "minimum 8 characters", "x-moz-errormessage" => "minimum 8 characters" %></td>
</tr> </tr>
</table> </table>
<p><%= submit_tag "Reset password", class: "btn blue" %></p> <p><%= submit_tag "Reset Password", class: "btn blue" %></p>
<% end %> <% end %>

View File

@@ -1,6 +1,6 @@
<% title "Sign up" %> <% title "Sign Up" %>
<h1>Sign up</h1> <h1>Sign Up</h1>
<%= form_for @user do |f| %> <%= form_for @user do |f| %>
<table> <table>
@@ -38,7 +38,7 @@
You can find more details in our info page about <a href="/info/15">tokens and website registration</a>. You can find more details in our info page about <a href="/info/15">tokens and website registration</a>.
</p> </p>
<%= f.submit "Sign up", class: "btn blue" %> <%= f.submit "Sign Up", class: "btn blue" %>
<p>Contact us ingame if you have problems signing up!</p> <p>Contact us ingame if you have problems signing up!</p>
<% end %> <% end %>

View File

@@ -25,7 +25,7 @@
<% if !@user.confirmed? %> <% if !@user.confirmed? %>
<% if @user.is?(current_user) || mod? %> <% if @user.is?(current_user) || mod? %>
<span class="user-unconfirmed">Please confirm your email <u><%= @user.email %></u> !</span> <span class="user-unconfirmed">Please confirm your email <u><%= @user.email %></u> !</span>
<%= button_to "Resend the confirmation mail", resend_mail_user_path, class: "btn dark", form_class: "inline-block", data: {confirm: "Did you check your spam folder?"} %> <%= button_to "Resend the confirmation mail", resend_mail_user_path, class: "btn blue", form_class: "inline-block", data: {confirm: "Did you check your spam folder?"} %>
<% else %> <% else %>
<span class="user-unconfirmed">This user hasn't confirmed their email yet!</span> <span class="user-unconfirmed">This user hasn't confirmed their email yet!</span>
<% end %> <% end %>
@@ -54,10 +54,10 @@
<td><b>Role</b></td> <td><b>Role</b></td>
<td><%= link_to @user.role, users_path(:role => @user.role.name) %></td> <td><%= link_to @user.role, users_path(:role => @user.role.name) %></td>
</tr> </tr>
<% if current_user && !@user.skype.blank? %> <% if current_user && !@user.discord.blank? %>
<tr> <tr>
<td><b>Skype</b></td> <td><b>Discord</b></td>
<td><%= link_to @user.skype, "skype:#{@user.skype}?chat", target: "_blank" %></a></td> <td><%= @user.discord %></td>
</tr> </tr>
<% end %> <% end %>
<% if !@user.youtube.blank? && !@user.youtube_channelname.blank? %> <% if !@user.youtube.blank? && !@user.youtube_channelname.blank? %>
@@ -82,6 +82,16 @@
<td><b>Joined</b></td> <td><b>Joined</b></td>
<td><%= ago @user.created_at %></td> <td><%= ago @user.created_at %></td>
</tr> </tr>
<tr>
<td><b>Last seen</b></td>
<td>
<% if @user.last_seen %>
<%= ago @user.last_seen %>
<% else %>
Never
<% end %>
</td>
</tr>
<% if mod? || @user.is?(current_user) %> <% if mod? || @user.is?(current_user) %>
<tr> <tr>
<td><b>Last IP</b></td> <td><b>Last IP</b></td>
@@ -91,16 +101,6 @@
<td><b>Email</b></td> <td><b>Email</b></td>
<td><%= mail_to @user.email, @user.email, :subject => "Redstoner" %></td> <td><%= mail_to @user.email, @user.email, :subject => "Redstoner" %></td>
</tr> </tr>
<tr>
<td><b>Last seen</b></td>
<td>
<% if @user.last_seen %>
<%= ago @user.last_seen %>
<% else %>
Never
<% end %>
</td>
</tr>
<% end %> <% end %>
</tbody> </tbody>
</table> </table>

View File

@@ -1,5 +1,5 @@
# config valid only for current version of Capistrano # config valid only for current version of Capistrano
lock '3.4.0' lock '3.11.0'
set :repo_url, 'https://github.com/RedstonerServer/redstoner.com' set :repo_url, 'https://github.com/RedstonerServer/redstoner.com'
@@ -13,9 +13,9 @@ set :default_environment, {
set :keep_releases, 5 set :keep_releases, 5
set :deploy_to, -> { "/home/www-data/apps/#{fetch(:application)}" } set :deploy_to, -> { "/var/www/#{fetch(:application)}" }
set :rbenv_ruby, '2.0.0-p648' set :rbenv_ruby, '2.5.0-dev'
set :bundle_without, %w{development test}.join(' ') set :bundle_without, %w{development test}.join(' ')
@@ -24,4 +24,4 @@ set :linked_dirs, fetch(:linked_dirs, []).push('bin', 'log', 'tmp/pids', 'tmp/ca
namespace :deploy do namespace :deploy do
after :publishing, :restart after :publishing, :restart
end end

View File

@@ -37,12 +37,12 @@ Redstoner::Application.configure do
} }
config.action_mailer.smtp_settings = { config.action_mailer.smtp_settings = {
address: "smtp.gmail.com", address: ENV["SMTP_ADDRESS"],
port: 587, port: ENV["SMTP_PORT"],
domain: "google.com", domain: "redstoner.com",
authentication: "plain", authentication: ENV["SMTP_AUTH"],
user_name: "redstonerserver@gmail.com", user_name: ENV["SMTP_USERNAME"],
password: ENV["GMAIL_PASSWORD"], password: ENV["SMTP_PASSWORD"],
} }
end end

View File

@@ -71,12 +71,12 @@ Redstoner::Application.configure do
} }
config.action_mailer.smtp_settings = { config.action_mailer.smtp_settings = {
address: "smtp.gmail.com", address: ENV["SMTP_ADDRESS"],
port: 587, port: ENV["SMTP_PORT"],
domain: "google.com", domain: "redstoner.com",
authentication: "plain", authentication: ENV["SMTP_AUTH"],
user_name: "redstonerserver@gmail.com", user_name: ENV["SMTP_USERNAME"],
password: ENV["GMAIL_PASSWORD"], password: ENV["SMTP_PASSWORD"],
} }
end end

View File

@@ -3,8 +3,8 @@ timeout 15
preload_app true preload_app true
stderr_path "/home/www-data/apps/redstoner/shared/log/unicorn.stderr.log" stderr_path "/var/www/redstoner/shared/log/unicorn.stderr.log"
stdout_path "/home/www-data/apps/redstoner/shared/log/unicorn.stdout.log" stdout_path "/var/www/redstoner/shared/log/unicorn.stdout.log"
before_fork do |server, worker| before_fork do |server, worker|
Signal.trap 'TERM' do Signal.trap 'TERM' do
@@ -23,4 +23,4 @@ after_fork do |server, worker|
defined?(ActiveRecord::Base) and defined?(ActiveRecord::Base) and
ActiveRecord::Base.establish_connection ActiveRecord::Base.establish_connection
end end

View File

@@ -0,0 +1,6 @@
class AddTotpToUsers < ActiveRecord::Migration
def change
add_column :users, :totp_secret, :string
add_column :users, :totp_enabled, :boolean, default: false
end
end

View File

@@ -0,0 +1,5 @@
class DropForumsLabels < ActiveRecord::Migration
def change
drop_table :forums_labels
end
end

View File

@@ -0,0 +1,6 @@
class RemoveSkypeAddDiscordFromUsers < ActiveRecord::Migration
def change
remove_column :users, :skype
add_column :users, :discord, :string
end
end

View File

@@ -0,0 +1,5 @@
class DisableDeletionForums < ActiveRecord::Migration
def change
add_column :forums, :disable_deletion, :boolean
end
end

View File

@@ -11,7 +11,7 @@
# #
# It's strongly recommended that you check this file into your version control system. # It's strongly recommended that you check this file into your version control system.
ActiveRecord::Schema.define(version: 20171013001146) do ActiveRecord::Schema.define(version: 20190224093907) do
create_table "badges", force: :cascade do |t| create_table "badges", force: :cascade do |t|
t.string "name", limit: 191 t.string "name", limit: 191
@@ -46,17 +46,13 @@ ActiveRecord::Schema.define(version: 20171013001146) do
end end
create_table "forums", force: :cascade do |t| create_table "forums", force: :cascade do |t|
t.string "name", limit: 255 t.string "name", limit: 255
t.integer "position", limit: 4 t.integer "position", limit: 4
t.integer "role_read_id", limit: 4 t.integer "role_read_id", limit: 4
t.integer "role_write_id", limit: 4 t.integer "role_write_id", limit: 4
t.integer "forumgroup_id", limit: 4 t.integer "forumgroup_id", limit: 4
t.integer "necro_length", limit: 4 t.integer "necro_length", limit: 4
end t.boolean "disable_deletion", default: false
create_table "forums_labels", id: false, force: :cascade do |t|
t.integer "forum_id", limit: 4
t.integer "label_id", limit: 4
end end
create_table "forumthreads", force: :cascade do |t| create_table "forumthreads", force: :cascade do |t|
@@ -134,7 +130,6 @@ ActiveRecord::Schema.define(version: 20171013001146) do
t.string "email", limit: 191 t.string "email", limit: 191
t.text "about", limit: 65535 t.text "about", limit: 65535
t.string "last_ip", limit: 255 t.string "last_ip", limit: 255
t.string "skype", limit: 255
t.string "youtube", limit: 255 t.string "youtube", limit: 255
t.string "youtube_channelname", limit: 255 t.string "youtube_channelname", limit: 255
t.string "twitter", limit: 255 t.string "twitter", limit: 255
@@ -154,12 +149,15 @@ ActiveRecord::Schema.define(version: 20171013001146) do
t.boolean "header_scroll", default: false t.boolean "header_scroll", default: false
t.boolean "dark", default: false t.boolean "dark", default: false
t.text "public_key", limit: 65535 t.text "public_key", limit: 65535
t.string "totp_secret", limit: 255
t.boolean "totp_enabled", default: false
t.string "discord", limit: 191
end end
add_index "users", ["email"], name: "index_users_on_email", unique: true, using: :btree add_index "users", ["email"], name: "index_users_on_email", unique: true, using: :btree
add_index "users", ["ign"], name: "index_users_on_ign", unique: true, using: :btree add_index "users", ["ign"], name: "index_users_on_ign", unique: true, using: :btree
add_index "users", ["name"], name: "index_users_on_name", unique: true, using: :btree add_index "users", ["name"], name: "index_users_on_name", unique: true, using: :btree
add_index "users", ["skype"], name: "index_users_on_skype", unique: true, using: :btree add_index "users", ["discord"], name: "index_users_on_discord", unique: true, using: :btree
add_index "users", ["twitter"], name: "index_users_on_twitter", unique: true, using: :btree add_index "users", ["twitter"], name: "index_users_on_twitter", unique: true, using: :btree
add_index "users", ["uuid"], name: "index_users_on_uuid", unique: true, using: :btree add_index "users", ["uuid"], name: "index_users_on_uuid", unique: true, using: :btree
add_index "users", ["youtube"], name: "index_users_on_youtube", unique: true, using: :btree add_index "users", ["youtube"], name: "index_users_on_youtube", unique: true, using: :btree

View File

@@ -32,7 +32,7 @@ deleted_user = User.create!(
password_confirmation: userpw, password_confirmation: userpw,
role: Role.get(:disabled), role: Role.get(:disabled),
badge: Badge.get(:none), badge: Badge.get(:none),
skype: "echo123", discord: "echo123#9804",
last_ip: "0.0.0.0", last_ip: "0.0.0.0",
confirmed: true, confirmed: true,
last_seen: Time.utc(0).to_datetime, last_seen: Time.utc(0).to_datetime,
@@ -40,4 +40,4 @@ deleted_user = User.create!(
utc_time: false, utc_time: false,
dark: false dark: false
) )
deleted_user.update_attribute(:ign, "Steve") deleted_user.update_attribute(:ign, "Steve")