mirror of https://github.com/docusealco/docuseal
				
				
				
			
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							147 lines
						
					
					
						
							6.6 KiB
						
					
					
				
			
		
		
	
	
							147 lines
						
					
					
						
							6.6 KiB
						
					
					
				| <div class="flex-wrap space-y-4 md:flex md:flex-nowrap md:space-y-0 md:space-x-10">
 | |
|   <%= render 'shared/settings_nav' %>
 | |
|   <div class="md:flex-grow">
 | |
|     <div class="max-w-xl">
 | |
|       <h1 class="text-4xl font-bold mb-4">PDF Signature</h1>
 | |
|       <div id="result">
 | |
|         <p class="mb-2">
 | |
|           Upload signed PDF file to validate its signature:
 | |
|         </p>
 | |
|       </div>
 | |
|       <%= form_for '', url: verify_pdf_signature_index_path, method: :post, html: { enctype: 'multipart/form-data' } do |f| %>
 | |
|         <%= f.button type: 'submit', class: 'flex' do %>
 | |
|           <div class="disabled mb-3">
 | |
|             <%= svg_icon('loader', class: 'w-5 h-5 animate-spin inline') %>
 | |
|             Analyzing...
 | |
|           </div>
 | |
|         <% end %>
 | |
|         <file-dropzone data-name="verify_attachments" data-submit-on-upload="true" class="w-full">
 | |
|           <label for="file" class="w-full block h-32 relative bg-base-200 hover:bg-base-200/70 rounded-md border border-base-content border-dashed">
 | |
|             <div class="absolute top-0 right-0 left-0 bottom-0 flex items-center justify-center">
 | |
|               <div class="flex flex-col items-center">
 | |
|                 <span data-target="file-dropzone.icon">
 | |
|                   <%= svg_icon('cloud_upload', class: 'w-10 h-10') %>
 | |
|                 </span>
 | |
|                 <span data-target="file-dropzone.loading" class="hidden">
 | |
|                   <%= svg_icon('loader', class: 'w-10 h-10 animate-spin') %>
 | |
|                 </span>
 | |
|                 <div class="font-medium mb-1">
 | |
|                   Verify Signed PDF
 | |
|                 </div>
 | |
|                 <div class="text-xs">
 | |
|                   <span class="font-medium">Click to upload</span> or drag and drop files
 | |
|                 </div>
 | |
|               </div>
 | |
|               <input id="file" name="files[]" class="hidden" data-action="change:file-dropzone#onSelectFiles" data-target="file-dropzone.input" type="file" accept="application/pdf" multiple>
 | |
|             </div>
 | |
|           </label>
 | |
|         </file-dropzone>
 | |
|       <% end %>
 | |
|     </div>
 | |
|     <div class="flex justify-between items-end mb-4 mt-8">
 | |
|       <h2 class="text-3xl font-bold">Signing Certificates</h2>
 | |
|       <% if can?(:create, @encrypted_config) %>
 | |
|         <%= link_to new_settings_esign_path, class: 'btn btn-primary btn-md', data: { turbo_frame: 'modal' } do %>
 | |
|           <%= svg_icon('plus', class: 'w-6 h-6') %>
 | |
|           <span>Upload Cert</span>
 | |
|         <% end %>
 | |
|       <% end %>
 | |
|     </div>
 | |
|     <%= render 'alert' %>
 | |
|     <div class="overflow-x-auto">
 | |
|       <table class="table w-full table-lg rounded-b-none overflow-hidden">
 | |
|         <thead class="bg-base-200">
 | |
|           <tr class="text-neutral uppercase">
 | |
|             <th>
 | |
|               Name
 | |
|             </th>
 | |
|             <th>
 | |
|               Valid To
 | |
|             </th>
 | |
|             <th>
 | |
|               Status
 | |
|             </th>
 | |
|             <th class="text-right" width="1px">
 | |
|             </th>
 | |
|           </tr>
 | |
|         </thead>
 | |
|         <tbody>
 | |
|           <% @pkcs_list.each do |item| %>
 | |
|             <tr scope="row" class="group">
 | |
|               <td>
 | |
|                 <%= item['name'] %>
 | |
|               </td>
 | |
|               <td>
 | |
|                 <%= l(item['pkcs'].certificate.not_after.to_date, format: :long, locale: current_account.locale) %>
 | |
