Integration of module_app workflow
This commit is contained in:
parent
65349796d0
commit
dac6348402
|
@ -43,7 +43,12 @@ class Admin::PurchasesController < ApplicationController
|
||||||
temp_file.write response.body
|
temp_file.write response.body
|
||||||
temp_file.rewind
|
temp_file.rewind
|
||||||
zip_name = response['content-disposition'].split('filename=')[1].gsub(/[\\\"]|.zip/, '') rescue ''
|
zip_name = response['content-disposition'].split('filename=')[1].gsub(/[\\\"]|.zip/, '') rescue ''
|
||||||
|
case purchase._type
|
||||||
|
when 'Pdesign'
|
||||||
unzip_design(temp_file, zip_name)
|
unzip_design(temp_file, zip_name)
|
||||||
|
when 'PModuleApp'
|
||||||
|
unzip_module_app(temp_file, zip_name)
|
||||||
|
end
|
||||||
temp_file.close
|
temp_file.close
|
||||||
temp_file.unlink
|
temp_file.unlink
|
||||||
end
|
end
|
||||||
|
@ -113,6 +118,59 @@ class Admin::PurchasesController < ApplicationController
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def unzip_module_app(file, zip_name)
|
||||||
|
destination = "#{Rails.root}/vendor/plugins"
|
||||||
|
Zip::ZipFile.open(file) do |zip_file|
|
||||||
|
encrypted = {}
|
||||||
|
['encrypted_data', 'encrypted_key', 'encrypted_iv'].each do |e|
|
||||||
|
encrypted.merge!(e => zip_file.read(e))
|
||||||
|
end
|
||||||
|
orig_file = decrypt_data(encrypted['encrypted_data'], encrypted['encrypted_key'], encrypted['encrypted_iv'])
|
||||||
|
|
||||||
|
temp_file = Tempfile.new("temp_file_zip")
|
||||||
|
temp_file.binmode
|
||||||
|
temp_file.write orig_file
|
||||||
|
temp_file.rewind
|
||||||
|
|
||||||
|
Zip::ZipFile.open(temp_file) { |orig_zip|
|
||||||
|
module_app = ModuleApp.new.from_json(orig_zip.read("#{zip_name}/#{zip_name}.json"))
|
||||||
|
orig_zip.remove("#{zip_name}/#{zip_name}.json")
|
||||||
|
|
||||||
|
orig_zip.each do |orig|
|
||||||
|
inner_temp_file = Tempfile.new("inner_temp_file_zip")
|
||||||
|
inner_temp_file.binmode
|
||||||
|
inner_temp_file.write orig_zip.read(orig)
|
||||||
|
inner_temp_file.rewind
|
||||||
|
|
||||||
|
Zip::ZipFile.open(inner_temp_file) {|inner_zip|
|
||||||
|
inner_zip.each do |f|
|
||||||
|
if (f.to_s=~/^#{zip_name}\/*/)
|
||||||
|
f_path = File.join(destination, f.name)
|
||||||
|
FileUtils.mkdir_p(File.dirname(f_path))
|
||||||
|
inner_zip.extract(f, f_path) unless File.exist?(f_path)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
}
|
||||||
|
inner_temp_file.close
|
||||||
|
inner_temp_file.unlink
|
||||||
|
end
|
||||||
|
|
||||||
|
module_app.save
|
||||||
|
|
||||||
|
log = Logger.new(STDOUT)
|
||||||
|
log.level = Logger::WARN
|
||||||
|
log.warn("App unzip procress is finished,please restart the server to apply effect")
|
||||||
|
}
|
||||||
|
|
||||||
|
temp_file.close
|
||||||
|
temp_file.unlink
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def build_file(orig_zip, zip_name, dir, object, type = nil)
|
def build_file(orig_zip, zip_name, dir, object, type = nil)
|
||||||
title = object.file_filename
|
title = object.file_filename
|
||||||
temp = File.new(dir + '/' + title, 'w+')
|
temp = File.new(dir + '/' + title, 'w+')
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
class AppModule
|
class ModuleApp
|
||||||
include Mongoid::Document
|
include Mongoid::Document
|
||||||
include Mongoid::Timestamps
|
include Mongoid::Timestamps
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
class PModuleApp < Purchase
|
||||||
|
|
||||||
|
end
|
|
@ -1,5 +1,5 @@
|
||||||
<%# if @site && @site.registered? %>
|
<% if @site && @site.registered? %>
|
||||||
<% if @site %>
|
<%# if @site %>
|
||||||
<div class="bought_btn">
|
<div class="bought_btn">
|
||||||
<%= t('admin.registered') %>
|
<%= t('admin.registered') %>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -3,11 +3,11 @@
|
||||||
<table id="siteinfo_tb">
|
<table id="siteinfo_tb">
|
||||||
<tr>
|
<tr>
|
||||||
<td>School Name</td>
|
<td>School Name</td>
|
||||||
<td>RulingDigital Universitry</td>
|
<td><%= @site.school %></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Department</td>
|
<td>Department</td>
|
||||||
<td>Computer Science</td>
|
<td><%= @site.department %></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>Version</td>
|
<td>Version</td>
|
||||||
|
|
|
@ -35,6 +35,8 @@ class CentralServerExchangeApp < Sinatra::Base
|
||||||
case params[:type]
|
case params[:type]
|
||||||
when 'Design'
|
when 'Design'
|
||||||
purchase = PDesign.new.from_json(private_key.private_decrypt(request.params['purchase']))
|
purchase = PDesign.new.from_json(private_key.private_decrypt(request.params['purchase']))
|
||||||
|
when 'ModuleApp'
|
||||||
|
purchase = PModuleApp.new.from_json(private_key.private_decrypt(request.params['purchase']))
|
||||||
end
|
end
|
||||||
|
|
||||||
purchase.save
|
purchase.save
|
||||||
|
|
|
@ -11,7 +11,7 @@ namespace :dev do
|
||||||
include
|
include
|
||||||
end.each(&:drop)
|
end.each(&:drop)
|
||||||
|
|
||||||
Site.create( :school => 'The Best School', :department => 'Awesome', :valid_locales => [ 'en', 'zh_tw' ], :in_use_locales => [ 'zh_tw', 'en' ])
|
Site.create( :school => 'RulingDigital Universitry', :department => 'Computer Science', :valid_locales => [ 'en', 'zh_tw' ], :in_use_locales => [ 'zh_tw', 'en' ])
|
||||||
|
|
||||||
user = User.new( :email => 'chris@rulingcom.com', :password => 'password', :password_confirmation => 'password', :admin => true, :active_role => 'teacher')
|
user = User.new( :email => 'chris@rulingcom.com', :password => 'password', :password_confirmation => 'password', :admin => true, :active_role => 'teacher')
|
||||||
user.user_roles.build(:key => 'teacher', :discipline_en => 'Database', :discipline_zh_tw => '資料庫' )
|
user.user_roles.build(:key => 'teacher', :discipline_en => 'Database', :discipline_zh_tw => '資料庫' )
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
{
|
{
|
||||||
"name_of_app": "NewBlog",
|
"title": "NewBlog",
|
||||||
"version": "0.1",
|
"version": "0.1",
|
||||||
"organization": "Rulingcom",
|
"organization": "Rulingcom",
|
||||||
"author": "RD dep",
|
"author": "RD dep",
|
||||||
|
|
Reference in New Issue