mirror of
				https://github.com/SoftFever/OrcaSlicer.git
				synced 2025-10-26 02:01:12 -06:00 
			
		
		
		
	Added networking support for SL1 Digest authorization.
Renamed login/password/authorization_type to printhost_user/printhost_password/printhost_authorization_type. Added initialization of physical printer preset with default values.
This commit is contained in:
		
							parent
							
								
									0a4debc98c
								
							
						
					
					
						commit
						ce06fc6cb7
					
				
					 11 changed files with 98 additions and 41 deletions
				
			
		|  | @ -1080,7 +1080,7 @@ boost::any& Choice::get_value() | |||
| 			m_value = static_cast<SLADisplayOrientation>(ret_enum); | ||||
|         else if (m_opt_id.compare("support_pillar_connection_mode") == 0) | ||||
|             m_value = static_cast<SLAPillarConnectionMode>(ret_enum); | ||||
| 		else if (m_opt_id == "authorization_type") | ||||
| 		else if (m_opt_id == "printhost_authorization_type") | ||||
| 			m_value = static_cast<AuthorizationType>(ret_enum); | ||||
| 	} | ||||
|     else if (m_opt.gui_type == "f_enum_open") { | ||||
|  |  | |||
|  | @ -194,7 +194,7 @@ void change_opt_value(DynamicPrintConfig& config, const t_config_option_key& opt | |||
| 				config.set_key_value(opt_key, new ConfigOptionEnum<SLADisplayOrientation>(boost::any_cast<SLADisplayOrientation>(value))); | ||||
|             else if(opt_key.compare("support_pillar_connection_mode") == 0) | ||||
|                 config.set_key_value(opt_key, new ConfigOptionEnum<SLAPillarConnectionMode>(boost::any_cast<SLAPillarConnectionMode>(value))); | ||||
|             else if(opt_key == "authorization_type") | ||||
|             else if(opt_key == "printhost_authorization_type") | ||||
|                 config.set_key_value(opt_key, new ConfigOptionEnum<AuthorizationType>(boost::any_cast<AuthorizationType>(value))); | ||||
| 			} | ||||
| 			break; | ||||
|  |  | |||
|  | @ -755,7 +755,7 @@ boost::any ConfigOptionsGroup::get_config_value(const DynamicPrintConfig& config | |||
|         else if (opt_key == "support_pillar_connection_mode") { | ||||
|             ret  = static_cast<int>(config.option<ConfigOptionEnum<SLAPillarConnectionMode>>(opt_key)->value); | ||||
|         } | ||||
|         else if (opt_key == "authorization_type") { | ||||
|         else if (opt_key == "printhost_authorization_type") { | ||||
|             ret  = static_cast<int>(config.option<ConfigOptionEnum<AuthorizationType>>(opt_key)->value); | ||||
|         } | ||||
| 	} | ||||
|  |  | |||
|  | @ -155,8 +155,9 @@ void PresetForPrinter::msw_rescale() | |||
| //          PhysicalPrinterDialog
 | ||||
| //------------------------------------------
 | ||||
| 
 | ||||
| PhysicalPrinterDialog::PhysicalPrinterDialog(wxString printer_name) | ||||
|     : DPIDialog(NULL, wxID_ANY, _L("Physical Printer"), wxDefaultPosition, wxSize(45 * wxGetApp().em_unit(), -1), wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER) | ||||
| PhysicalPrinterDialog::PhysicalPrinterDialog(wxString printer_name) :  | ||||
|     DPIDialog(NULL, wxID_ANY, _L("Physical Printer"), wxDefaultPosition, wxSize(45 * wxGetApp().em_unit(), -1), wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER), | ||||
|     m_printer("", wxGetApp().preset_bundle->physical_printers.default_config()) | ||||
| { | ||||
|     SetFont(wxGetApp().normal_font()); | ||||
|     SetBackgroundColour(wxSystemSettings::GetColour(wxSYS_COLOUR_WINDOW)); | ||||
|  | @ -186,7 +187,8 @@ PhysicalPrinterDialog::PhysicalPrinterDialog(wxString printer_name) | |||
|     PhysicalPrinter* printer = printers.find_printer(into_u8(printer_name)); | ||||
|     if (!printer) { | ||||
|         const Preset& preset = wxGetApp().preset_bundle->printers.get_edited_preset(); | ||||
|         printer = new PhysicalPrinter(into_u8(printer_name), preset); | ||||
|         //FIXME Vojtech: WTF??? Memory leak?
 | ||||
|         printer = new PhysicalPrinter(into_u8(printer_name), m_printer.config, preset); | ||||
|         // if printer_name is empty it means that new printer is created, so enable all items in the preset list
 | ||||
|         m_presets.emplace_back(new PresetForPrinter(this, preset.name)); | ||||
|     } | ||||
|  | @ -249,7 +251,7 @@ PhysicalPrinterDialog::~PhysicalPrinterDialog() | |||
| void PhysicalPrinterDialog::build_printhost_settings(ConfigOptionsGroup* m_optgroup) | ||||
| { | ||||
|     m_optgroup->m_on_change = [this](t_config_option_key opt_key, boost::any value) { | ||||
|         if (opt_key == "authorization_type") | ||||
|         if (opt_key == "printhost_authorization_type") | ||||
|             this->update(); | ||||
|     }; | ||||
| 
 | ||||
|  | @ -308,7 +310,7 @@ void PhysicalPrinterDialog::build_printhost_settings(ConfigOptionsGroup* m_optgr | |||
|     host_line.append_widget(print_host_test); | ||||
|     m_optgroup->append_line(host_line); | ||||
| 
 | ||||
|     m_optgroup->append_single_option_line("authorization_type"); | ||||
|     m_optgroup->append_single_option_line("printhost_authorization_type"); | ||||
| 
 | ||||
|     option = m_optgroup->get_option("printhost_apikey"); | ||||
|     option.opt.width = Field::def_width_wider(); | ||||
|  | @ -368,7 +370,7 @@ void PhysicalPrinterDialog::build_printhost_settings(ConfigOptionsGroup* m_optgr | |||
|         m_optgroup->append_line(line); | ||||
|     } | ||||
| 
 | ||||
|     for (const std::string& opt_key : std::vector<std::string>{ "login", "password" }) {         | ||||
|     for (const std::string& opt_key : std::vector<std::string>{ "printhost_user", "printhost_password" }) {         | ||||
|         option = m_optgroup->get_option(opt_key); | ||||
|         option.opt.width = Field::def_width_wider(); | ||||
|         m_optgroup->append_single_option_line(option); | ||||
|  | @ -385,20 +387,20 @@ void PhysicalPrinterDialog::update() | |||
|     // Only offer the host type selection for FFF, for SLA it's always the SL1 printer (at the moment)
 | ||||
|     if (tech == ptFFF) { | ||||
|         m_optgroup->show_field("host_type"); | ||||
|         m_optgroup->hide_field("authorization_type"); | ||||
|         for (const std::string& opt_key : std::vector<std::string>{ "login", "password" }) | ||||
|         m_optgroup->hide_field("printhost_authorization_type"); | ||||
|         for (const std::string& opt_key : std::vector<std::string>{ "printhost_user", "printhost_password" }) | ||||
|             m_optgroup->hide_field(opt_key); | ||||
|     } | ||||
|     else { | ||||
|         m_optgroup->set_value("host_type", int(PrintHostType::htOctoPrint), false); | ||||
|         m_optgroup->hide_field("host_type"); | ||||
| 
 | ||||
|         m_optgroup->show_field("authorization_type"); | ||||
|         m_optgroup->show_field("printhost_authorization_type"); | ||||
| 
 | ||||
|         AuthorizationType auth_type = m_config->option<ConfigOptionEnum<AuthorizationType>>("authorization_type")->value; | ||||
|         AuthorizationType auth_type = m_config->option<ConfigOptionEnum<AuthorizationType>>("printhost_authorization_type")->value; | ||||
|         m_optgroup->show_field("printhost_apikey", auth_type == AuthorizationType::atKeyPassword); | ||||
| 
 | ||||
|         for (const std::string& opt_key : std::vector<std::string>{ "login", "password" }) | ||||
|         for (const std::string& opt_key : std::vector<std::string>{ "printhost_user", "printhost_password" }) | ||||
|             m_optgroup->show_field(opt_key, auth_type == AuthorizationType::atUserPassword); | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -415,6 +415,16 @@ Http& Http::remove_header(std::string name) | |||
| 	return *this; | ||||
| } | ||||
| 
 | ||||
| // Authorization by HTTP digest, based on RFC2617.
 | ||||
| Http& Http::auth_digest(const std::string &user, const std::string &password) | ||||
| { | ||||
| 	curl_easy_setopt(p->curl, CURLOPT_USERNAME, user.c_str()); | ||||
| 	curl_easy_setopt(p->curl, CURLOPT_PASSWORD, password.c_str()); | ||||
| 	curl_easy_setopt(p->curl, CURLOPT_HTTPAUTH, CURLAUTH_DIGEST); | ||||
| 
 | ||||
| 	return *this; | ||||
| } | ||||
| 
 | ||||
| Http& Http::ca_file(const std::string &name) | ||||
| { | ||||
| 	if (p && priv::ca_file_supported(p->curl)) { | ||||
|  |  | |||
|  | @ -64,6 +64,8 @@ public: | |||
| 	Http& header(std::string name, const std::string &value); | ||||
| 	// Removes a header field.
 | ||||
| 	Http& remove_header(std::string name); | ||||
| 	// Authorization by HTTP digest, based on RFC2617.
 | ||||
| 	Http& auth_digest(const std::string &user, const std::string &password); | ||||
| 	// Sets a CA certificate file for usage with HTTPS. This is only supported on some backends,
 | ||||
| 	// specifically, this is supported with OpenSSL and NOT supported with Windows and OS X native certificate store.
 | ||||
| 	// See also ca_file_supported().
 | ||||
|  |  | |||
|  | @ -170,6 +170,13 @@ std::string OctoPrint::make_url(const std::string &path) const | |||
|     } | ||||
| } | ||||
| 
 | ||||
| SL1Host::SL1Host(DynamicPrintConfig *config) :  | ||||
|     OctoPrint(config), | ||||
|     authorization_type(dynamic_cast<const ConfigOptionEnum<AuthorizationType>*>(config->option("printhost_authorization_type"))->value), | ||||
|     username(config->opt_string("printhost_user")), | ||||
|     password(config->opt_string("printhost_password")) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| // SL1Host
 | ||||
| const char* SL1Host::get_name() const { return "SL1Host"; } | ||||
|  | @ -191,4 +198,20 @@ bool SL1Host::validate_version_text(const boost::optional<std::string> &version_ | |||
|     return version_text ? boost::starts_with(*version_text, "Prusa SLA") : false; | ||||
| } | ||||
| 
 | ||||
| void SL1Host::set_auth(Http &http) const | ||||
| { | ||||
|     switch (authorization_type) { | ||||
|     case atKeyPassword: | ||||
|         http.header("X-Api-Key", get_apikey()); | ||||
|         break; | ||||
|     case atUserPassword: | ||||
|         http.auth_digest(username, password); | ||||
|         break; | ||||
|     } | ||||
| 
 | ||||
|     if (! get_cafile().empty()) { | ||||
|         http.ca_file(get_cafile()); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -29,6 +29,8 @@ public: | |||
|     bool can_test() const override { return true; } | ||||
|     bool can_start_print() const override { return true; } | ||||
|     std::string get_host() const override { return host; } | ||||
|     const std::string& get_apikey() const { return apikey; } | ||||
|     const std::string& get_cafile() const { return cafile; } | ||||
| 
 | ||||
| protected: | ||||
|     virtual bool validate_version_text(const boost::optional<std::string> &version_text) const; | ||||
|  | @ -38,14 +40,14 @@ private: | |||
|     std::string apikey; | ||||
|     std::string cafile; | ||||
| 
 | ||||
|     void set_auth(Http &http) const; | ||||
|     virtual void set_auth(Http &http) const; | ||||
|     std::string make_url(const std::string &path) const; | ||||
| }; | ||||
| 
 | ||||
| class SL1Host: public OctoPrint | ||||
| { | ||||
| public: | ||||
|     SL1Host(DynamicPrintConfig *config) : OctoPrint(config) {} | ||||
|     SL1Host(DynamicPrintConfig *config); | ||||
|     ~SL1Host() override = default; | ||||
| 
 | ||||
|     const char* get_name() const override; | ||||
|  | @ -56,6 +58,15 @@ public: | |||
| 
 | ||||
| protected: | ||||
|     bool validate_version_text(const boost::optional<std::string> &version_text) const override; | ||||
| 
 | ||||
| private: | ||||
|     void set_auth(Http &http) const override; | ||||
| 
 | ||||
|     // Host authorization type.
 | ||||
|     AuthorizationType authorization_type; | ||||
|     // username and password for HTTP Digest Authentization (RFC RFC2617)
 | ||||
|     std::string username; | ||||
|     std::string password; | ||||
| }; | ||||
| 
 | ||||
| } | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Vojtech Bubnik
						Vojtech Bubnik