|               </td>
 | |
|               <td>
 | |
|                 <% if item['status'] == 'default' %>
 | |
|                   <span class="badge badge-lg badge-info badge-outline">
 | |
|                     <%= item['status'] %>
 | |
|                   </span>
 | |
|                 <% elsif can?(:update, @encrypted_config) %>
 | |
|                   <%= button_to settings_esign_path, method: :put, params: { name: item['name'] }, class: 'btn btn-outline btn-neutral btn-xs whitespace-nowrap', title: 'Delete', data: { turbo_confirm: 'Are you sure?' } do %>
 | |
|                     Make Default
 | |
|                   <% end %>
 | |
|                 <% end %>
 | |
|               </td>
 | |
|               <td>
 | |
|                 <% if item['name'] != EsignSettingsController::DEFAULT_CERT_NAME && item['status'] != 'default' &&  can?(:destroy, @encrypted_config) %>
 | |
|                   <%= button_to settings_esign_path, params: { name: item['name'] }, method: :delete, class: 'btn btn-outline btn-error btn-xs', title: 'Delete', data: { turbo_confirm: 'Are you sure?' } do %>
 | |
|                     Remove
 | |
|                   <% end %>
 | |
|                 <% end %>
 | |
|               </td>
 | |
|             </tr>
 | |
|           <% end %>
 | |
|         </tbody>
 | |
|       </table>
 | |
|     </div>
 | |
|     <% encrypted_config = EncryptedConfig.find_or_initialize_by(account: current_account, key: EncryptedConfig::TIMESTAMP_SERVER_URL_KEY) %>
 | |
|     <% if !Docuseal.multitenant? && can?(:manage, encrypted_config) %>
 | |
|       <div class="flex-grow max-w-xl">
 | |
|         <div class="flex justify-between items-end mb-4 mt-8">
 | |
|           <h2 class="text-3xl font-bold">Timestamp Server</h2>
 | |
|         </div>
 | |
|         <%= form_for encrypted_config, url: timestamp_server_index_path, method: :post, html: { autocomplete: 'off', class: 'space-y-4' } do |f| %>
 | |
|           <div class="form-control">
 | |
|             <%= f.label :value, class: 'label' do %>
 | |
|               <span class="flex items-center space-x-1">
 | |
|                 <span>
 | |
|                   Timeserver URL
 | |
|                 </span>
 | |
|                 <span class="tooltip" data-tip="URL of the trusted RFC 3161 timeserver to be used to generate timestamp signatures.">
 | |
|                   <%= svg_icon('info_circle', class: 'w-4 h-4') %>
 | |
|                 </span>
 | |
|               </span>
 | |
|             <% end %>
 | |
|             <%= f.url_field :value, autocomplete: 'off', class: 'base-input', placeholder: 'URL (optional)' %>
 | |
|           </div>
 | |
|           <div class="form-control pt-2">
 | |
|             <%= f.button button_title(title: 'Save', disabled_with: 'Updating'), class: 'base-button' %>
 | |
|           </div>
 | |
|         <% end %>
 | |
|       </div>
 | |
|     <% end %>
 | |
|     <% account_config = AccountConfig.where(account: current_account, key: AccountConfig::ESIGNING_PREFERENCE_KEY).first_or_initialize(value: 'multiple') %>
 | |
|     <% if can?(:manage, account_config) %>
 | |
|       <div class="px-1 mt-8 max-w-xl">
 | |
|         <div class="flex justify-between items-end mb-4 mt-8">
 | |
|           <h2 class="text-3xl font-bold">Preferences</h2>
 | |
|         </div>
 | |
|         <% if can?(:manage, account_config) %>
 | |
|           <%= form_for account_config, url: account_configs_path, method: :post do |f| %>
 | |
|             <%= f.hidden_field :key %>
 | |
|             <div class="flex items-center justify-between py-2.5">
 | |
|               <span>
 | |
|                 Apply multiple PDF digital signatures in the document per each signer
 | |
|               </span>
 | |
|               <%= f.check_box :value, { class: 'toggle', checked: account_config.value == 'multiple', onchange: 'this.form.requestSubmit()' }, 'multiple', 'single' %>
 | |
|             </div>
 | |
|           <% end %>
 | |
|         <% end %>
 | |
|       </div>
 | |
|     <% end %>
 | |
|   </div>
 | |
| </div>
 |