summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMrYummy <elemental428@gmail.com>2017-07-04 22:24:50 +0200
committerMrYummy <elemental428@gmail.com>2017-07-04 22:27:07 +0200
commit0aad3bb71afbb6419b90f499118f18676452b095 (patch)
treee6af19ca1fe67f2edfa1f2fef47089a97b1f9eeb
parent0f74795159ba65432aa1a6a25367dfdcffd4bb12 (diff)
Added choice of project, r/w perms, and fixed up some cssmemory
-rw-r--r--app/assets/javascripts/.memory.js.swp (renamed from app/controllers/.memory_controller.rb.swp)bin12288 -> 12288 bytes
-rw-r--r--app/assets/javascripts/memory.js7
-rw-r--r--app/assets/stylesheets/style.css.scss4
-rw-r--r--app/controllers/memory_controller.rb23
-rw-r--r--app/views/memory/index.html.erb5
-rw-r--r--app/views/memory/table.html.erb3
-rw-r--r--config/database.yml4
-rw-r--r--config/environments/development.rb2
-rw-r--r--db/seeds.rb2
9 files changed, 31 insertions, 19 deletions
diff --git a/app/controllers/.memory_controller.rb.swp b/app/assets/javascripts/.memory.js.swp
index 18f0137..964c946 100644
--- a/app/controllers/.memory_controller.rb.swp
+++ b/app/assets/javascripts/.memory.js.swp
Binary files differ
diff --git a/app/assets/javascripts/memory.js b/app/assets/javascripts/memory.js
index 4dac5a0..a614e91 100644
--- a/app/assets/javascripts/memory.js
+++ b/app/assets/javascripts/memory.js
@@ -1,10 +1,17 @@
$(function() {
+ $('td').focus(function() {
+ if (this.id.split("-")[0] == "memory") {
+ $(this).css("background-color", "lightblue")
+ }
+ });
var data = [];
$('td').keydown(function() {
data.push(this.id, $(this).html().substr(0, 2)); //position, value
})
$('td').blur(function() {
+ $(this).css("background", "none");
if ((id_i = data.indexOf(this.id) != -1) && data[id_i+1] != $(this).html().substr(0, 2)) {
+ $(this).css("color", "darkgreen");
var int_id = this.id.split("-")[1]
$.post("/memory/update_memory?project="+$(this).closest("table").data("project")+"&file="+Math.floor((int_id/2048)+1)+"&mem_id="+int_id%2048+"&value="+$(this).html().substr(0, 2));
data.splice(id_i, 2);
diff --git a/app/assets/stylesheets/style.css.scss b/app/assets/stylesheets/style.css.scss
index e8f06ab..04bfee8 100644
--- a/app/assets/stylesheets/style.css.scss
+++ b/app/assets/stylesheets/style.css.scss
@@ -1028,9 +1028,11 @@ nav.pagination {
text-shadow: none;
}
.memory-table {
- width: 870px;
+ width: 980px;
margin: auto;
+ text-align: center;
th, td {
+ height: 20px;
border: 1px solid black;
}
}
diff --git a/app/controllers/memory_controller.rb b/app/controllers/memory_controller.rb
index 6d5947e..3b988a8 100644
--- a/app/controllers/memory_controller.rb
+++ b/app/controllers/memory_controller.rb
@@ -16,30 +16,31 @@ class MemoryController < ApplicationController
end
def table
- Dir.chdir("/etc/minecraft/redstoner/plugins/JavaUtils/memory/projects/#{params[:project]}")
+ Dir.chdir("/etc/minecraft/redstoner/plugins/JavaUtils/memory/projects/#{params[:project].gsub(/[^a-zA-Z0-9-]/,"")[0..35]}")
@data = []
Dir.glob('*').reverse.each do |f|
File.open(Dir.pwd+"/#{f}") do |file|
@data.concat(file.read.unpack("C*").map{|h| h.to_s(16)})
- if JSON.parse((jf = File.open(Dir.pwd+"/project.json")).read)["read"].include? current_user.uuid.gsub("-","")
- @can_edit = false
- else
+ unless (parse = JSON.parse((jf = File.open(Dir.pwd+"/project.json")).read))["read"].include? current_user.uuid.gsub("-","")
@can_edit = true
end
+ @name = parse["name"]
jf.close
end
end
end
def update_memory
- Dir.chdir("/etc/minecraft/redstoner/plugins/JavaUtils/memory/projects/#{params[:project]}")
- new_text = ""
- File.open("#{params[:file]}.hex"){|f| new_text = f.read.unpack("C*").collect{|h| h.to_s(16)}}
- new_text[params[:mem_id].to_i] = params[:value]
- File.open("#{params[:file]}.hex", "w") do |f|
- f.write((new_text.collect{|h| h.to_s.to_i(16)}).pack("C*").force_encoding("UTF-8"))
+ Dir.chdir("/etc/minecraft/redstoner/plugins/JavaUtils/memory/projects/#{params[:project].gsub(/[^a-zA-Z0-9-]/,"")[0..35]}")
+ unless params[:mem_id].to_i > JSON.parse(File.read("project.json"))["size"] || (/[^A-Fa-f0-9]/.match params[:value])
+ new_text = ""
+ File.open("#{params[:file]}.hex"){|f| new_text = f.read.unpack("C*").collect{|h| h.to_s(16)}}
+ new_text[params[:mem_id].to_i] = params[:value]
+ File.open("#{params[:file]}.hex", "w") do |f|
+ f.write((new_text.collect{|h| h.to_s.to_i(16)}).pack("C*").force_encoding("UTF-8"))
+ end
+ render nothing: true
end
- render nothing: true
end
private
diff --git a/app/views/memory/index.html.erb b/app/views/memory/index.html.erb
index 9348db0..6abcee0 100644
--- a/app/views/memory/index.html.erb
+++ b/app/views/memory/index.html.erb
@@ -1,4 +1,5 @@
-<%= form_tag "memory/table", method: :get do %>
+<%= form_tag url_for(controller: "memory", action: "table"), method: :get do %>
<%= select_tag "project", options_for_select(@projects.collect.with_index{|p, i| [@project_names[i], p]}) %>
- <%= submit_tag "View Table", name: nil %>
+ <br><br>
+ <%= submit_tag "Load table", name: nil, class: "btn blue" %>
<% end %>
diff --git a/app/views/memory/table.html.erb b/app/views/memory/table.html.erb
index 03f1ef2..2f24dc4 100644
--- a/app/views/memory/table.html.erb
+++ b/app/views/memory/table.html.erb
@@ -1,3 +1,4 @@
+<h1 style="text-align:center"><%= title @name + (" (read-only)" if !@can_edit).to_s %></h1>
<table class="memory-table", data-project="<%=params[:project]%>">
<tr>
<% ["Address","0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F"].each do |i| %>
@@ -8,7 +9,7 @@
<tr>
<td><b><%=(rindex*16).to_s(16).upcase.rjust(6, "0")%></b></td>
<% row.each_with_index do |hex, hindex| %>
- <td contenteditable="<%=@can_edit%>" id="memory-<%=(16*rindex)+hindex%>"><%=hex.to_s.upcase.rjust(2, "0")%></td>
+ <td contenteditable="<%=!!@can_edit%>" id="memory-<%=(16*rindex)+hindex%>"><%=hex.to_s.upcase.rjust(2, "0")%></td>
<% end %>
</tr>
<% end %>
diff --git a/config/database.yml b/config/database.yml
index f421bef..9888fe9 100644
--- a/config/database.yml
+++ b/config/database.yml
@@ -10,7 +10,7 @@ default: &default
development:
<<: *default
database: redstoner-web
- username: root
+ username: web
production:
<<: *default
@@ -24,4 +24,4 @@ test:
adapter: sqlite3
database: db/test.sqlite3
pool: 5
- timeout: 5000 \ No newline at end of file
+ timeout: 5000
diff --git a/config/environments/development.rb b/config/environments/development.rb
index 06819fd..429866e 100644
--- a/config/environments/development.rb
+++ b/config/environments/development.rb
@@ -43,4 +43,4 @@ Redstoner::Application.configure do
password: ENV["GMAIL_PASSWORD"],
}
-end \ No newline at end of file
+end
diff --git a/db/seeds.rb b/db/seeds.rb
index 780ddb5..bc2dd6c 100644
--- a/db/seeds.rb
+++ b/db/seeds.rb
@@ -38,4 +38,4 @@ User.create!(
password: "123456789", # high seructity!
password_confirmation: "123456789",
role: Role.get(:superadmin)
-) \ No newline at end of file
+)