ESP3D  3.0
Firmware for ESP boards connected to 3D Printer
ESP161.cpp
Go to the documentation of this file.
1 /*
2  ESP161.cpp - ESP3D command class
3 
4  Copyright (c) 2014 Luc Lebosse. All rights reserved.
5 
6  This library is free software; you can redistribute it and/or
7  modify it under the terms of the GNU Lesser General Public
8  License as published by the Free Software Foundation; either
9  version 2.1 of the License, or (at your option) any later version.
10 
11  This library is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  Lesser General Public License for more details.
15 
16  You should have received a copy of the GNU Lesser General Public
17  License along with this library; if not, write to the Free Software
18  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
19 */
20 #include "../../include/esp3d_config.h"
21 #if defined (WS_DATA_FEATURE)
22 #include "../commands.h"
23 #include "../esp3doutput.h"
24 #include "../settings_esp3d.h"
25 #include "../../modules/authentication/authentication_service.h"
26 //Set Websocket port
27 //[ESP161]<port>pwd=<admin password>
28 bool Commands::ESP161(const char* cmd_params, level_authenticate_type auth_type, ESP3DOutput * output)
29 {
30  bool response = true;
31  String parameter;
32 #ifdef AUTHENTICATION_FEATURE
33  if (auth_type == LEVEL_GUEST) {
34  output->printERROR("Wrong authentication!", 401);
35  return false;
36  }
37 #else
38  (void)auth_type;
39 #endif //AUTHENTICATION_FEATURE
40  parameter = get_param (cmd_params, "");
41  //get
42  if (parameter.length() == 0) {
44  } else { //set
45 #ifdef AUTHENTICATION_FEATURE
46  if (auth_type != LEVEL_ADMIN) {
47  output->printERROR("Wrong authentication!", 401);
48  return false;
49  }
50 #endif //AUTHENTICATION_FEATURE
51  uint ibuf = parameter.toInt();
53  output->printERROR ("Incorrect port!");
54  return false;
55  }
57  output->printERROR ("Set failed!");
58  response = false;
59  } else {
60  output->printMSG ("ok");
61  }
62  }
63  return response;
64 }
65 
66 #endif //WS_DATA_FEATURE
Commands::get_param
const char * get_param(const char *cmd_params, const char *label)
Definition: commands.cpp:162
Settings_ESP3D::get_max_int32_value
static uint32_t get_max_int32_value(int pos)
Definition: settings_esp3d.cpp:416
Commands::ESP161
bool ESP161(const char *cmd_params, level_authenticate_type auth_level, ESP3DOutput *output)
Definition: ESP161.cpp:28
Settings_ESP3D::write_uint32
static bool write_uint32(int pos, const uint32_t value)
Definition: settings_esp3d.cpp:970
LEVEL_GUEST
@ LEVEL_GUEST
Definition: authentication_service.h:26
level_authenticate_type
level_authenticate_type
Definition: authentication_service.h:25
ESP3DOutput::printMSG
size_t printMSG(const char *s, bool withNL=true)
Definition: esp3doutput.cpp:190
ESP3DOutput::printERROR
size_t printERROR(const char *s, int code_error=200)
Definition: esp3doutput.cpp:247
ESP_WEBSOCKET_PORT
#define ESP_WEBSOCKET_PORT
Definition: settings_esp3d.h:64
Settings_ESP3D::get_min_int32_value
static uint32_t get_min_int32_value(int pos)
Definition: settings_esp3d.cpp:462
Settings_ESP3D::read_uint32
static uint32_t read_uint32(int pos, bool *haserror=NULL)
Definition: settings_esp3d.cpp:919
LEVEL_ADMIN
@ LEVEL_ADMIN
Definition: authentication_service.h:28
ESP3DOutput
Definition: esp3doutput.h:48