89ccb125d1 
					 
					
						
						
							
							tape: use 36 byte Inquiry (recommended size)  
						
						
						
						
					 
					
						2021-01-27 12:35:28 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						887f1cb90c 
					 
					
						
						
							
							cleanup: move scan changers API implementation  
						
						
						
						
					 
					
						2021-01-27 09:58:16 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						16b4d78400 
					 
					
						
						
							
							tape: rename retry_command to execute_scsi_command, make retry a flag  
						
						
						
						
					 
					
						2021-01-27 09:34:24 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						ec8d9c6b80 
					 
					
						
						
							
							tape: repeat changer scsi command until successful  
						
						
						
						
					 
					
						2021-01-27 08:59:10 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						49c2d1dcad 
					 
					
						
						
							
							sgutils2: use sg_get_asc_ascq_str to produce error messages  
						
						
						
						
					 
					
						2021-01-27 06:56:11 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						d0f51651f9 
					 
					
						
						
							
							sgutils2: add ASC codes from tandeberg docs  
						
						
						
						
					 
					
						2021-01-26 18:54:08 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						481ccf16a5 
					 
					
						
						
							
							sgutils2: further improve error messages  
						
						
						
						
					 
					
						2021-01-26 15:19:43 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						a223458753 
					 
					
						
						
							
							sgutils2: support RequestSense Descriptor format  
						
						
						
						
					 
					
						2021-01-26 13:38:16 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						e1740f3f01 
					 
					
						
						
							
							tape/changer/mtx: add mtx parser test  
						
						... 
						
						
						
						Signed-off-by: Dominik Csapak <d.csapak@proxmox.com > 
						
						
					 
					
						2021-01-26 12:51:26 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						740dc9d1d4 
					 
					
						
						
							
							api2/tape/changer: reorganize api  
						
						... 
						
						
						
						add a changer listing here (copied from api2/config/changer)
and put the status and transfer api calls below that
puts the changer scan into the top level tape api
and removes the (now redundant) info from the config api path
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com > 
						
						
					 
					
						2021-01-26 12:47:34 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						bbf01b644c 
					 
					
						
						
							
							tape: fix typos  
						
						... 
						
						
						
						Signed-off-by: Dominik Csapak <d.csapak@proxmox.com > 
						
						
					 
					
						2021-01-26 12:39:54 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						c81c46c336 
					 
					
						
						
							
							sgutils2: improve error messages  
						
						
						
						
					 
					
						2021-01-26 12:24:58 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						c3747b93c8 
					 
					
						
						
							
							tape: add new command line tool "pmtx"  
						
						... 
						
						
						
						Also improve sgutil2 error reporting 
						
						
					 
					
						2021-01-26 11:57:15 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						6864fd0149 
					 
					
						
						
							
							server/worker_task: improve newline handling in upid_read_status  
						
						... 
						
						
						
						improves upid_read_status with:
* ignore multiple newlines at the end
* remove all code that could panic (array index access)
  the one place where we access with '[pos+1..]' is ok since
  we explicitely test the len of the vector, this is done to
  let rust optimize away the range checks, so it cannot panic
Signed-off-by: Dominik Csapak <d.csapak@proxmox.com > 
						
						
					 
					
						2021-01-26 10:48:15 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						340c0bf9e3 
					 
					
						
						
							
							pxar: don't clone patterns unnecessarily  
						
						... 
						
						
						
						The options struct has no Drop handler and is passed by-move
so we can partially move out of it.
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-26 10:24:18 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						4d104cd4d8 
					 
					
						
						
							
							clippy: more misc fixes  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:55 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						367c0ff7c6 
					 
					
						
						
							
							clippy: allow api functions with many arguments  
						
						... 
						
						
						
						some of those can be reduced/cleaned up when we have updater support in
the api macro.
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:52 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						9c26a3d61a 
					 
					
						
						
							
							verify: factor out common parameters  
						
						... 
						
						
						
						all the verify methods pass along the following:
- task worker
- datastore
- corrupt and verified chunks
might as well pull that out into a common type, with the added bonus of
now having a single point for construction instead of copying the
default capacaties in three different modules..
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:49 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						93e3581ce7 
					 
					
						
						
							
							derive/impl and use Default for some structs  
						
						... 
						
						
						
						and revamp HttpClientOptions with two constructors for the common use
cases
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:45 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						f4e52bb27d 
					 
					
						
						
							
							authid: make Tokenname(Ref) derive Eq  
						
						... 
						
						
						
						it's needed to derive Hash, and we always compare Authids or their
Userid components, never just the Tokenname part anyway..
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:40 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						72064fd0df 
					 
					
						
						
							
							pxar: extract PxarExtractOptions  
						
						... 
						
						
						
						same as PxarCreateOptions, but for extraction/restore rather than
create.
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:36 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						77486a608e 
					 
					
						
						
							
							pxar: factor out PxarCreateOptions  
						
						... 
						
						
						
						containing the CLI parameters that are mostly passed-through from the
