examples/api-samples/samples/sample27.rb in groupdocs-1.5.8 vs examples/api-samples/samples/sample27.rb in groupdocs-1.5.9
- old
+ new
@@ -1,13 +1,13 @@
-# GET request
+#GET request
get '/sample27' do
haml :sample27
end
-# POST request
+#POST request
post '/sample27' do
- # Set variables
+ #Set variables
set :client_id, params[:clientId]
set :private_key, params[:privateKey]
set :file_id, params[:fileId]
set :source, params[:source]
set :sex, params[:sex]
@@ -15,112 +15,119 @@
set :sunrise, params[:sunrise]
set :name, params[:name]
set :type, params[:type]
set :base_path, params[:basePath]
- # Set download path
+ #Set download path
downloads_path = "#{File.dirname(__FILE__)}/../public/downloads"
- # Remove all files from download directory or create folder if it not there
+ #Remove all files from download directory or create folder if it not there
if File.directory?(downloads_path)
Dir.foreach(downloads_path) { |f| fn = File.join(downloads_path, f); File.delete(fn) if f != '.' && f != '..' }
else
Dir::mkdir(downloads_path)
end
begin
- # Check required variables
+ #Check required variables
raise 'Please enter all required parameters' if settings.client_id.empty? or settings.private_key.empty?
- if settings.base_path.empty? then settings.base_path = 'https://api.groupdocs.com' end
+ #Prepare base path
+ if settings.base_path.empty?
+ base_path = 'https://api.groupdocs.com'
+ elsif settings.base_path.match('/v2.0')
+ base_path = settings.base_path.split('/v2.0')[0]
+ else
+ base_path = settings.base_path
+ end
- # Configure your access to API server
+ #Configure your access to API server
GroupDocs.configure do |groupdocs|
groupdocs.client_id = settings.client_id
groupdocs.private_key = settings.private_key
- # Optionally specify API server and version
- groupdocs.api_server = settings.base_path # default is 'https://api.groupdocs.com'
+ #Optionally specify API server and version
+ groupdocs.api_server = base_path # default is 'https://api.groupdocs.com'
end
- # Get document by file GUID
+ #Get document by file GUID
case settings.source
when 'guid'
- # Create instance of File
+ #Create instance of File
file = GroupDocs::Storage::File.new({:guid => settings.file_id})
when 'local'
- # Construct path
+ #Construct path
file_path = "#{Dir.tmpdir}/#{params[:file][:filename]}"
- # Open file
+ #Open file
File.open(file_path, 'wb') { |f| f.write(params[:file][:tempfile].read) }
# Make a request to API using client_id and private_key
file = GroupDocs::Storage::File.upload!(file_path, {})
when 'url'
# Upload file from defined url
file = GroupDocs::Storage::File.upload_web!(settings.url)
else
raise 'Wrong GUID source.'
end
- # Raise exception if something went wrong
+ #Raise exception if something went wrong
raise 'No such file' unless file.is_a?(GroupDocs::Storage::File)
- # Make GroupDocs::Storage::Document instance
+ #Make GroupDocs::Storage::Document instance
document = file.to_document
- # Create datasource with fields
+ #Create datasource with fields
datasource = GroupDocs::DataSource.new
- # Get arry of document's fields
+ #Get arry of document's fields
enteredData = {"sex" => settings.sex, "name" => settings.name, "age"=> settings.age, "sunrise" => settings.sunrise}
- # Create Field instance and fill the fields
+ #Create Field instance and fill the fields
datasource.fields = enteredData.map { |key, value| GroupDocs::DataSource::Field.new(name: key, type: :text, values: Array.new() << value) }
- # Adds datasource.
+ #Adds datasource.
datasource.add!()
- # Creates new job to merge datasource into document.
+ #Creates new job to merge datasource into document.
job = document.datasource!(datasource, {:new_type => settings.type})
- sleep 10 # wait for merge and convert
+ sleep 10 #Wait for merge and convert
- # Returns an hash of input and output documents associated to job.
+ #Returns an hash of input and output documents associated to job.
document = job.documents!()
- # Download file
+ #Download file
document[:inputs][0].outputs[0].download!(downloads_path)
- # Set converted document GUID
+ #Set converted document GUID
guid = document[:inputs][0].outputs[0].guid
- # Set converted document Name
+ #Set converted document Name
file_name = document[:inputs][0].outputs[0].name
- #Get url from request
- case settings.base_path
-
+ #Prepare to sign url
+ iframe = "/document-viewer/embed/#{guid}"
+ # Construct result string
+ url = GroupDocs::Api::Request.new(:path => iframe).prepare_and_sign_url
+ #Generate iframe URL
+ case base_path
when 'https://stage-api-groupdocs.dynabic.com'
- url = "http://stage-apps-groupdocs.dynabic.com/document-viewer/embed/#{guid}"
+ iframe = "https://stage-api-groupdocs.dynabic.com#{url}"
when 'https://dev-api-groupdocs.dynabic.com'
- url = "http://dev-apps-groupdocs.dynabic.com/document-viewer/embed/#{guid}"
+ iframe = "https://dev-apps.groupdocs.com#{url}"
else
- url = "https://apps.groupdocs.com/document-viewer/embed/#{guid}"
+ iframe = "https://apps.groupdocs.com#{url}"
end
- # Add the signature to url the request
-
- iframe = GroupDocs::Api::Request.new(:path => url).prepare_and_sign_url
-
- # Set iframe with document GUID or raise an error
+ #Set iframe with document GUID or raise an error
if guid
- iframe = "<iframe width='100%' height='600' frameborder='0' src='#{iframe}'></iframe>"
+ #Make iframe
+ iframe = "<iframe id='downloadframe' src='#{iframe}' width='800' height='1000'></iframe>"
else
raise 'File was not converted'
end
rescue Exception => e
err = e.message
end
- # Set variables for template
+ #Set variables for template
haml :sample27, :locals => {:userId => settings.client_id, :privateKey => settings.private_key, :sex => settings.sex, :age => settings.age, :sunrise => settings.sunrise, :name => settings.name, :type => settings.type, :iframe => iframe, :file_name => file_name, :err => err}
end
\ No newline at end of file