1.创建一个项目 指定数据库
rails new demo02 -d mysql
2.修改 config/database.yml 修改数据库密码
default: &default
adapter: mysql2
encoding: utf8
pool: <%= ENV.fetch("RAILS_MAX_THREADS") { 5 } %>
username: root
password: 111
host: localhost
development:
<<: *default
database: AirQueen_development
3. 创建数据库(会创建2个库 airQueen_developmen airqueen_developmen_test )
rails db:create
4. 执行数据迁移
rails db:migrate
5. 安装bundler
gem install bundler
6. 执行bundle update
------------------------------------------------
创建控制器 包含index动作
rails g controller work_pros index
创建模型层
rails generate model vehicle type:string color:string price:decimal{10.2}
-------------------------------------------------------------------------
创建资源 user shop 在shops表中添加user_name 关联字段
rails g scaffold user name age shop_id:integer
rails db:migrate (执行迁移创建表)
rails g scaffold shop name price:integer shop_id:integer num:integer user_name
rails db:migrate
-------------------------------------------------------------------
关联查询
select u.*,s.price from users u join shops s on u.name=s.user_name
使用find_by_sql()
@shops = User.find_by_sql("select u.*,s.price,s.name sname from users u join shops s on
u.name=s.user_name where u.name='lmg02'")
根据名字关联查询【使用find_by_sql()】
@name = params[:name]
@shops = User.find_by_sql("select u.*,s.price,s.name sname from users u join shops s on
u.name=s.user_name where u.name='#{@name}'")
--------------------------------------------------------------
同时保存2张表数据
def create
linkman = params[:linkman]
tel = params[:linkman_tel]
unit = params[:unit_address]
@SRegionCode = SRegionCode.new(params_s_region_code)
respond_to do |format|
if @SRegionCode.save
@info = SRegionCodeInfo.new(:linkman => linkman, :linkman_tel => tel, :unit_address
=> unit, :s_region_code_id => @SRegionCode.id)
@info.save
format.html {redirect_to "/s_region_code"}
format.json {render json: {status: "success", location: @SRegionCode}}
else
format.html {render :new}
format.json {render json: {status: "false", location: @SRegionCode.errors}}
end
end
end
step1:
创建关联的表 model d_power_cut_audit_logs【关联字段d_power_cut_record_id:integer】
rails g model d_power_cut_audit_log audit_cause note d_power_cut_record_id:integer
--------------------------------------------------------------------
audit_cause = params[:audit_des]
note = params[:note]
#保存关联数据到另一张表
@power_cut_audit_log=DPowerCutAuditLog.new(:audit_cause => audit_cause, :note =>
note, :d_power_cut_record_id => @powerCutRecord.id)
@power_cut_audit_log.save
#按条件查询
@unit_yw = params[:unit_yw] # 按运维单位
@station_name = params[:station_name] # 按站点
@job_status = params[:job_status] # 按工单状态
@origin = params[:origin] # 按来源
@audit_des = params[:audit_des] # 按回退原因
#按运维单位搜索
scope :by_unit_yw, ->(unit_yw) {
where(:unit_yw => unit_yw) if unit_yw.present?
}
#按站点搜索
scope :by_station_name, ->(station_name) {
where(:station_name => station_name) if work_type.present?
}
#按工单状态搜索
scope :by_job_status, ->(job_status) {
where(:job_status => job_status) if job_status.present?
}
#按来源搜索
scope :by_origin, ->(origin) {
where(:origin => origin) if origin.present?
}
#按回退原因搜索
scope :by_audit_des, ->(audit_des) {
where(:audit_des => audit_des) if audit_des.present?
}
#按创建时间
scope :by_created_at, ->(created_at,end_at) {
where(:created_at => (created_at..end_at)) if created_at.present? && end_at.present?
}
scope :by_time, ->(created_time,end_time) {
where(created_at: (created_time)..end_time) if created_time.present? &&
end_time.present?
}
#获取创建开始时间
@created_at=params[:created_at].to_s + " 00:00:00" if params[:created_at].present?
#获取结束时间
@end_at=params[:end_at].to_s + " 23:59:59" if params[:end_at].present?
------------------------------------------------------------
【将前端查询的条件封装为一个json---详见:d_power_cut_record.rb】
模型层DPowerCutRecord
def self.status
@str = []
%w(待分配 待处理 待审核 完成).each_with_index do |statu,index|
hande_no = %w(waitting no_handle no_audit finish )[index]
@str << {value: statu, text: hande_no }
end
return @str
end
json中添加
json.status DPowerCutRecord.status
-----------------------------------------------------------------
【转换日期格式】
json.powerCutRecords @powerCutRecords do |p|
#json.id p.id
#json.station_name p.station_name
# json.unit_yw p.unit_yw
json.begin_time p.begin_time.strftime("%Y/%m/%d %H:%M:%S")
json.end_time p.end_time.strftime("%Y/%m/%d %H:%M:%S")
#json.time_range p.time_range
json.created_at p.created_at.strftime("%Y/%m/%d %H:%M:%S")
#json.exception_name p.exception_name
# json.origin p.origin
# json.handle_man p.handle_man
# json.audit_des p.audit_des
# json.job_status p.job_status
# json.img_path p.img_path
end
【转换日期格式---项目中的写法】
方式2:(项目中的写法 d_alarms /index.json.jbuilder)
json.first_alarm_time alarm.first_alarm_time.present? ? alarm.first_alarm_time.strftime
("%Y-%m-%d %H:%M:%S") : ''
json.last_alarm_time alarm.last_alarm_time.present? ? alarm.last_alarm_time.strftime("%Y-
%m-%d %H:%M:%S") : ''
【CRT中:调用model类方法查询】
DPowerCutRecord.where(:d_station_id => ["1","2","1001"]).by_unit_yw("")
--------------------------------------------------
Last login: Fri Aug 25 09:21:15 2017 from 172.168.10.84
dingfj@envsafe-server:~$ cd ../envsafe/AirQueen
dingfj@envsafe-server:/home/envsafe/AirQueen$ sudo su envsafe
[sudo] dingfj 的密码:
envsafe@envsafe-server:~/AirQueen$ rails c
--------------》修改文件后需要退出重新进入
exit 退出
rails c
1.创建一个项目 指定数据库rails new demo02 -d mysql 2.修改 config/database.yml 修改数据库密码 3. 创建数据库(会创建2个库 demo02_developem demo02_test )rails db:create
4. 安装bundlergem install bundler 5. 执行bundle update
创建控制器 包含index动作rails g controller work_pros index
创建模型层rails generate model vehicle type:string color:string price:decimal{10.2} -------------------------------------------------------------------------创建资源 user shop 在shops表中添加user_name 关联字段 rails g scaffold user name age shop_id:integer rails db:migrate (执行迁移创建表) rails g scaffold shop name price:integer shop_id:integer num:integer user_namerails db:migrate
-------------------------------------------------------------------关联查询select u.*,s.price from users u join shops s on u.name=s.user_name使用find_by_sql()@shops = User.find_by_sql("select u.*,s.price,s.name sname from users u join shops s on u.name=s.user_name where u.name='lmg02'")
根据名字关联查询【使用find_by_sql()】@name = params[:name]@shops = User.find_by_sql("select u.*,s.price,s.name sname from users u join shops s on u.name=s.user_name where u.name='#{@name}'") --------------------------------------------------------------同时保存2张表数据 def create linkman = params[:linkman] tel = params[:linkman_tel] unit = params[:unit_address] @SRegionCode = SRegionCode.new(params_s_region_code) respond_to do |format| if @SRegionCode.save @info = SRegionCodeInfo.new(:linkman => linkman, :linkman_tel => tel, :unit_address => unit, :s_region_code_id => @SRegionCode.id) @info.save format.html {redirect_to "/s_region_code"} format.json {render json: {status: "success", location: @SRegionCode}} else format.html {render :new} format.json {render json: {status: "false", location: @SRegionCode.errors}} end end end step1: 创建关联的表 model d_power_cut_audit_logs【关联字段d_power_cut_record_id:integer】 rails g model d_power_cut_audit_log audit_cause note d_power_cut_record_id:integer -------------------------------------------------------------------- audit_cause = params[:audit_des] note = params[:note] #保存关联数据到另一张表 @power_cut_audit_log=DPowerCutAuditLog.new(:audit_cause => audit_cause, :note => note, :d_power_cut_record_id => @powerCutRecord.id) @power_cut_audit_log.save
#按条件查询 @unit_yw = params[:unit_yw] # 按运维单位 @station_name = params[:station_name] # 按站点 @job_status = params[:job_status] # 按工单状态 @origin = params[:origin] # 按来源 @audit_des = params[:audit_des] # 按回退原因 #按运维单位搜索scope :by_unit_yw, ->(unit_yw) { where(:unit_yw => unit_yw) if unit_yw.present?} #按站点搜索 scope :by_station_name, ->(station_name) { where(:station_name => station_name) if work_type.present?} #按工单状态搜索 scope :by_job_status, ->(job_status) { where(:job_status => job_status) if job_status.present?} #按来源搜索 scope :by_origin, ->(origin) { where(:origin => origin) if origin.present?} #按回退原因搜索 scope :by_audit_des, ->(audit_des) { where(:audit_des => audit_des) if audit_des.present?} #按创建时间scope :by_created_at, ->(created_at,end_at) { where(:created_at => (created_at..end_at)) if created_at.present? && end_at.present?} scope :by_time, ->(created_time,end_time) {where(created_at: (created_time)..end_time) if created_time.present? && end_time.present?}
#获取创建开始时间@created_at=params[:created_at].to_s + " 00:00:00" if params[:created_at].present?#获取结束时间@end_at=params[:end_at].to_s + " 23:59:59" if params[:end_at].present? ------------------------------------------------------------【将前端查询的条件封装为一个json---详见:d_power_cut_record.rb】模型层DPowerCutRecorddef self.status @str = [] %w(待分配 待处理 待审核 完成).each_with_index do |statu,index| hande_no = %w(waitting no_handle no_audit finish )[index] @str << {value: statu, text: hande_no } end return @strend json中添加json.status DPowerCutRecord.status -----------------------------------------------------------------【转换日期格式】 json.powerCutRecords @powerCutRecords do |p|
#json.id p.id #json.station_name p.station_name # json.unit_yw p.unit_yw json.begin_time p.begin_time.strftime("%Y/%m/%d %H:%M:%S") json.end_time p.end_time.strftime("%Y/%m/%d %H:%M:%S") #json.time_range p.time_range json.created_at p.created_at.strftime("%Y/%m/%d %H:%M:%S") #json.exception_name p.exception_name # json.origin p.origin # json.handle_man p.handle_man # json.audit_des p.audit_des # json.job_status p.job_status # json.img_path p.img_path end 【转换日期格式---项目中的写法】方式2:(项目中的写法 d_alarms /index.json.jbuilder)json.first_alarm_time alarm.first_alarm_time.present? ? alarm.first_alarm_time.strftime ("%Y-%m-%d %H:%M:%S") : ''json.last_alarm_time alarm.last_alarm_time.present? ? alarm.last_alarm_time.strftime("%Y- %m-%d %H:%M:%S") : ''
【CRT中:调用model类方法查询】 DPowerCutRecord.where(:d_station_id => ["1","2","1001"]).by_unit_yw("") -------------------------------------------------- Last login: Fri Aug 25 09:21:15 2017 from 172.168.10.84dingfj@envsafe-server:~$ cd ../envsafe/AirQueendingfj@envsafe-server:/home/envsafe/AirQueen$ sudo su envsafe [sudo] dingfj 的密码: envsafe@envsafe-server:~/AirQueen$ rails c --------------》修改文件后需要退出重新进入exit 退出rails c
#封装 按回退原因 搜素信息def self.audits @str = [] %w(停电时间超出证明范围 停电时间填写有误 停电站点与凭证中的站点名称不符 间断停电时间请分 开录入 其他).each_with_index do |statu,index| hande_no = %w(out_range info_wrong no_match sep_entry other )[index] @str << {value: statu, text: hande_no } end return @strend #封装 按来源 搜素信息def self.origins @str = [] %w(地方站报送 其它报送 市站盖章 地方供电局证明 公司盖章 其他).each_with_index do | statu,index| hande_no = %w(local_submit other_submit city_stamp local_prove company_seal other ) [index] @str << {value: statu, text: hande_no } end return @strend ------------------------------------------------
-------------------------报错信息------------------------------------Completed 500 Internal Server Error in 6ms (ActiveRecord: 0.6ms) NoMethodError (undefined method `[]' for nil:NilClass): app/controllers/ops_audit_controller.rb:28:in `update'
Parameters: {"audit_if"=>"Y", "audit_des"=>"", "id"=>"27"} DTaskForm Load (0.5ms) SELECT `d_task_forms`.* FROM `d_task_forms` WHERE `d_task_forms`.`id` = 27 LIMIT 1当前用户的SessionCode: WViY6LkSdLPq9TO9qY8DCg DLoginMsg Load (0.5ms) SELECT `d_login_msgs`.* FROM `d_login_msgs` WHERE `d_login_msgs`.`session` = 'WViY6LkSdLPq9TO9qY8DCg' LIMIT 1当前用户信息: #<DLoginMsg:0xb3351e8>当前用户的SessionCode: WViY6LkSdLPq9TO9qY8DCgCompleted 400 Bad Request in 6ms (ActiveRecord: 1.0ms) ActionController::ParameterMissing (param is missing or the value is empty: d_task_form): app/controllers/ops_audit_controller.rb:72:in `ops_audit_params' app/controllers/ops_audit_controller.rb:42:in `block in update' app/controllers/ops_audit_controller.rb:41:in `update
--------------批量审核-------------------batch_audit?batch_audit_ids=["2065","2398"]
batch_audit_ops_audit_index POST /ops_audit/batch_audit(.:format) ops_audit#batch_audit ops_audit_index GET /ops_audit(.:format) ops_audit#index POST /ops_audit(.:format) ops_audit#create new_ops_audit GET /ops_audit/new(.:format) ops_audit#new edit_ops_audit GET /ops_audit/:id/edit(.:format) ops_audit#edit ops_audit GET /ops_audit/:id(.:format) ops_audit#show PATCH /ops_audit/:id(.:format) ops_audit#update PUT /ops_audit/:id(.:format) ops_audit#update DELETE /ops_audit/:id(.:format) ops_audit#destroy
Started POST "/ops_audit/batch_audit.json" for 172.168.10.84 at 2017-09-01 16:37:51 +0800Cannot render console from 172.168.10.84! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255Processing by OpsAuditController#batch_audit as JSON Parameters: {"batch_audit_ids"=>"28,27,26"}当前用户的SessionCode: V_gaUK87N85ouf1kK924Ww DLoginMsg Load (0.5ms) SELECT `d_login_msgs`.* FROM `d_login_msgs` WHERE `d_login_msgs`.`session` = 'V_gaUK87N85ouf1kK924Ww' LIMIT 1当前用户信息: #<DLoginMsg:0xb3489230>当前用户的SessionCode: V_gaUK87N85ouf1kK924Ww DTaskForm Load (0.4ms) SELECT `d_task_forms`.* FROM `d_task_forms` WHERE `d_task_forms`.`id` = 28 (0.2ms) BEGIN SQL (0.4ms) UPDATE `d_task_forms` SET `job_status` = 'audit', `audit_time` = '2017-09-01 16:37:51', `audit_if` = 'Y', `updated_at` = '2017-09-01 16:37:51' WHERE `d_task_forms`.`id` = 28 (69.1ms) COMMIT (0.2ms) BEGIN SQL (0.3ms) INSERT INTO `d_fault_job_details` (`job_status`, `handle_man`, `begin_time`, `end_time`, `handle_status`, `d_task_form_id`, `created_at`, `updated_at`) VALUES ('audit', 'zs11', '2017-09-01 16:37:51', '2017-09-01 16:37:51', '完成', 28, '2017-09-01 16:37:51', '2017-09-01 16:37:51') (25.3ms) COMMITCompleted 200 OK in 128ms (Views: 1.3ms | ActiveRecord: 96.4ms)---------------------按数据查询------------------------- #按站点id查询 scope :by_station_id, ->(station_ids){ where(d_station_id: station_ids) if station_ids.present? } #按创建时间查询 scope :by_time, ->(created_time,end_time) { where(created_at: (created_time)..end_time) if created_time.present? && end_time.present? }-----------------------------------------------------------------------【关联表数据的保存】#保存工单日志 (通过不通过均保存日志信息) #@d_fault_job_detail=DFaultJobDetail.new(:job_status => @ops_audit.job_status,:handle_man => handle_man,:begin_time => Time.now,:end_time =>Time.now,:handle_status =>handle_status,:d_task_form_id =>@ops_audit.id) @d_fault_job_detail=@ops_audit.d_fault_job_details.new(:job_status => @ops_audit.job_status,:handle_man => handle_man,:begin_time => Time.now,:end_time =>Time.now,:handle_status =>handle_status) @d_fault_job_detail.save-------------------------【关联查询省份信 息】--------------------------------------------------- area = ops.s_administrative_area province = area.zone_name == "北京市" ? area.zone_name : area.parent.zone_name json.id ops.id json.procince province ----------------审核查询条件------------------ http://172.168.10.7:3030/ops_audit_manages/plan_audit.json? handle_station=1001&week_time=2017-08-28%2000:00:00&edit_status=W Started GET "/ops_audit_manages/plan_audit.json?plan_audit_params%5B0%5D%5Bparam%5D %5Bweek_time%5D=2017-09-04&plan_audit_params%5B0%5D%5Bparam%5D%5Bhandle_station%5D%5B %5D=1001&plan_audit_params%5B1%5D%5Bparam%5D%5Bweek_time%5D=2017-09-11&plan_audit_params %5B1%5D%5Bparam%5D%5Bhandle_station%5D%5B%5D=1001&edit_status=W" for 172.168.10.84 at 2017 -09-15 17:24:13 +0800Cannot render console from 172.168.10.84! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255Processing by OpsAuditManagesController#plan_audit as JSON Parameters: {"plan_audit_params"=>{"0"=>{"param"=>{"week_time"=>"2017-09-04", "handle_station"=>["1001"]}}, "1"=>{"param"=>{"week_time"=>"2017-09-11", "handle_station"=>["1001"]}}}, "edit_status"=>"W"}当前用户的SessionCode: bnCFWOZa-VzuTq4S36iXxw DLoginMsg Load (0.6ms) SELECT `d_login_msgs`.* FROM `d_login_msgs` WHERE `d_login_msgs`.`session` = 'bnCFWOZa-VzuTq4S36iXxw' LIMIT 1当前用户信息: #<DLoginMsg:0xac03e2f4>当前用户的SessionCode: bnCFWOZa-VzuTq4S36iXxwCompleted 500 Internal Server Error in 4ms (ActiveRecord: 0.6ms) TypeError (no implicit conversion of String into Integer): app/controllers/ops_audit_manages_controller.rb:24:in `[]' app/controllers/ops_audit_manages_controller.rb:24:in `block in plan_audit' app/controllers/ops_audit_manages_controller.rb:23:in `plan_audit'
Rendered vendor/bundle/ruby/2.3.0/gems/actionpack- 4.2.6/lib/action_dispatch/middleware/templates/rescues/_source.erb (4.7ms) Rendered vendor/bundle/ruby/2.3.0/gems/actionpack- 4.2.6/lib/action_dispatch/middleware/templates/rescues/_trace.text.erb (1.0ms) Rendered vendor/bundle/ruby/2.3.0/gems/actionpack- 4.2.6/lib/action_dispatch/middleware/templates/rescues/_request_and_response.text.erb (1.3ms) Rendered vendor/bundle/ruby/2.3.0/gems/actionpack- 4.2.6/lib/action_dispatch/middleware/templates/rescues/diagnostics.text.erb (38.0ms)^Cenvsafe@envsafe-server:~/AirQueen/log$ no implicit conversion of String into Integer^C -------------------封装参数---------- Parameters: {"plan_details_params"=>{"params"=>{"0"=>{"id"=>"26", "job_time"=>"2017-09- 12"}, "1"=>{"id"=>"27", "job_time"=>"2017-09- 12"}}}, "id"=>"8"} plan_details_params=params[:plan_details_params][:params] #获取到参数 plan_details_params.each do |params| @ops_plan_detail=@ops_plan.d_ops_plan_details.find_by(:d_work_pro_id =>params[1]['id']) @ops_plan_detail.job_time=params[1]['job_time'] Parameters: {"plan_audit_params"=>{"0"=>{"param"=>{"week_time"=>"2017-09-04", "handle_station"=>["1001"]}}, "1"=>{"param"=>{"week_time"=>"2017-09-11", "handle_station"=>["1001"]}}}, "edit_status"=>"W"} plan_audit_params = params[:plan_audit_params] #是一个数组 edit_if = params[:edit_status] #审核内容 plan_audit_params.each do |param| week_time = param['param']['week_time'] d_station_id = param['param']['handle_station'] @ops_plans = DOpsPlanManage.where(d_station_id: d_station_id, week_begin_time: week_time) -----each后-----》 ["0", {"param"=>{"week_time"=>"2017-09-04", "handle_station"=>["1001"]}}] ------------图片上传--------------------------- Started POST "/power_cut_records" for 172.168.10.84 at 2017-09-19 18:09:32 +0800Cannot render console from 172.168.10.84! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255Processing by PowerCutRecordsController#create as HTML Parameters: {"utf8"=>"✓", "d_power_cut_record"=>{"station_name"=>"平顶山市-高压开关厂", "d_station_id"=>"1831", "begin_time"=>"2017-09-19 06:40", "end_time"=>"2017-09-20 06:02", "time_range"=>"5", "exception_name"=>"", "exception_device_type"=>"on", "handle_man"=>"lmg", "origin"=>"其他"}, "image_file"=>#<ActionDispatch::Http::UploadedFile:0xc999bb4 @tempfile=#<Tempfile:/tmp/RackMultipart20170919-2211-p7gtz3.png>, @original_filename="商丘 运维模块图0906.png", @content_type="image/png", @headers="Content-Disposition: form-data; name=\"image_file\"; filename=\"\xE5\x95\x86\xE4\xB8\x98\xE8\xBF\x90\xE7\xBB \xB4\xE6\xA8\xA1\xE5\x9D\x97\xE5\x9B\xBE0906.png\"\r\nContent-Type: image/png\r\n">}Can't verify CSRF token authenticityCompleted 422 Unprocessable Entity in 1ms (ActiveRecord: 0.0ms) #上传图片 多个图片 def upload_img(tasks,id) picture = "img#{Time.now.strftime('%Y%m%d%H%M%S')}.jpg" tasks.each_value do |task| handle_type = task['handle_type'] image_file = task['image_file'] Rails.logger.info ">>>>>#{handle_type}" png = Base64.decode64(image_file['data:image/jpeg;base64,'.length .. -1]) #向dir目录写入文件 File.open(Rails.root.join("public","task_app_images", picture ), 'wb') { |f| f.write(png) } #创建或者修改上传图片记录 if @handle = DFaultHandle.find_by(:d_task_form_id =>id,:handle_type =>handle_type).blank? @handle = DFaultHandle.create(:handle_man =>@current_user.login_name,:handle_type => handle_type,:handle_time =>Time.now,:d_task_form_id => id,:img_one => "task_app_images/#{picture}") else @handle = DFaultHandle.find_by(:d_task_form_id =>id,:handle_type=> handle_type) @handle.update(:img_one => "task_app_images/#{picture}",:handle_time =>Time.now) end end ---------------------------------------------------- #只保存图片到本地文件 def save if filename=uploadFile(params[:file]['file']) redirect_to :action => "index" end end def uploadFile(file) if !file.original_filename.empty? @filename=getFileName(file.original_filename) File.open("d:/#{@filename}", "wb") do |f| f.write(file.read) end return @filename end end def getFileName(filename) if !filename.nil? return filename end end #保存到项目中 def upload uploaded_io = params['file'] File.open(Rails.root.join('public', uploaded_io.original_filename), 'wb') do |file| file.write(uploaded_io.read) end redirect_to :action => "index" end -------------------图片上传的参数---------------------------- Parameters: {"task"=>{"tasks"=>{"0"=>{"id"=>"151", "handle_type"=>"每周(次)巡检工作汇总表 ", "image_file"=>" AABAAAAYgEbAAUAAAABAAAAagEoAAMAAAABAAIAAAExAAIAAAAcAAAAcgEyAAIAAAAUAAAAjodpAAQAAAABAAAApAAA ANAACvyAAAAnEAAK/IAAACcQQWRvYmUgUGhvdG9zaG9wIENTNSBXaW5kb3dzADIwMTc6MDk6MjEgMTI6NTk6NTAAAAA AA6ABAAMAAAAB//8AAKACAAQAAAABAAAAlqADAAQAAAABAAAAggAAAAAAAAAGAQMAAwAAAAEABgAAARoABQAAAAEAAA EeARsABQAAAAEAAAEmASgAAwAAAAEAAgAAAgEABAAAAAEAAAEuAgIABAAAAAEAAAgbAAAAAAAAAEgAAAABAAAASAAAA AH/2P/tAAxBZG9iZV9DTQAC/ +4ADkFkb2JlAGSAAAAAAf/bAIQADAgICAkIDAkJDBELCgsRFQ8MDA8VGBMTFRMTGBEMDAwMDAwRDAwMDAwMDAwMDAwM DAwMDAwMDAwMDAwMDAwMDAENCwsNDg0QDg4QFA4ODhQUDg4ODhQRDAwMDAwREQwMDAwMDBEMDAwMDAwMDAwMDAwMDAw MDAwMDAwMDAwMDAwM/8AAEQgAggCWAwEiAAIRAQMRAf/dAAQACv/EAT8AAAEFAQEBAQEBAAAAAAAAAAMAAQIEBQYHCA kKCwEAAQUBAQEBAQEAAAAAAAAAAQACAwQFBgcICQoLEAABBAEDAgQCBQcGCAUDDDMBAAIRAwQhEjEFQVFhEyJxgTIGF JGhsUIjJBVSwWIzNHKC0UMHJZJT8OHxY3M1FqKygyZEk1RkRcKjdDYX0lXiZfKzhMPTdePzRieUpIW0lcTU5PSltcXV 5fVWZnaGlqa2xtbm9jdHV2d3h5ent8fX5/cRAAICAQIEBAMEBQYHBwYFNQEAAhEDITESBEFRYXEiEwUygZEUobFCI8F S0fAzJGLhcoKSQ1MVY3M08SUGFqKygwcmNcLSRJNUoxdkRVU2dGXi8rOEw9N14/NGlKSFtJXE1OT0pbXF1eX1VmZ2hp amtsbW5vYnN0dXZ3eHl6e3x//aAAwDAQACEQMRAD8A9VSSSSUpJJJJSkkkL7Tjjm1n+cElJUkL7Tjf6Vn +cEvtON/pWf5wSUlSQvtON/pWf5wS+043+lZ/nBJSVJC+043+lZ/nBL7Tjf6Vn+cElJUkL7Tjf6Vn +cFNr2PEscHDxBlJTJJJJJSkkkklKSSSSU//0PVUkkklKSSSSU4P1szLqMWumpxZ6zjvI0O0D6KxX/VzqH2avJqaL22 NDi1v0hPkfpLT+uf0Mb4u/Itzpv8Ayfj/APFt/Igp8+dWWO2PaWOGhBEELSw+iV5o/QZtJf3Y4Oa4f2XLr8vp +HmN25FTX+DuHD+0PcsDN+qVjT6mBbujUVv0d/ZsCVKR/wDM3M/09X3OS/5m5n+nq +5yFV1jrXSninLa6xg/MtmY/kW/+drcwfrJ07Lhr3fZ7D +bZoP7L/opaKcj/mbmf6er7nJf8zcz/T1fc5dWCCJGoKdGlPJ/8zcz/T1fc5AwDldI62zENm5rnBlgbO0h38krs1yHU P8AxUt/4yv8iCnr0kkkVKSSSSUpJJJJT//R9VSSSSUpJJJJTzX1z +hjfF35FudN/wCT8f8A4tv5Fh/XP6GN8XfkW503/k/H/wCLb +RJTZSSSSUwtpquYa7mNsYeWuEj8Vh531TxbZfhvND/ANw +5n/k2rfSSU8WLetdBtaywn0idGE7q3AfS2/ursMe5uRRXe3RtjQ4DwkSsD65fzWN/Wd +QLX6R/yZjf8AFtQU3FyHUP8AxUt/4yv8i69ch1D/AMVLf +Mr/IkVPXpJJIqUkkkkpSSSSSn/0vVUkkklKSSSSU819c/oY3xd+RbnTf8Ak/H/AOLb+RYf1z +hjfF35FudN/5Px/8Ai2/kSU2UkkklKSSSSU859cv5rG/rO/IFr9I/5Mxv+Lasj65fzWN/Wd +QLX6R/wAmY3/FtQ6qbi5DqH/ipb/xlf5F165DqH/ipb/xlf5Eip69JJJFSkkkklKSSSSU/wD/0/VUkkklKSSSSU819 c/oY3xd+RbnTf8Ak/H/AOLb+RYf1z +hjfF35FudN/5Px/8Ai2/kSU2UkkklKWB1jrGZidWox6SBTDS9pAO7cSPpLfXJfWMH9u0CNS2uPP3OSKm19cv5rG/rO /IFr9I/5Mxv+Lasj65fzWN/Wd +QLX6R/wAmY3/FtQ6qbi5DqH/ipb/xlf5F165DqH/ipb/xlf5Eip69JJJFSkkkklKSSSSU/wD/1PVUkkklKSSSSU819 c/oY3xd+RbnTf8Ak/H/AOLb+RYf1z+hjfF35FudN/5Px/8Ai2/kSU2UkkklKQ30Uve2x7Guez6DiJI +CIkkp5z65fzWN/Wd+QLX6R/yZjf8W1ZH1y/msb+s78gWv0j/AJMxv +Lah1U3FyHUP/FS3/jK/wAi69ch1D/xUt/4yv8AIkVPXpJJIqUkkkkpSSSSSn//1fVUkkklKSSSSU4P1txLr8Wq6ppe KXHeBqQCPpKt0v6001U14+VWWhgDRazUQP3mLp1nZ3Qem5kufX6dh/wlftPz/Nckpt42Zi5TN +Pa2weR1H9Zv0moy5HJ+rXU8N/rYNhtDdRtO2wf +ST431n6jiP9HOr9WOdw2v8A/MkLU9aks/C6707MgMsDLD/g3+0rQRU859cv5rG/rO/IFn431n6hj0V0MrqLK2hrSWu mB/bWh9cv5rG/rO/IFrdJY09MxpA/m29kOqnnf+d3U/8ARU/5rv8Ayaj02rN6t1hubYzaxrg+xwBDfbw1u5dfsZ +6PuTgAcCEVLpJJJKUkkkkpSSSSSn/1vVUkkklKSSSSUpJJJJSkDJwsXLZsyKm2DzGv3o6SSnm836oMMvwbdp5Fdmo/ svVBuX1/oztlocah2f7mH +rYuzTOa17S14DmnkESClSniesda/atdDBUa31kl2sgk6exdd06p9OBj1PEPbW0OHgY4UauldOpt9avHY2zndHHw/dV tJSkkkklKSSSSUpJJJJSkkkklP/1/VUl8qpJKfqpJfKqSSn6qSXyqkkp+qkl8qpJKfqpJfKqSSn6qSXyqkkp +qkl8qpJKfqpJfKqSSn6qSXyqkkp +qkl8qpJKf/2f/tED5QaG90b3Nob3AgMy4wADhCSU0EJQAAAAAAEAAAAAAAAAAAAAAAAAAAAAA4QklNBDoAAAAAAJMA AAAQAAAAAQAAAAAAC3ByaW50T3V0cHV0AAAABQAAAABDbHJTZW51bQAAAABDbHJTAAAAAFJHQkMAAAAASW50ZWVudW0 AAAAASW50ZQAAAABDbHJtAAAAAE1wQmxib29sAQAAAA9wcmludFNpeHRlZW5CaXRib29sAAAAAAtwcmludGVyTmFtZV RFWFQAAAABAAAAOEJJTQQ7AAAAAAGyAAAAEAAAAAEAAAAAABJwcmludE91dHB1dE9wdGlvbnMAAAASAAAAAENwdG5ib 29sAAAAAABDbGJyYm9vbAAAAAAAUmdzTWJvb2wAAAAAAENybkNib29sAAAAAABDbnRDYm9vbAAAAAAATGJsc2Jvb2wA AAAAAE5ndHZib29sAAAAAABFbWxEYm9vbAAAAAAASW50cmJvb2wAAAAAAEJja2dPYmpjAAAAAQAAAAAAAFJHQkMAAAA DAAAAAFJkICBkb3ViQG/gAAAAAAAAAAAAR3JuIGRvdWJAb +AAAAAAAAAAAABCbCAgZG91YkBv4AAAAAAAAAAAAEJyZFRVbnRGI1JsdAAAAAAAAAAAAAAAAEJsZCBVbnRGI1JsdAAA AAAAAAAAAAAAAFJzbHRVbnRGI1B4bEBSAAAAAAAAAAAACnZlY3RvckRhdGFib29sAQAAAABQZ1BzZW51bQAAAABQZ1B zAAAAAFBnUEMAAAAATGVmdFVudEYjUmx0AAAAAAAAAAAAAAAAVG9wIFVudEYjUmx0AAAAAAAAAAAAAAAAU2NsIFVudE YjUHJjQFkAAAAAAAA4QklNA+0AAAAAABAASAAAAAEAAgBIAAAAAQACOEJJTQQmAAAAAAAOAAAAAAAAAAAAAD +AAAA4QklNBA0AAAAAAAQAAAAeOEJJTQQZAAAAAAAEAAAAHjhCSU0D8wAAAAAACQAAAAAAAAAAAQA4QklNJxAAAAAAA AoAAQAAAAAAAAACOEJJTQP1AAAAAABIAC9mZgABAGxmZgAGAAAAAAABAC9mZgABAKGZmgAGAAAAAAABADIAAAABAFoA AAAGAAAAAAABADUAAAABAC0AAAAGAAAAAAABOEJJTQP4AAAAAABwAAD/////////////////////////////A +gAAAAA/////////////////////////////wPoAAAAAP////////////////////////////8D6AAAAAD///////// ////////////////////A +gAADhCSU0ECAAAAAAAEAAAAAEAAAJAAAACQAAAAAA4QklNBB4AAAAAAAQAAAAAOEJJTQQaAAAAAAM5AAAABgAAAAAA AAAAAAAAggAAAJYAAAACAHcAeQAAAAEAAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAAAAAAAAAAlgAAAIIAAAAAAAAAAAA AAAAAAAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAQAAAAAQAAAAAAAG51bGwAAAACAAAABmJvdW5kc09iamMAAAABAAAAAA AAUmN0MQAAAAQAAAAAVG9wIGxvbmcAAAAAAAAAAExlZnRsb25nAAAAAAAAAABCdG9tbG9uZwAAAIIAAAAAUmdodGxvb mcAAACWAAAABnNsaWNlc1ZsTHMAAAABT2JqYwAAAAEAAAAAAAVzbGljZQAAABIAAAAHc2xpY2VJRGxvbmcAAAAAAAAA B2dyb3VwSURsb25nAAAAAAAAAAZvcmlnaW5lbnVtAAAADEVTbGljZU9yaWdpbgAAAA1hdXRvR2VuZXJhdGVkAAAAAFR 5cGVlbnVtAAAACkVTbGljZVR5cGUAAAAASW1nIAAAAAZib3VuZHNPYmpjAAAAAQAAAAAAAFJjdDEAAAAEAAAAAFRvcC Bsb25nAAAAAAAAAABMZWZ0bG9uZwAAAAAAAAAAQnRvbWxvbmcAAACCAAAAAFJnaHRsb25nAAAAlgAAAAN1cmxURVhUA AAAAQAAAAAAAG51bGxURVhUAAAAAQAAAAAAAE1zZ2VURVhUAAAAAQAAAAAABmFsdFRhZ1RFWFQAAAABAAAAAAAOY2Vs bFRleHRJc0hUTUxib29sAQAAAAhjZWxsVGV4dFRFWFQAAAABAAAAAAAJaG9yekFsaWduZW51bQAAAA9FU2xpY2VIb3J 6QWxpZ24AAAAHZGVmYXVsdAAAAAl2ZXJ0QWxpZ25lbnVtAAAAD0VTbGljZVZlcnRBbGlnbgAAAAdkZWZhdWx0AAAAC2 JnQ29sb3JUeXBlZW51bQAAABFFU2xpY2VCR0NvbG9yVHlwZQAAAABOb25lAAAACXRvcE91dHNldGxvbmcAAAAAAAAAC mxlZnRPdXRzZXRsb25nAAAAAAAAAAxib3R0b21PdXRzZXRsb25nAAAAAAAAAAtyaWdodE91dHNldGxvbmcAAAAAADhC SU0EKAAAAAAADAAAAAI/8AAAAAAAADhCSU0EEQAAAAAAAQEAOEJJTQQUAAAAAAAEAAAAAThCSU0EDAAAAAAINwAAAAE AAACWAAAAggAAAcQAAOWIAAAIGwAYAAH/2P/tAAxBZG9iZV9DTQAC/ +4ADkFkb2JlAGSAAAAAAf/bAIQADAgICAkIDAkJDBELCgsRFQ8MDA8VGBMTFRMTGBEMDAwMDAwRDAwMDAwMDAwMDAwM DAwMDAwMDAwMDAwMDAwMDAENCwsNDg0QDg4QFA4ODhQUDg4ODhQRDAwMDAwREQwMDAwMDBEMDAwMDAwMDAwMDAwMDAw MDAwMDAwMDAwMDAwM/8AAEQgAggCWAwEiAAIRAQMRAf/dAAQACv/EAT8AAAEFAQEBAQEBAAAAAAAAAAMAAQIEBQYHCA kKCwEAAQUBAQEBAQEAAAAAAAAAAQACAwQFBgcICQoLEAABBAEDAgQCBQcGCAUDDDMBAAIRAwQhEjEFQVFhEyJxgTIGF JGhsUIjJBVSwWIzNHKC0UMHJZJT8OHxY3M1FqKygyZEk1RkRcKjdDYX0lXiZfKzhMPTdePzRieUpIW0lcTU5PSltcXV 5fVWZnaGlqa2xtbm9jdHV2d3h5ent8fX5/cRAAICAQIEBAMEBQYHBwYFNQEAAhEDITESBEFRYXEiEwUygZEUobFCI8F S0fAzJGLhcoKSQ1MVY3M08SUGFqKygwcmNcLSRJNUoxdkRVU2dGXi8rOEw9N14/NGlKSFtJXE1OT0pbXF1eX1VmZ2hp amtsbW5vYnN0dXZ3eHl6e3x//aAAwDAQACEQMRAD8A9VSSSSUpJJJJSkkkL7Tjjm1n+cElJUkL7Tjf6Vn +cEvtON/pWf5wSUlSQvtON/pWf5wS+043+lZ/nBJSVJC+043+lZ/nBL7Tjf6Vn+cElJUkL7Tjf6Vn +cFNr2PEscHDxBlJTJJJJJSkkkklKSSSSU//0PVUkkklKSSSSU4P1szLqMWumpxZ6zjvI0O0D6KxX/VzqH2avJqaL22 NDi1v0hPkfpLT+uf0Mb4u/Itzpv8Ayfj/APFt/Igp8+dWWO2PaWOGhBEELSw+iV5o/QZtJf3Y4Oa4f2XLr8vp +HmN25FTX+DuHD+0PcsDN+qVjT6mBbujUVv0d/ZsCVKR/wDM3M/09X3OS/5m5n+nq +5yFV1jrXSninLa6xg/MtmY/kW/+drcwfrJ07Lhr3fZ7D +bZoP7L/opaKcj/mbmf6er7nJf8zcz/T1fc5dWCCJGoKdGlPJ/8zcz/T1fc5AwDldI62zENm5rnBlgbO0h38krs1yHU P8AxUt/4yv8iCnr0kkkVKSSSSUpJJJJT//R9VSSSSUpJJJJTzX1z +hjfF35FudN/wCT8f8A4tv5Fh/XP6GN8XfkW503/k/H/wCLb +RJTZSSSSUwtpquYa7mNsYeWuEj8Vh531TxbZfhvND/ANw +5n/k2rfSSU8WLetdBtaywn0idGE7q3AfS2/ursMe5uRRXe3RtjQ4DwkSsD65fzWN/Wd +QLX6R/yZjf8AFtQU3FyHUP8AxUt/4yv8i69ch1D/AMVLf +Mr/IkVPXpJJIqUkkkkpSSSSSn/0vVUkkklKSSSSU819c/oY3xd+RbnTf8Ak/H/AOLb+RYf1z +hjfF35FudN/5Px/8Ai2/kSU2UkkklKSSSSU859cv5rG/rO/IFr9I/5Mxv+Lasj65fzWN/Wd +QLX6R/wAmY3/FtQ6qbi5DqH/ipb/xlf5F165DqH/ipb/xlf5Eip69JJJFSkkkklKSSSSU/wD/0/VUkkklKSSSSU819 c/oY3xd+RbnTf8Ak/H/AOLb+RYf1z +hjfF35FudN/5Px/8Ai2/kSU2UkkklKWB1jrGZidWox6SBTDS9pAO7cSPpLfXJfWMH9u0CNS2uPP3OSKm19cv5rG/rO /IFr9I/5Mxv+Lasj65fzWN/Wd +QLX6R/wAmY3/FtQ6qbi5DqH/ipb/xlf5F165DqH/ipb/xlf5Eip69JJJFSkkkklKSSSSU/wD/1PVUkkklKSSSSU819 c/oY3xd+RbnTf8Ak/H/AOLb+RYf1z+hjfF35FudN/5Px/8Ai2/kSU2UkkklKQ30Uve2x7Guez6DiJI +CIkkp5z65fzWN/Wd+QLX6R/yZjf8W1ZH1y/msb+s78gWv0j/AJMxv +Lah1U3FyHUP/FS3/jK/wAi69ch1D/xUt/4yv8AIkVPXpJJIqUkkkkpSSSSSn//1fVUkkklKSSSSU4P1txLr8Wq6ppe KXHeBqQCPpKt0v6001U14+VWWhgDRazUQP3mLp1nZ3Qem5kufX6dh/wlftPz/Nckpt42Zi5TN +Pa2weR1H9Zv0moy5HJ+rXU8N/rYNhtDdRtO2wf +ST431n6jiP9HOr9WOdw2v8A/MkLU9aks/C6707MgMsDLD/g3+0rQRU859cv5rG/rO/IFn431n6hj0V0MrqLK2hrSWu mB/bWh9cv5rG/rO/IFrdJY09MxpA/m29kOqnnf+d3U/8ARU/5rv8Ayaj02rN6t1hubYzaxrg+xwBDfbw1u5dfsZ +6PuTgAcCEVLpJJJKUkkkkpSSSSSn/1vVUkkklKSSSSUpJJJJSkDJwsXLZsyKm2DzGv3o6SSnm836oMMvwbdp5Fdmo/ svVBuX1/oztlocah2f7mH +rYuzTOa17S14DmnkESClSniesda/atdDBUa31kl2sgk6exdd06p9OBj1PEPbW0OHgY4UauldOpt9avHY2zndHHw/dV tJSkkkklKSSSSUpJJJJSkkkklP/1/VUl8qpJKfqpJfKqSSn6qSXyqkkp+qkl8qpJKfqpJfKqSSn6qSXyqkkp +qkl8qpJKfqpJfKqSSn6qSXyqkkp +qkl8qpJKf/2QA4QklNBCEAAAAAAFUAAAABAQAAAA8AQQBkAG8AYgBlACAAUABoAG8AdABvAHMAaABvAHAAAAATAEEA ZABvAGIAZQAgAFAAaABvAHQAbwBzAGgAbwBwACAAQwBTADUAAAABADhCSU0EBgAAAAAABwAIAAAAAQEA/ +EN9Gh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8APD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhp SHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmU gWE1QIENvcmUgNS4wLWMwNjAgNjEuMTM0Nzc3LCAyMDEwLzAyLzEyLTE3OjMyOjAwICAgICAgICAiPiA8cmRmOlJERi B4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2Nya XB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOmRj PSJodHRwOi8vcHVybC5vcmcvZGMvZWxlbWVudHMvMS4xLyIgeG1sbnM6cGhvdG9zaG9wPSJodHRwOi8vbnMuYWRvYmU uY29tL3Bob3Rvc2hvcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG 1sbnM6c3RFdnQ9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZUV2ZW50IyIgeG1wOkNyZ WF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgQ1M1IFdpbmRvd3MiIHhtcDpDcmVhdGVEYXRlPSIyMDE3LTA5LTIxVDEy OjQ5KzA4OjAwIiB4bXA6TW9kaWZ5RGF0ZT0iMjAxNy0wOS0yMVQxMjo1OTo1MCswODowMCIgeG1wOk1ldGFkYXRhRGF 0ZT0iMjAxNy0wOS0yMVQxMjo1OTo1MCswODowMCIgZGM6Zm9ybWF0PSJpbWFnZS9qcGVnIiBwaG90b3Nob3A6Q29sb3 JNb2RlPSIzIiB4bXBNTTpJbnN0YW5jZUlEPSJ4bXAuaWlkOjBBMkRGRjg2ODk5RUU3MTE5QzlBODMxN0Y5M0ZGMzM4I iB4bXBNTTpEb2N1bWVudElEPSJ4bXAuZGlkOjA5MkRGRjg2ODk5RUU3MTE5QzlBODMxN0Y5M0ZGMzM4IiB4bXBNTTpP cmlnaW5hbERvY3VtZW50SUQ9InhtcC5kaWQ6MDkyREZGODY4OTlFRTcxMTlDOUE4MzE3RjkzRkYzMzgiPiA8eG1wTU0 6SGlzdG9yeT4gPHJkZjpTZXE +IDxyZGY6bGkgc3RFdnQ6YWN0aW9uPSJjcmVhdGVkIiBzdEV2dDppbnN0YW5jZUlEPSJ4bXAuaWlkOjA5MkRGRjg2OD k5RUU3MTE5QzlBODMxN0Y5M0ZGMzM4IiBzdEV2dDp3aGVuPSIyMDE3LTA5LTIxVDEyOjQ5KzA4OjAwIiBzdEV2dDpzb 2Z0d2FyZUFnZW50PSJBZG9iZSBQaG90b3Nob3AgQ1M1IFdpbmRvd3MiLz4gPHJkZjpsaSBzdEV2dDphY3Rpb249ImNv bnZlcnRlZCIgc3RFdnQ6cGFyYW1ldGVycz0iZnJvbSBpbWFnZS9wbmcgdG8gaW1hZ2UvanBlZyIvPiA8cmRmOmxpIHN 0RXZ0OmFjdGlvbj0ic2F2ZWQiIHN0RXZ0Omluc3RhbmNlSUQ9InhtcC5paWQ6MEEyREZGODY4OTlFRTcxMTlDOUE4Mz E3RjkzRkYzMzgiIHN0RXZ0OndoZW49IjIwMTctMDktMjFUMTI6NTk6NTArMDg6MDAiIHN0RXZ0OnNvZnR3YXJlQWdlb nQ9IkFkb2JlIFBob3Rvc2hvcCBDUzUgV2luZG93cyIgc3RFdnQ6Y2hhbmdlZD0iLyIvPiA8L3JkZjpTZXE +IDwveG1wTU06SGlzdG9yeT4gPC9yZGY6RGVzY3JpcHRpb24+IDwvcmRmOlJERj4gPC94OnhtcG1ldGE +ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAg ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICA gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC AgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgI CAgPD94cGFja2V0IGVuZD0idyI/Pv/uAA5BZG9iZQBkQAAAAAH/2wCEAAEBAQEBAQEBAQEBAQEBAQEBAQEBAQEBAQEB AQEBAQEBAQEBAQEBAQEBAQECAgICAgICAgICAgMDAwMDAwMDAwMBAQEBAQEBAQEBAQICAQICAwMDAwMDAwMDAwMDAwM DAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDA//AABEIAIIAlgMBEQACEQEDEQH/3QAEABP/xAGiAAAABg IDAQAAAAAAAAAAAAAHCAYFBAkDCgIBAAsBAAAGAwEBAQAAAAAAAAAAAAYFBAMHAggBCQAKCxAAAgEDBAEDAwIDAwMCB gl1AQIDBBEFEgYhBxMiAAgxFEEyIxUJUUIWYSQzF1JxgRhikSVDobHwJjRyChnB0TUn4VM2gvGSokRUc0VGN0djKFVW VxqywtLi8mSDdJOEZaOzw9PjKThm83UqOTpISUpYWVpnaGlqdnd4eXqFhoeIiYqUlZaXmJmapKWmp6ipqrS1tre4ubr ExcbHyMnK1NXW19jZ2uTl5ufo6er09fb3+Pn6EQACAQMCBAQDBQQEBAYGBW0BAgMRBCESBTEGACITQVEHMmEUcQhCgS ORFVKhYhYzCbEkwdFDcvAX4YI0JZJTGGNE8aKyJjUZVDZFZCcKc4OTRnTC0uLyVWV1VjeEhaOzw9Pj8ykalKS0xNTk9 JWltcXV5fUoR1dmOHaGlqa2xtbm9md3h5ent8fX5/dIWGh4iJiouMjY6Pg5SVlpeYmZqbnJ2en5KjpKWmp6ipqqusra 6vr/2gAMAwEAAhEDEQA/AN/j37r3Xvfuvde9+691737r3Xvfuvde9+691737r3Xvfuvde9+691737r3Xvfuvde9+691 737r3Xvfuvde9+691737r3Xvfuvde9+691737r3X/0N/j37r3Xvfuvde9+691737r3XRIAJJAABJJNgAOSSTwAB7917 pHSdjdewu0Uu +9mxSIxV45Nz4RHRgbFWRq4MrA/UH3qo9evdcP9JXXP/Pf7K/9CrBf/V/v1R69e69/pK65/wCe/wBlf +hVgv8A6v8Afqj16917/SV1z/z3+yv/AEKsF/8AV/v1R69e69/pK65/57/ZX/oVYL/6v9+qPXr3Xv8ASV1z/wA9/sr/ ANCrBf8A1f79UevXuvf6Suuf+e/2V/6FWC/+r/fqj16917/SV1z/AM9/sr/0KsF/9X +/VHr17pR4vM4jOU33mFyuNy9IHMZqsXXUuQphIACU89JLNFrAI4vfn3vjw6905e/de697917r3v3Xuve/de697917r //R3+Pfuvde9+691737r3XvfuvdVPfzYu4949fdWbK2VtHL12Bj7EzeTh3NkcZPLR5CbA4WgWrOKpq2B0mp48hVSKJ9 BVmjXSCAT7TXLlVAHn1Vjw6rHzP8uj5CDrnavaW1cbiOysburb1BuSfE7amqJN0YuPJQR1ENLJj8gqTZurCyjWaUvYg /Uc +2fAfSGGetaT0SLI4CrwmTkxGfxVXgshTVH29bR5TH1FJWUZSTxzGSkmjSdvDYkhQSbWHPtmlDQ4610dbpz4S7c73ii Trz5NdNVeZMCz1W1sviN24Hc9F9FdZMPlqOkq54lc6RLErxva6n26sSv8Mgr1unz6Mb/wAM49uf8/X6v/8APRuj/wCp /bn0zfxDrenr3/DOPbn/AD9fq/8A89G6P/qf376Zv4h17T17/hnHtz/n6/V//no3R/8AU/v30zfxDr2nr3/DOPbn/P1 +r/8Az0bo/wDqf376Zv4h17T17/hnHtz/AJ+v1f8A+ejdH/1P799M38Q69p6DToSXs74Y/NfbfTU +7Y8xi8nuHB7V3jj8RPkG2xm8XuajWopqylxdeUNLk8ZO6MkmlGDKwJZD7qmqKUJXrwrWnWy97XdW697917r3v3Xuve /de697917r/9Lf49+691737r3Xvfuvde9+691SH/OW/wCLN0l/2st4f +6um9pLrgvVW49WofG7/mQPTv8A4jva3/uqp/alPgX7OrdZ +2Pj5053fQPQ9mbCwe45TF4oMu9P9luCiCq4hNJnaFqfJxpAz6liMjQlgNSMOPfmRX+IdapXqozun +UnnsTPLuT4974bIvRSmtoNq7uqVxWfpZYrGIYTd1EsFFLXGQko1QlAsaj/ADpPtM1t5oetFfToENqfMP5pfELNU2ze 4MJmtz4WmYxRYHtCmrY6+ejp3CyPtrf0Ec02QgZz/wACZDlIzey24tQSyxkB +Hz/AM/WqkdWldHfzHvjv3B9pi8zm36s3bUeOM4XfUlPQYupqGGkrjN0pI2CnV5SFiSeWmqZSRaG/HtQs6NxND1ao6P zDNFURRzwSxzQzIksU0TrJFLHIodJI5EJV0dSCCCQQfb3W+snv3Xuve/de61yvkD/ANvRsF/4kDrT/wBwIPaJv9yR +XVR8X59bGvtb1br3v3Xuve/de697917r3v3Xuv/09/j37r3Xvfuvde9+691737r3VIf85b/AIs3SX/ay3h/7q6b2ku uC9Vbj1ah8bv+ZA9O/wDiO9rf+6qn9qU+Bfs6t0Nnu3Xuve/de6Tm69n7U31hanbm89uYTdWBrB/lOIz +Mo8tj5WCsqyGlrYZolmjDHQ4AdDypB96IBFCMde6q07x/lO9Zbr +7zPSu4a3rXMvrlXbmVNRuLZ1RJYt4oGqJ/49hjPITdxUVUMS2CQAC3tO9upyhoeq6R0QKLdfzN/l3bpweI3FW1X9y6 2snbH4Gqy/96etd10tDJE+UiwqSvHWYGpZJlLPHFjqs3BsyA +2aywkA8P5dayOtjvr7eVB2JsXZ2/MXE9Pj947awu5KWmldZJqSPMY +nrvs5pFVVeejaYxOQAC6G3Htcp1AN69X6WHvfXutcr5A/8Ab0bBf+JA60/9wIPaJv8Ackfl1UfF +fWxr7W9W697917r3v3Xuve/de697917r//U3+Pfuvde9+691737r3XvfuvdUh/zlv8AizdJf9rLeH/urpvaS64L1Vu PVqHxu/5kD07/AOI72t/7qqf2pT4F+zq3Q2e7de697917r3v3Xuve/de6pY/nIf8AHr9Hf +HFu/8A91GP9pbngn29Vby6se+JH/ZM3R//AIjnbn/uGvt+L+zT7OtjgOjE +79b61yvkD/29GwX/iQOtP8A3Ag9om/3JH5dVHxfn1sa +1vVuve/de697917r3v3Xuve/de6/9Xf49+691737r3Xvfuvde9+691SH/OW/wCLN0l/2st4f +6um9pLrgvVW49WofG7/mQPTv8A4jva3/uqp/alPgX7OrdDZ7t17r3v3Xuve/de697917qlj +ch/wAev0d/4cW7/wD3UY/2lueCfb1VvLqx74kf9kzdH/8AiOduf+4a+34v7NPs62OA6MT7v1vrXK+QP/b0bBf +JA60/wDcCD2ib/ckfl1UfF +fWxr7W9W697917r3v3Xuve/de697917r/1t/j37r3Xvfuvde9+691737r3VIf85b/AIs3SX/ay3h/7q6b2kuuC9Vbj 1ah8bv+ZA9O/wDiO9rf+6qn9qU +Bfs6t0Nnu3Xuve/de697917r3v3XuqWP5yH/AB6/R3/hxbv/APdRj/aW54J9vVW8urHviR/2TN0f/wCI525/7hr7fi /s0+zrY4DoxPu/W+tcr5A/9vRsF/4kDrT/ANwIPaJv9yR +XVR8X59bGvtb1br3v3Xuve/de697917r3v3Xuv/X3+Pfuvde9+691737r3XvfuvdUh/zlv8AizdJf9rLeH/urpvaS6 4L1VuPVqHxu/5kD07/AOI72t/7qqf2pT4F +zq3Q2e7de697917r3v3XuqjfmD8xO4unPlf1b1rsrIYyk2RJj9nZDc2GqcRja2TdD7l3FkMfWw1WSqqWbI42Gmx9Ii wfZywMspZ3LgqqppZGWRVHDqpJB6RX85D/j1+jv8Aw4t3/wDuox/vVzwT7evN5dWPfEj/ALJm6P8A/Ec7c/8AcNfb8X 9mn2dbHAdGJ93631rlfIH/ALejYL/xIHWn/uBB7RN/uSPy6qPi/PrY19rerde9+691737r3Xvfuvde9+691//Q3+Pfu vde9+691737r3XvfuvdUh/zlv8AizdJf9rLeH/urpvaS64L1VuPVqHxu/5kD07/AOI72t/7qqf2pT4F +zq3Q2e7de697917r3v3Xutef +YrBO3zs6vhWGVpq/A9VpQxLG7SVrvvLNU6pSIAWqHaoUoAtzr4+vtFP/bL9g/w9VPHocf5yH/Hr9Hf +HFu/wD91GP93ueCfb15vLqx74kf9kzdH/8AiOduf+4a+34v7NPs62OA6MT7v1vrXK+QP/b0bBf +JA60/wDcCD2ib/ckfl1UfF +fWxr7W9W697917r3v3Xuve/de697917r/0d/j37r3Xvfuvde9+691737r3VIf85b/AIs3SX/ay3h/7q6b2kuuC9Vbj 1ah8bv+ZA9O/wDiO9rf+6qn9qU +Bfs6t0Nnu3Xuve/de697917pMZXZW0M5nMLuXM7ZwWV3DtwyNgc1X4yjqsliGkOpjQVc0TzU5D +pdJGh/Utm596oCQaZ691T/wDzkP8Aj1+jv/Di3f8A+6jH +01zwT7eqt5dWPfEj/smbo//AMRztz/3DX2/F/Zp9nWxwHRifd +t9a5XyB/7ejYL/wASB1p/7gQe0Tf7kj8uqj4vz62Nfa3q3Xvfuvde9+691737r3Xvfuvdf//S3+Pfuvde9+691737r 3XvfuvdUh/zlv8AizdJf9rLeH/urpvaS64L1VuPVqHxu/5kD07/AOI72t/7qqf2pT4F +zq3Q2e7de697917r3v3Xuve/de6pY/nIf8AHr9Hf+HFu/8A91GP9pbngn29Vby6se+JH/ZM3R//AIjnbn/uGvt+L +zT7OtjgOjE+79b61yvkD/29GwX/iQOtP8A3Ag9om/3JH5dVHxfn1sa +1vVuve/de697917r3v3Xuve/de6/9Pf49+691737r3Xvfuvde9+691Ux/Nm6j3fvzq/Yu89qYavztP1/nMtLuekxdP NW11Jg8xjRT/xWOjp0lnlpqGphBnZVPijOs+kE+01ypZQQOHVW9egb +Ln80jZu1tn7Q627f2hX4qj21iKDb9FvjabjK0U1LQRR01PPmMBUPHWUfjhjvLLTT1Rdv0wD3WO4AADDrwb16uE647e 6x7dxS5rrXfG3t4UPjSWYYmuR66iSQlU/iWJnEOVxTuRwtTBExHIFvalWVhVTXq3Qj +7de697917r3v3XuqWf5x/O2OjR/2ce7v/AHU4/wBpbngn29Vby6KL13/M47/602LtPYGA2T1bWYbaOEosFjavJ7f3n UZGppKGPxQzVk1JvKkpZahlHqMcUaH8KPbazuqhQooPt/z9ar0s/wDh3D5Lf88D0/8A +gzvv/7O/dvqZP4B/P8Az9e1Hpi+OG1+5fmJ8w8D3vuTawxGDw+4MVuvd2dx+JyeI2nTU+36QU +NwWCnyc9ZNW5GsmVBoE9TIi6nkKrY +6oGllDkYr14ZNetkr2u6v1737r3Xvfuvde9+691737r3X//1N/j37r3Xvfuvde9+691737r3XTKrqyOqsjKVZWAZWV hZlZTcFSDyPfuvdE27t +B3xy7xasyOX2dFtPdlX5HO8NkGPAZeSpe1qjIwU8RxmadPwKuCYC/tpoUbyoetUHVUnY/8tf5K9H5Y7z6C3fU71ixs xqqCXbdfNtHsOh0vaHx061EeNytUiAFnimg/wBpj/HtOYJENUNf8PWqEdZutP5m3yG6aykezO/tm1G8o6FhBUR52gm2 fv8ApYYbxao6mWmjosumr1PPNDK0ukaZOb+/LO6mjiv +HrVT1bD0p85vjp3itNR4HetNtzc0yDXtTefjwGWEgVQ4pZamX +H10ZlJWMxza5LX0C4HtQkqPwOerVHRvQQQCCCCLgjkEH6EH8g+3et9Us/zkP8Aj1+jv/Di3f8A+6jH +0tzwT7eqt5dWH/E3FYub409Iyy42glkfrrbrPJJR0zu7GjW7MzRlmY/knk+3ogPDT7Otjh0Yb +DYf8A51WN/wDOGl/69e70Hp1vqZBT09MnjpoIaeO9/HBEkSXP1OmNVW597691m9+691737r3Xvfuvde9+691737r3X //V3+Pfuvde9+691737r3Xvfuvde9+691737r3XvfuvdBh2X0v1Z3DipcP2Tsbb27KSRQEkyePheup2VWEclJkUVK6m eItddEgAYA2491ZVbDCvXqV6qf7q/lFYmpaozXQu958RURs1RBtHery11GskamRExm4qdRX0s7zWEfmUpGAPVxf2ne2 HFD1XT0VHHds/PX4O18OH3dSbhrdoU0vgix28Ip937LrIYWEs64PdcDSz0RdQAZRKQo4C +2w00OCMdayOkb8vfmevy7291XhIOvqza24tq1+ZqcosGTizFBl8jmoKGioqTb0cKLkGiHifV541kLFQoPPuskvihRp p14mtOtir47bXymyuieo9rZynkpMzhevtr0mVoplKTUOQ/hVPLWUM6n9M9FPI0T/7Uh9rYwQig8adX4dDL7v17r3v3X uve/de697917r3v3Xuve/de697917r/9bf49+691737r3Xvfuvde9+691737r3Xvfuvde9+691737r3XvfuvdQcljMb maGpxeXx9DlcZWxGGsx2SpIK6hq4SQTFU0lVHLTzxEgHS6kce/de6BHa/xa+POy91ne +2Oo9m4jdHnNVFlIMe0ho6kv5FqMdR1Ms2Pxk8bi6PTxRNGf0ke6CNAahRXrVB0Pnu/W +ve/de697917r3v3Xuve/de697917r3v3Xuve/de6//X3+Pfuvde9+691737r3Xvfuvde9+691737r3Xvfuvde9+691 737r3Xvfuvde9+691737r3Xvfuvde9+691737r3Xvfuvde9+691737r3Xvfuvdf/Z"}}}, "job_status"=>"deal_with", "id"=>"280"}
|
请发表评论