home *** CD-ROM | disk | FTP | other *** search
/ PC Welt 2006 November (DVD) / PCWELT_11_2006.ISO / casper / filesystem.squashfs / usr / lib / hplip / base / pml.py < prev    next >
Encoding:
Python Source  |  2006-08-30  |  19.7 KB  |  595 lines

  1. # -*- coding: utf-8 -*-
  2. #
  3. # (c) Copyright 2003-2006 Hewlett-Packard Development Company, L.P.
  4. #
  5. # This program is free software; you can redistribute it and/or modify
  6. # it under the terms of the GNU General Public License as published by
  7. # the Free Software Foundation; either version 2 of the License, or
  8. # (at your option) any later version.
  9. #
  10. # This program is distributed in the hope that it will be useful,
  11. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  13. # GNU General Public License for more details.
  14. #
  15. # You should have received a copy of the GNU General Public License
  16. # along with this program; if not, write to the Free Software
  17. # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
  18. #
  19. # Author: Don Welch
  20. #
  21.  
  22. # Std Lib
  23. import sys, struct
  24.  
  25. # Local
  26. from g import *
  27. from base.utils import unprintable
  28.  
  29.  
  30. # Request codes
  31. GET_REQUEST = 0x00
  32. GET_NEXT_REQUEST = 0x01
  33. GET_BLOCK_REQUEST = 0x02
  34. GET_NEXT_BLOCK_REQUEST = 0x03
  35. SET_REQUEST = 0x04
  36. ENABLE_TRAP_REQUEST = 0x05
  37. DISABLE_TRAP_REQUEST = 0x06
  38. TRAP_REQUEST = 0x07
  39.  
  40. # Reply codes
  41. GET_REPLY = 0x80
  42. GET_NEXT_REPLY = 0x81
  43. BLOCK_REPLY = 0x82
  44. NEXT_BLOCK_REPLY = 0x83
  45. SET_REPLY = 0x84
  46. ENABLE_TRAP_REPLY = 0x85
  47. DISABLE_TRAP_REPLY = 0x85
  48.  
  49. # PML Reply error codes
  50. ERROR_OK = 0x00
  51. ERROR_OK_END_OF_SUPPORTED_OBJECTS = 0x01
  52. ERROR_OK_NEAREST_LEGAL_VALUE_SUBSITUTED = 0x02
  53. ERROR_MAX_OK = 0x7f
  54. ERROR_UNKNOWN_REQUEST = 0x80
  55. ERROR_BUFFER_OVERFLOW = 0x81
  56. ERROR_COMMAND_EXECUTION = 0x82
  57. ERROR_UNKNOWN_OID = 0x83
  58. ERROR_OBJ_DOES_NOT_SUPPORT_SPECIFIED_ACTION = 0x84
  59. ERROR_INVALID_OR_UNSUPPORTED_VALUE = 0x85
  60. ERROR_PAST_END_OF_SUPPORTED_OBJS = 0x86
  61. ERROR_ACTION_CANNOT_BE_PERFORMED_NOW = 0x87
  62. ERROR_SYNTAX = 0x88
  63.  
  64. # Data types
  65. TYPE_MASK = 0xfc
  66. TYPE_OBJECT_IDENTIFIER = 0x00
  67. TYPE_ENUMERATION = 0x04
  68. TYPE_SIGNED_INTEGER = 0x08
  69. TYPE_REAL = 0x0C
  70. TYPE_STRING = 0x10
  71. TYPE_BINARY = 0x14
  72. TYPE_ERROR_CODE = 0x18
  73. TYPE_NULL_VALUE = 0x1c
  74. TYPE_COLLECTION = 0x20
  75. TYPE_UNKNOWN = 0xff
  76.  
  77. # Misc. constants
  78. MAX_VALUE_LEN = 1023
  79. MAX_OID_LEN = 32
  80. MAX_DATALEN = 4096
  81.  
  82. # desired_int_sizes
  83. INT_SIZE_BYTE = struct.calcsize('b')
  84. INT_SIZE_WORD = struct.calcsize('h')
  85. INT_SIZE_INT = struct.calcsize('i')
  86.  
  87.  
  88. def buildPMLGetPacket(oid): # String dotted notation
  89.     oid = ''.join([chr(int(b.strip())) for b in oid.split('.')])
  90.     return struct.pack('>BBB%ss' % len(oid),
  91.                         GET_REQUEST,
  92.                         TYPE_OBJECT_IDENTIFIER,
  93.                         len(oid), oid)
  94.  
  95. def buildPMLGetPacketEx(oid): # OID identifier dict
  96.     return buildPMLGetPacket(oid['oid'])
  97.  
  98. def buildEmbeddedPMLSetPacket(oid, value, data_type):
  99.     return ''.join(['PML\x20', buildPMLSetPacket(oid, value, data_type)])
  100.  
  101. def buildPMLSetPacket(oid, value, data_type): # String dotted notation
  102.     oid = ''.join([chr(int(b.strip())) for b in oid.split('.')])
  103.  
  104.     if data_type in (TYPE_ENUMERATION, TYPE_SIGNED_INTEGER, TYPE_COLLECTION):
  105.         data = struct.pack(">i", int(value))
  106.  
  107.         if value > 0:
  108.             while len(data) > 0 and data[0] == '\x00':
  109.                 data = data[1:]
  110.         else:
  111.             while len(data) > 1 and data[0] == '\xff' and data[1] == '\xff':
  112.                 data = data[1:]
  113.  
  114.         data = struct.pack(">BB%ds" % len(data), data_type, len(data), data)
  115.  
  116.     elif data_type == TYPE_REAL:
  117.         data = struct.pack(">BBf", data_type, struct.calcsize("f"), float(value))
  118.  
  119.     elif data_type == TYPE_STRING:
  120.         data = struct.pack(">BBBB%ss" % len(value), data_type, len(value) + 2, 0x01, 0x15, value)
  121.  
  122.     elif data_type == TYPE_BINARY:
  123.         data = struct.pack(">BB%ss" % len(value), data_type, len(value), ''.join([chr(x) for x in value]))
  124.  
  125.     p = struct.pack('>BBB%ss%ss' % (len(oid), len(data)),
  126.                     SET_REQUEST,
  127.                     TYPE_OBJECT_IDENTIFIER,
  128.                     len(oid), oid,
  129.                     data)
  130.  
  131.     return p
  132.  
  133. def ConvertToPMLDataFormat(value, data_type): 
  134.     if data_type in (TYPE_ENUMERATION, TYPE_SIGNED_INTEGER, TYPE_COLLECTION):
  135.         data = struct.pack(">i", int(value))
  136.  
  137.         if value > 0:
  138.             while len(data) > 0 and data[0] == '\x00':
  139.                 data = data[1:]
  140.         else:
  141.             while len(data) > 1 and data[0] == '\xff' and data[1] == '\xff':
  142.                 data = data[1:]
  143.  
  144.         data = struct.pack(">%ds" % len(data), data)
  145.  
  146.     elif data_type == TYPE_REAL:
  147.         data = struct.pack(">f", float(value))
  148.  
  149.     elif data_type == TYPE_STRING:
  150.         #data = struct.pack(">BB%ss" % len(value), 0x01, 0x15, value)
  151.         data = struct.pack(">BB%ss" % len(value), 0x00, 0x0e, value) # changed for K80, seems to work on others...
  152.  
  153.     elif data_type == TYPE_BINARY:
  154.         if type(value) == type(''):
  155.             data = value
  156.         elif type(value) == type([]):
  157.             data = struct.pack(">%ds" % len(value), ''.join([chr(x) for x in value]))
  158.         else:
  159.             log.error("Value type error.")
  160.  
  161.     return data
  162.  
  163. def ConvertFromPMLDataFormat(data, data_type, desired_int_size=INT_SIZE_INT):
  164.     if data_type in (TYPE_ENUMERATION, TYPE_SIGNED_INTEGER, TYPE_COLLECTION):
  165.  
  166.         if len(data):
  167.  
  168.             if data[0] == '\xff':
  169.                 while len(data) < 4:
  170.                     data = '\xff' + data
  171.  
  172.             else:
  173.                 while len(data) < 4:
  174.                     data = '\x00' + data
  175.  
  176.             if desired_int_size == INT_SIZE_INT:
  177.                 return struct.unpack(">i", data)[0]
  178.  
  179.             elif desired_int_size == INT_SIZE_WORD:
  180.                 return struct.unpack(">h", data[-INT_SIZE_WORD])[0]
  181.  
  182.             elif desired_int_size == INT_SIZE_BYTE:
  183.                 return struct.unpack(">b", data[-INT_SIZE_BYTE])[0]
  184.  
  185.             else:
  186.                 raise Error(ERROR_INTERNAL)
  187.  
  188.         else:
  189.             return 0
  190.  
  191.     elif data_type == TYPE_REAL:
  192.         if len(data) == struct.calcsize("f"):
  193.             return struct.unpack(">f", data)[0]
  194.         else:
  195.             return 0.0
  196.  
  197.     elif data_type == TYPE_STRING:
  198.         return ''.join([c for c in data if c not in unprintable])
  199.  
  200.     elif data_type == TYPE_BINARY:
  201.         return data
  202.  
  203.     return None
  204.  
  205.  
  206. def parsePMLPacket(p, expected_data_type=TYPE_UNKNOWN):
  207.     pos, state = 0, 1
  208.  
  209.     data_type = TYPE_UNKNOWN
  210.     error_state = False
  211.     while state:
  212.  
  213.         if state == 1: # reply and error code
  214.             reply, error_code = struct.unpack(">BB", p[pos : pos + 2])
  215.             state, pos = 2, pos + 2
  216.  
  217.             if error_code > ERROR_MAX_OK:
  218.                 error_state = True
  219.  
  220.         elif state == 2: # data type and length
  221.             data_type, length = struct.unpack(">BB", p[pos : pos + 2])
  222.             state, pos = 3, pos + 2
  223.  
  224.             if error_state:
  225.  
  226.                 if expected_data_type in (TYPE_COLLECTION, TYPE_ENUMERATION,
  227.                                     TYPE_SIGNED_INTEGER, TYPE_BINARY):
  228.                     data = 0
  229.  
  230.                 elif expected_data_type == TYPE_REAL:
  231.                     data = 0.0
  232.  
  233.                 else:
  234.                     data = ''
  235.  
  236.                 break
  237.  
  238.         elif state == 3: # data
  239.             data = p[pos : pos + length]
  240.             state, pos = 0, pos + length
  241.  
  242.             if data_type == TYPE_OBJECT_IDENTIFIER:
  243.                 state = 2
  244.                 continue
  245.  
  246.             elif data_type == TYPE_STRING:
  247.                 if length > 0:
  248.                     symbol_set, data = struct.unpack(">H%ss" % (length - 2), data)
  249.                 else:
  250.                     data = ''
  251.  
  252.             elif data_type == TYPE_BINARY:
  253.                 data = [ord(b) for b in data]
  254.  
  255.             elif data_type == TYPE_ENUMERATION:
  256.                 if length > 0:
  257.                     data = struct.unpack(">i", "%s%s" % ('\x00' * (4 - length), data))[0]
  258.                 else:
  259.                     data = 0
  260.  
  261.             elif data_type == TYPE_REAL:
  262.                 if length > 0:
  263.                     data = struct.unpack(">f", data)[0]
  264.                 else:
  265.                     data = 0.0
  266.  
  267.             elif data_type ==  TYPE_SIGNED_INTEGER:
  268.                 if length > 0:
  269.                     pad = '\x00'
  270.                     if ord(data[0]) & 0x80: pad = '\xff' # negative number
  271.                     data = struct.unpack(">i", "%s%s" % (pad * (4 - length), data))[0]
  272.                 else:
  273.                     data = 0
  274.  
  275.             elif data_type == TYPE_COLLECTION:
  276.                 if length > 0:
  277.                     data = struct.unpack(">i", "%s%s" % ('\x00' * (4 - length), data))[0]
  278.                 else:
  279.                     data = 0
  280.  
  281.             elif data_type == TYPE_ERROR_CODE:
  282.                 data = struct.unpack(">B", data)[0]
  283.  
  284.             elif data_type == TYPE_NULL_VALUE:
  285.                 data = None
  286.  
  287.             break
  288.  
  289.     return data, data_type, error_code
  290.  
  291.  
  292. def HPToSNMP(oid): # 1.
  293.     return '.'.join(['1.3.6.1.4.1.11.2.3.9.4.2', oid, '0'])
  294.  
  295. def StdToSNMP(oid): # 2.
  296.     return '.'.join(['1.3.6.1.2.1.43', oid[2:]])
  297.  
  298. def HRToSNMP(oid): # 3.
  299.     return '.'.join(['1.3.6.1.2.1.25', oid[2:]])
  300.  
  301. def PMLToSNMP(oid):
  302.     assert len(oid) > 2
  303.  
  304.     if oid[0] == '0': # 0. means its already in SNMP format (will fail for PML)
  305.         return oid[2:]
  306.  
  307.     elif oid[0] == '1': # HP MIB
  308.         return HPToSNMP(oid)
  309.  
  310.     elif oid[0] == '2': # Std MIB
  311.         return StdToSNMP(oid)
  312.  
  313.     elif oid[0] == '3': # Host Resources MIB
  314.         return HRToSNMP(oid)
  315.  
  316.     assert False
  317.  
  318.  
  319. #
  320. # OIDs
  321. #
  322. OID_DEVICE_SUPPORTED_FUNCTIONS = ('1.1.2.67', TYPE_COLLECTION)
  323. DEVICE_SUPPORTED_FUNCTIONS_SCAN =                 0x00002
  324. DEVICE_SUPPORTED_FUNCTIONS_SCAN_SIMPLEX =         0x00004
  325. DEVICE_SUPPORTED_FUNCTIONS_SCAN_DUPLEX =          0x00008
  326. DEVICE_SUPPORTED_FUNCTIONS_COPY =                 0x00010
  327. DEVICE_SUPPORTED_FUNCTIONS_COPY_SIMPLEX_SIMPLEX = 0x00020
  328. DEVICE_SUPPORTED_FUNCTIONS_COPY_SIMPLEX_DUPLEX =  0x00040
  329. DEVICE_SUPPORTED_FUNCTIONS_COPY_DUPLEX_SIMPLEX =  0x00080
  330. DEVICE_SUPPORTED_FUNCTIONS_COPY_DUPLEX_DUPLEX =   0x00100
  331. DEVICE_SUPPORTED_FUNCTIONS_COPY_COLLATION =       0x00200
  332. DEVICE_SUPPORTED_FUNCTIONS_PRINT =                0x00400
  333. DEVICE_SUPPORTED_FUNCTIONS_AUTO_FEED_SIMPLEX =    0x00800
  334. DEVICE_SUPPORTED_FUNCTIONS_AUTO_FEED_DUPLEX =     0x01000
  335. DEVICE_SUPPORTED_FUNCTIONS_FAX_SEND =             0x02000
  336. DEVICE_SUPPORTED_FUNCTIONS_FAX_RECV =             0x04000
  337. DEVICE_SUPPORTED_FUNCTIONS_MASS_STORAGE =         0x08000
  338. DEVICE_SUPPORTED_FUNCTIONS_STREAMING_SAVE =       0x10000
  339. DEVICE_SUPPORTED_FUNCTIONS_FAX_CONFIG =           0x20000
  340. DEVICE_SUPPORTED_FUNCTIONS_FAX_CFG_SPEEDDIAL =    0x40000
  341. DEVICE_SUPPORTED_FUNCTIONS_FAX_CFG_GROUPDIAL =    0x80000
  342.  
  343. OID_CLEAN = ('1.4.1.5.1.1', TYPE_ENUMERATION)
  344. CLEAN_CLEAN = 100
  345. CLEAN_PRIME = 200
  346. CLEAN_WIPE_AND_SPIT = 300
  347.  
  348. OID_SERIAL_NUMBER = ('1.1.3.3', TYPE_STRING)
  349. OID_R_SETTING = ('1.1.1.35', TYPE_SIGNED_INTEGER)
  350.  
  351. OID_PRINT_INTERNAL_PAGE = ('1.1.5.2', TYPE_ENUMERATION)
  352. PRINT_INTERNAL_PAGE_SUPPLIES_PAGE = 101
  353. PRINT_INTERNAL_PAGE_COLOR_PALETTE_CMYK_PAGE = 259
  354. PRINT_INTERNAL_PAGE_COLOR_CAL = 1102
  355. PRINT_INTERNAL_PAGE_COLOR_CAL_VERIFICATION = 1104
  356. PRINT_INTERNAL_PAGE_ALIGNMENT_PAGE = 1100 # LBOW
  357. PRINT_INTERNAL_PAGE_ALIGNMENT_PAGE_VERIFICATION = 1150 # LBOW
  358.  
  359. # From xojpanel
  360. OID_SPM_LINE1 = ('2.16.5.1.2.1.1', TYPE_STRING)
  361. OID_SPM_LINE2 = ('2.16.5.1.2.1.2', TYPE_STRING)
  362.  
  363. OID_HP_LINE1 = ('1.1.2.20.2.1.1', TYPE_STRING)
  364. OID_HP_LINE2 = ('1.1.2.20.2.2.1', TYPE_STRING)
  365.  
  366.  
  367. # LaserJet Status (status type 3)
  368. OID_ON_OFF_LINE = ('1.1.2.5', TYPE_SIGNED_INTEGER)
  369. ON_OFF_LINE_ONLINE = 1
  370. ON_OFF_LINE_OFFLINE = 2
  371. ON_OFF_LINE_OFFLINE_AT_END_OF_JOB = 3
  372.  
  373. OID_SLEEP_MODE = ('1.1.1.2', TYPE_SIGNED_INTEGER)
  374. SLEEP_MODE_FALSE = 1
  375. SLEEP_MODE_TRUE = 2
  376.  
  377. OID_PRINTER_STATUS = ('3.3.5.1.1.1', TYPE_SIGNED_INTEGER)
  378. PRINTER_STATUS_OTHER = 1
  379. PRINTER_STATUS_UNKNOWN = 2
  380. PRINTER_STATUS_IDLE = 3
  381. PRINTER_STATUS_PRINTING = 4
  382. PRINTER_STATUS_WARMUP = 5
  383.  
  384. OID_COVER_STATUS = ('2.6.1.1.3.1.1', TYPE_SIGNED_INTEGER)
  385. COVER_STATUS_OPEN = 3
  386. COVER_STATUS_CLOSED = 4
  387.  
  388. OID_DETECTED_ERROR_STATE = ('3.3.5.1.2.1', TYPE_BINARY)
  389. DETECTED_ERROR_STATE_LOW_PAPER_MASK = 0x80
  390. DETECTED_ERROR_STATE_NO_PAPER_MASK = 0x40
  391. DETECTED_ERROR_STATE_LOW_CART_MASK = 0x20
  392. DETECTED_ERROR_STATE_OUT_CART_MASK = 0x10
  393. DETECTED_ERROR_STATE_DOOR_OPEN_MASK = 0x08
  394. DETECTED_ERROR_STATE_JAMMED_MASK = 0x04
  395. DETECTED_ERROR_STATE_OFFLINE_MASK = 0x02
  396. DETECTED_ERROR_STATE_SERVICE_REQUEST_MASK = 0x01
  397. DETECTED_ERROR_STATE_NO_ERROR = 0x00
  398.  
  399. OID_MARKER_SUPPLIES_TYPE_x = '2.11.1.1.5.1.%d'
  400. OID_MARKER_SUPPLIES_TYPE_x_TYPE = TYPE_ENUMERATION
  401. OID_MARKER_SUPPLIES_TYPE_OTHER = 1
  402. OID_MARKER_SUPPLIES_TYPE_UNKNOWN = 2
  403. OID_MARKER_SUPPLIES_TYPE_TONER = 3
  404. OID_MARKER_SUPPLIES_TYPE_WASTE_TONER = 4
  405. OID_MARKER_SUPPLIES_TYPE_INK = 5
  406. OID_MARKER_SUPPLIES_TYPE_INK_CART = 6
  407. OID_MARKER_SUPPLIES_TYPE_INK_RIBBON = 7
  408. OID_MARKER_SUPPLIES_TYPE_WASTE_INK = 8
  409. OID_MARKER_SUPPLIES_TYPE_OPC = 9
  410. OID_MARKER_SUPPLIES_TYPE_DEVELOPER = 10
  411. OID_MARKER_SUPPLIES_TYPE_FUSER_OIL = 11
  412. OID_MARKER_SUPPLIES_TYPE_SOLID_WAX = 12
  413. OID_MARKER_SUPPLIES_TYPE_RIBBON_WAX = 13
  414. OID_MARKER_SUPPLIES_TYPE_WASTE_WAX = 14
  415. OID_MARKER_SUPPLIES_TYPE_FUSER = 15
  416. OID_MARKER_SUPPLIES_TYPE_CORONA_WIRE = 16
  417. OID_MARKER_SUPPLIES_TYPE_FUSER_OIL_WICK = 17
  418. OID_MARKER_SUPPLIES_TYPE_CLEANER_UNIT = 18
  419. OID_MARKER_SUPPLIES_TYPE_FUSER_CLEANING_PAD = 19
  420. OID_MARKER_SUPPLIES_TYPE_TRANSFER_UNIT = 20
  421. OID_MARKER_SUPPLIES_TYPE_TONER_CART = 21
  422. OID_MARKER_SUPPLIES_TYPE_FUSER_OILER = 22
  423. OID_MARKER_SUPPLIES_TYPE_ADF_MAINT_KIT = 23
  424.  
  425. OID_MARKER_SUPPLIES_COLORANT_INDEX_x = '2.11.1.1.3.1.%d'
  426. OID_MARKER_SUPPLIES_COLORANT_INDEX_x_TYPE = TYPE_SIGNED_INTEGER
  427.  
  428. OID_MARKER_SUPPLIES_MAX_x = '2.11.1.1.8.1.%d'
  429. OID_MARKER_SUPPLIES_MAX_x_TYPE = TYPE_SIGNED_INTEGER
  430.  
  431. OID_MARKER_SUPPLIES_LEVEL_x = '2.11.1.1.9.1.%d'
  432. OID_MARKER_SUPPLIES_LEVEL_x_TYPE = TYPE_SIGNED_INTEGER
  433.  
  434. OID_MARKER_COLORANT_VALUE_x = '2.12.1.1.4.1.%d'
  435. OID_MARKER_COLORANT_VALUE_x_TYPE = TYPE_STRING
  436.  
  437. OID_MARKER_STATUS_x = '2.10.2.1.15.1.%d'
  438. OID_MARKER_STATUS_x_TYPE = TYPE_SIGNED_INTEGER
  439. OID_MARKER_STATUS_OK = 0
  440. OID_MARKER_STATUS_LOW_TONER_CONT = 8
  441. OID_MARKER_STATUS_LOW_TONER_STOP = 49
  442. OID_MARKER_STATUS_MISINSTALLED = 51
  443.  
  444. OID_MARKER_SUPPLIES_DESCRIPTION_x = '2.11.1.1.6.1.%d'
  445. OID_MARKER_SUPPLIES_DESCRIPTION_x_TYPE = TYPE_BINARY
  446.  
  447. OID_DEVICE_STATUS = ('3.3.2.1.5.1', TYPE_ENUMERATION)
  448. DEVICE_STATUS_UNKNOWN = 1
  449. DEVICE_STATUS_RUNNING = 2
  450. DEVICE_STATUS_WARNING = 3
  451. DEVICE_STATUS_TESTING = 4
  452. DEVICE_STATUS_DOWN = 5
  453. #end
  454.  
  455. # alignment, cleaning, etc.
  456. OID_AUTO_ALIGNMENT = ('1.1.5.2', TYPE_ENUMERATION)
  457. AUTO_ALIGNMENT = 1100
  458. OID_ZCA = ('1.4.1.8.5.4.1', TYPE_SIGNED_INTEGER)
  459. OID_AGENT2_VERTICAL_ALIGNMENT = ('1.4.1.5.3.2.5', TYPE_SIGNED_INTEGER)
  460. OID_AGENT2_HORIZONTAL_ALIGNMENT = ('1.4.1.5.3.2.6', TYPE_SIGNED_INTEGER)
  461. OID_AGENT1_BIDIR_ADJUSTMENT = ('1.4.1.5.3.1.7', TYPE_SIGNED_INTEGER)
  462. OID_AGENT2_BIDIR_ADJUSTMENT = ('1.4.1.5.3.2.7', TYPE_SIGNED_INTEGER)
  463. OID_MARKING_AGENTS_INITIALIZED = ('1.4.1.5.1.4', TYPE_COLLECTION)
  464. OID_AGENT3_VERTICAL_ALIGNMENT = ("1.4.1.5.3.3.5", TYPE_SIGNED_INTEGER)
  465. OID_AGENT3_HORIZONTAL_ALIGNMENT = ("1.4.1.5.3.3.6", TYPE_SIGNED_INTEGER)
  466. OID_AGENT3_BIDIR_ADJUSTMENT = ("1.4.1.5.3.3.7", TYPE_SIGNED_INTEGER)
  467. OID_COLOR_CALIBRATION_SELECTION = ("1.4.1.5.1.9", TYPE_SIGNED_INTEGER)
  468.  
  469. # Type 4 color cal
  470. OID_COLOR_CALIBRATION_ARRAY_1 = ("1.4.1.1.30.1.1", TYPE_SIGNED_INTEGER) # K
  471. OID_COLOR_CALIBRATION_ARRAY_2 = ("1.4.1.1.30.1.2", TYPE_SIGNED_INTEGER) # C
  472. OID_COLOR_CALIBRATION_ARRAY_3 = ("1.4.1.1.30.1.3", TYPE_SIGNED_INTEGER) # M
  473. OID_COLOR_CALIBRATION_ARRAY_4 = ("1.4.1.1.30.1.4", TYPE_SIGNED_INTEGER) # Y
  474. OID_COLOR_CALIBRATION_ARRAY_5 = ("1.4.1.1.30.1.5", TYPE_SIGNED_INTEGER) # c
  475. OID_COLOR_CALIBRATION_ARRAY_6 = ("1.4.1.1.30.1.6", TYPE_SIGNED_INTEGER) # m
  476.  
  477. # Supported funcs
  478. OID_DEVICE_SUPPORTED_FUNCTIONS = ('1.1.2.67', TYPE_COLLECTION)
  479. DEVICE_SUPPORTED_FUNCTIONS_SCAN =                 0x00002
  480. DEVICE_SUPPORTED_FUNCTIONS_SCAN_SIMPLEX =         0x00004
  481. DEVICE_SUPPORTED_FUNCTIONS_SCAN_DUPLEX =          0x00008
  482. DEVICE_SUPPORTED_FUNCTIONS_COPY =                 0x00010
  483. DEVICE_SUPPORTED_FUNCTIONS_COPY_SIMPLEX_SIMPLEX = 0x00020
  484. DEVICE_SUPPORTED_FUNCTIONS_COPY_SIMPLEX_DUPLEX =  0x00040
  485. DEVICE_SUPPORTED_FUNCTIONS_COPY_DUPLEX_SIMPLEX =  0x00080
  486. DEVICE_SUPPORTED_FUNCTIONS_COPY_DUPLEX_DUPLEX =   0x00100
  487. DEVICE_SUPPORTED_FUNCTIONS_COPY_COLLATION =       0x00200
  488. DEVICE_SUPPORTED_FUNCTIONS_PRINT =                0x00400
  489. DEVICE_SUPPORTED_FUNCTIONS_AUTO_FEED_SIMPLEX =    0x00800
  490. DEVICE_SUPPORTED_FUNCTIONS_AUTO_FEED_DUPLEX =     0x01000
  491. DEVICE_SUPPORTED_FUNCTIONS_FAX_SEND =             0x02000
  492. DEVICE_SUPPORTED_FUNCTIONS_FAX_RECV =             0x04000
  493. DEVICE_SUPPORTED_FUNCTIONS_MASS_STORAGE =         0x08000
  494. DEVICE_SUPPORTED_FUNCTIONS_STREAMING_SAVE =       0x10000
  495. DEVICE_SUPPORTED_FUNCTIONS_FAX_CONFIG =           0x20000
  496. DEVICE_SUPPORTED_FUNCTIONS_FAX_CFG_SPEEDDIAL =    0x40000
  497. DEVICE_SUPPORTED_FUNCTIONS_FAX_CFG_GROUPDIAL =    0x80000
  498.  
  499.  
  500. OID_BATTERY_LEVEL = ('1.1.2.13', TYPE_SIGNED_INTEGER)
  501. OID_POWER_MODE = ('1.1.2.14', TYPE_ENUMERATION)
  502. POWER_MODE_ADPATER = 0x01
  503. POWER_MODE_BATTERY = 0x02
  504. POWER_MODE_CHARGING = 0x04
  505. POWER_MODE_DISCHARGING = 0x08
  506. POWER_MODE_BATTERY_LEVEL_KNOWN = 0x10
  507.  
  508. # Fax
  509. OID_DEV_DOWNLOAD_TIMEOUT = ('1.1.1.17', TYPE_SIGNED_INTEGER)
  510. DEFAULT_DOWNLOAD_TIMEOUT = 60
  511.  
  512. OID_FAX_DOWNLOAD_ERROR = ('1.3.7.2.6', TYPE_SIGNED_INTEGER)
  513.  
  514. OID_FAXJOB_TX_TYPE = ('1.1.6.3.1.3', TYPE_ENUMERATION)
  515. FAXJOB_TX_TYPE_HOST_ONLY = 2
  516.  
  517. OID_FAXJOB_TX_STATUS = ('1.1.6.3.3.3.1', TYPE_ENUMERATION)
  518. FAXJOB_TX_STATUS_IDLE = 1
  519. FAXJOB_TX_STATUS_DIALING = 2
  520. FAXJOB_TX_STATUS_CONNECTING = 3
  521. FAXJOB_TX_STATUS_TRANSMITTING = 4
  522. FAXJOB_TX_STATUS_DONE = 5
  523.  
  524. FAXJOB_TX_STATUS_STR = {FAXJOB_TX_STATUS_IDLE: "Idle",
  525.                  FAXJOB_TX_STATUS_DIALING: "Dialing",
  526.                  FAXJOB_TX_STATUS_CONNECTING: "Connecting",
  527.                  FAXJOB_TX_STATUS_TRANSMITTING: "Transmitting",
  528.                  FAXJOB_TX_STATUS_DONE: "Done",}
  529.  
  530. OID_FAXJOB_RX_STATUS = ('1.1.6.3.3.1.1', TYPE_ENUMERATION)
  531. FAXJOB_RX_STATUS_IDLE = 1
  532. FAXJOB_RX_STATUS_RINGING = 2
  533. FAXJOB_RX_STATUS_ANSWERING = 3
  534. FAXJOB_RX_STATUS_RECEIVING = 4
  535. FAXJOB_RX_STATUS_DONE = 5
  536.  
  537. FAXJOB_RX_STATUS_STR = {FAXJOB_RX_STATUS_IDLE: "Idle",
  538.                         FAXJOB_RX_STATUS_RINGING: "Ringing",
  539.                         FAXJOB_RX_STATUS_ANSWERING: "Answering",
  540.                         FAXJOB_RX_STATUS_RECEIVING: "Receiving",
  541.                         FAXJOB_RX_STATUS_DONE: "Done",}
  542.  
  543. OID_FAX_DOWNLOAD = ('1.3.7.1.6', TYPE_ENUMERATION)
  544. UPDN_STATE_IDLE = 1
  545. UPDN_STATE_REQSTART = 2
  546. UPDN_STATE_XFERACTIVE = 3
  547. UPDN_STATE_ERRORABORT = 4
  548. UPDN_STATE_XFERDONE = 5
  549. UPDN_STATE_NEWPAGE = 6
  550. UPDN_STATE_DISABLED = 7
  551.  
  552. UPDN_STATE_STR = {UPDN_STATE_IDLE: "Idle",
  553.                   UPDN_STATE_REQSTART: "Request start",
  554.                   UPDN_STATE_XFERACTIVE: "Transfer active",
  555.                   UPDN_STATE_ERRORABORT: "Error abort",
  556.                   UPDN_STATE_XFERDONE: "Transfer done",
  557.                   UPDN_STATE_NEWPAGE: "New page",
  558.                   UPDN_STATE_DISABLED: "Disabled",}
  559.  
  560. OID_FAX_TOKEN = ('1.1.1.27', TYPE_BINARY)
  561.  
  562. OID_FAX_TX_ID = ('1.1.6.3.2.3', TYPE_SIGNED_INTEGER)
  563. OID_FAXJOB_TX_ERROR = ('1.1.6.3.3.4.1', TYPE_SIGNED_INTEGER)
  564.  
  565. OID_FAX_LOCAL_PHONE_NUM = ('1.1.3.8', TYPE_STRING)
  566. OID_FAX_STATION_NAME = ('1.1.3.9', TYPE_STRING)
  567. OID_FAX_LINE_TYPE = ('1.3.7.1.16', TYPE_ENUMERATION)
  568. OID_FAX_ANSWERMODE = ('1.1.9.2.1.1', TYPE_ENUMERATION)
  569. OID_FAX_RING_ENABLE = ('1.3.7.1.8', TYPE_ENUMERATION)
  570. OID_FAX_NUM_RINGS_PICKUP = ('1.1.9.2.1.2', TYPE_SIGNED_INTEGER)
  571. OID_FAX_MIN_RINGS_PICKUP = ('1.3.7.2.2', TYPE_SIGNED_INTEGER)
  572. OID_FAX_MAX_RINGS_PICKUP = ('1.3.7.2.3', TYPE_SIGNED_INTEGER)
  573. OID_FAX_RING_TYPE_PICKUP = ('1.1.9.2.1.3', TYPE_COLLECTION)
  574. OID_FAX_DIAL_MODE = ('1.1.9.1.1.1', TYPE_ENUMERATION)
  575. OID_FAX_ALLOW_REDIALS = ('1.4.2.5.3', TYPE_ENUMERATION)
  576. OID_FAX_REDIAL = ('1.1.9.1.1.2', TYPE_COLLECTION)
  577. OID_FAX_RESOLUTION = ('1.4.2.1.1', TYPE_BINARY)
  578. OID_FAX_CONTRAST = ('1.4.2.1.2', TYPE_SIGNED_INTEGER)
  579.  
  580. #OID_FAX_UPLOAD = ('1.3.7.2.1', TYPE_ENUMERATION)
  581. #OID_FAX_UPLOAD_ERROR = ('1.3.7.2.7', TYPE_SIGNED_INTEGER)
  582.  
  583. OID_FAX_CFG_UPLOAD_DATA_TYPE = ('1.1.1.14', TYPE_ENUMERATION)
  584. FAX_CFG_UPLOAD_DATA_TYPE_SPEEDDIALS = 5
  585. FAX_CFG_UPLOAD_DATA_TYPE_FAXLOGS = 6
  586. FAX_CFG_UPLOAD_DATA_TYPE_CONFIG_PARAMS = 7
  587. FAX_CFG_UPLOAD_DATA_TYPE_JUNK_FAX_DIAL_STRINGS = 8
  588.  
  589. OID_UPLOAD_TIMEOUT = ('1.1.1.18', TYPE_SIGNED_INTEGER)
  590. DEFAULT_UPLOAD_TIMEOUT = 60
  591.  
  592. OID_DEVICE_CFG_UPLOAD = ('1.1.1.13', TYPE_ENUMERATION)
  593.  
  594.  
  595.