client to our pxar archive creation wrapper in pxar::create
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:32 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						e97025ab02 
					 
					
						
						
							
							pxar: typedef on_error as ErrorHandler  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:26 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						e43b9175c0 
					 
					
						
						
							
							client: factor out UploadOptions  
						
						... 
						
						
						
						to reduce function signature complexity.
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:18 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						9cc1415ef5 
					 
					
						
						
							
							systemd/time: extract Time/DateSpec structs  
						
						... 
						
						
						
						could be pulled up into CalendarEvent if desired..
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:54:13 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						bd215dc0e4 
					 
					
						
						
							
							async index reader: typedef ReadFuture  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:53:58 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						12e874cef0 
					 
					
						
						
							
							allow complex Futures in tower_service impl  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:53:55 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						6d233161b0 
					 
					
						
						
							
							client: refactor catalog upload spawning  
						
						... 
						
						
						
						by pulling out Result type into separate struct
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:53:51 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						905a570489 
					 
					
						
						
							
							broadcast_future: refactor broadcast/future binding  
						
						... 
						
						
						
						into its own, private struct.
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:53:48 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						432fe44187 
					 
					
						
						
							
							report: type-alias function call tuple  
						
						... 
						
						
						
						to make clippy happy.
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com > 
						
						
					 
					
						2021-01-26 09:53:43 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						51b938496d 
					 
					
						
						
							
							tools::sgutils2: name fixup  
						
						... 
						
						
						
						it's not a box anymore
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 15:05:52 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						b7f9b25e4d 
					 
					
						
						
							
							tools::sgutils2: use NonNull  
						
						... 
						
						
						
						Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 14:56:10 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						fe61280b6b 
					 
					
						
						
							
							tools::sgutils2: extern 'C' and import ordering  
						
						... 
						
						
						
						Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 14:54:25 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						68c087d578 
					 
					
						
						
							
							tools::sgutils2: don't transmute to a Box  
						
						... 
						
						
						
						Otherwise we run the drop handler for the scsi pt object AND
the box itself, which shouldn't even work as it should be
doing a double-free (unless the library does some kind of
reference counting in which case this should simply crash
later on?)
anyway, let's make a wrapper simply called `SgPt` containing
the pointer from `construct_scsi_pt_obj()`
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 14:48:27 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						d6bf87cab7 
					 
					
						
						
							
							tools::sgutils2: const correctness  
						
						... 
						
						
						
						Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 14:33:45 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						2b96a43879 
					 
					
						
						
							
							tape: cleanup - use ScsiMediaChange trait instead of mtx_status()  
						
						
						
						
					 
					
						2021-01-25 13:25:22 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						697c41c584 
					 
					
						
						
							
							tape: add/use rust scsi changer implementation using libsgutil2  
						
						
						
						
					 
					
						2021-01-25 13:14:07 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						a2379996e6 
					 
					
						
						
							
							sgutils2: add scsi_inquiry command  
						
						
						
						
					 
					
						2021-01-25 13:14:07 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						29077d95db 
					 
					
						
						
							
							http-client: further clippy cleanups  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:54 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						dbd00a57b0 
					 
					
						
						
							
							http-client: fix typoed ticket cache condition  
						
						... 
						
						
						
						which was even copy-pasted once without noticing.
found with clippy.
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:51 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						d08cff51a4 
					 
					
						
						
							
							rework GC traversal error handling  
						
						... 
						
						
						
						the error message don't make sense with an empty default
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:48 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						3e461dec1c 
					 
					
						
						
							
							apt: let api handle optional bool with default  
						
						... 
						
						
						
						one less FIXME :)
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:46 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						4d08e25913 
					 
					
						
						
							
							clippy: rewrite ifs with identical return values  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:43 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						43313c2ee7 
					 
					
						
						
							
							clippy: rewrite comparison chains  
						
						... 
						
						
						
						chunk_stream one can be collapsed, since split == split_to with at set
to buffer.len() anyway.
Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:39 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						81b2a87232 
					 
					
						
						
							
							clippy: fix Mutex with unused value  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:36 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						3d8cd0ced7 
					 
					
						
						
							
							clippy: add is_empty() when len() is implemented  
						
						... 
						
						
						
						Signed-off-by: Fabian Grünbichler <f.gruenbichler@proxmox.com >
Signed-off-by: Wolfgang Bumiller <w.bumiller@proxmox.com > 
						
						
					 
					
						2021-01-25 11:41:32 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						7c78d54231 
					 
					
						
						
							
							sgutils: allow command which does not transfer any data  
						
						
						
						
					 
					
						2021-01-24 15:19:43 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						f9d71e8b17 
					 
					
						
						
							
							sgutils2: allow to set custom timeouts  
						
						
						
						
					 
					
						2021-01-24 14:54:30 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						0107fd323c 
					 
					
						
						
							
							cleanup: avoid compiler warnings  
						
						
						
						
					 
					
						2021-01-23 17:34:26 +01:00 
						 
				 
			
				
					
						
					 
					
						
						
							
						
						979dccc7ec 
					 
					
						
						
							
							tape: avoid error when clearing encryption key  
						
						... 
						
						
						
						Simply ignore clear request when sg_spin_data_encryption_caps fails.
Assume those are tapes without hardware encryption support. 
						
						
					 
					
						2021-01-23 10:20:43 +01:00