home *** CD-ROM | disk | FTP | other *** search
/ Personal Computer World 2007 September / PCWSEP07.iso / Software / Linux / Linux Mint 3.0 Light / LinuxMint-3.0-Light.iso / casper / filesystem.squashfs / usr / lib / hplip / base / pml.py < prev    next >
Encoding:
Python Source  |  2007-04-04  |  23.9 KB  |  726 lines

  1. # -*- coding: utf-8 -*-
  2. #
  3. # (c) Copyright 2003-2007 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/OJ Pro L7xxx
  357. PRINT_INTERNAL_PAGE_ALIGNMENT_PAGE_VERIFICATION = 1150 # LBOW
  358. PRINT_INTERNAL_PAGE_LINEFEED_CALIBRATION = 1407 # OJ Pro
  359. PRINT_INTERNAL_PAGE_PRINT_QUALITY_DIAGNOSTIC = 1409 # OJ Pro
  360.  
  361. # From xojpanel
  362. OID_SPM_LINE1 = ('2.16.5.1.2.1.1', TYPE_STRING)
  363. OID_SPM_LINE2 = ('2.16.5.1.2.1.2', TYPE_STRING)
  364.  
  365. OID_HP_LINE1 = ('1.1.2.20.2.1.1', TYPE_STRING)
  366. OID_HP_LINE2 = ('1.1.2.20.2.2.1', TYPE_STRING)
  367.  
  368.  
  369. # LaserJet Status (status type 3)
  370. OID_ON_OFF_LINE = ('1.1.2.5', TYPE_SIGNED_INTEGER)
  371. ON_OFF_LINE_ONLINE = 1
  372. ON_OFF_LINE_OFFLINE = 2
  373. ON_OFF_LINE_OFFLINE_AT_END_OF_JOB = 3
  374.  
  375. OID_SLEEP_MODE = ('1.1.1.2', TYPE_SIGNED_INTEGER)
  376. SLEEP_MODE_FALSE = 1
  377. SLEEP_MODE_TRUE = 2
  378.  
  379. OID_PRINTER_STATUS = ('3.3.5.1.1.1', TYPE_SIGNED_INTEGER)
  380. PRINTER_STATUS_OTHER = 1
  381. PRINTER_STATUS_UNKNOWN = 2
  382. PRINTER_STATUS_IDLE = 3
  383. PRINTER_STATUS_PRINTING = 4
  384. PRINTER_STATUS_WARMUP = 5
  385.  
  386. OID_COVER_STATUS = ('2.6.1.1.3.1.1', TYPE_SIGNED_INTEGER)
  387. COVER_STATUS_OPEN = 3
  388. COVER_STATUS_CLOSED = 4
  389.  
  390. OID_DETECTED_ERROR_STATE = ('3.3.5.1.2.1', TYPE_BINARY)
  391. DETECTED_ERROR_STATE_LOW_PAPER_MASK = 0x80
  392. DETECTED_ERROR_STATE_NO_PAPER_MASK = 0x40
  393. DETECTED_ERROR_STATE_LOW_CART_MASK = 0x20
  394. DETECTED_ERROR_STATE_OUT_CART_MASK = 0x10
  395. DETECTED_ERROR_STATE_DOOR_OPEN_MASK = 0x08
  396. DETECTED_ERROR_STATE_JAMMED_MASK = 0x04
  397. DETECTED_ERROR_STATE_OFFLINE_MASK = 0x02
  398. DETECTED_ERROR_STATE_SERVICE_REQUEST_MASK = 0x01
  399. DETECTED_ERROR_STATE_NO_ERROR = 0x00
  400.  
  401. OID_MARKER_SUPPLIES_TYPE_x = '2.11.1.1.5.1.%d'
  402. OID_MARKER_SUPPLIES_TYPE_x_TYPE = TYPE_ENUMERATION
  403. OID_MARKER_SUPPLIES_TYPE_OTHER = 1
  404. OID_MARKER_SUPPLIES_TYPE_UNKNOWN = 2
  405. OID_MARKER_SUPPLIES_TYPE_TONER = 3
  406. OID_MARKER_SUPPLIES_TYPE_WASTE_TONER = 4
  407. OID_MARKER_SUPPLIES_TYPE_INK = 5
  408. OID_MARKER_SUPPLIES_TYPE_INK_CART = 6
  409. OID_MARKER_SUPPLIES_TYPE_INK_RIBBON = 7
  410. OID_MARKER_SUPPLIES_TYPE_WASTE_INK = 8
  411. OID_MARKER_SUPPLIES_TYPE_OPC = 9
  412. OID_MARKER_SUPPLIES_TYPE_DEVELOPER = 10
  413. OID_MARKER_SUPPLIES_TYPE_FUSER_OIL = 11
  414. OID_MARKER_SUPPLIES_TYPE_SOLID_WAX = 12
  415. OID_MARKER_SUPPLIES_TYPE_RIBBON_WAX = 13
  416. OID_MARKER_SUPPLIES_TYPE_WASTE_WAX = 14
  417. OID_MARKER_SUPPLIES_TYPE_FUSER = 15
  418. OID_MARKER_SUPPLIES_TYPE_CORONA_WIRE = 16
  419. OID_MARKER_SUPPLIES_TYPE_FUSER_OIL_WICK = 17
  420. OID_MARKER_SUPPLIES_TYPE_CLEANER_UNIT = 18
  421. OID_MARKER_SUPPLIES_TYPE_FUSER_CLEANING_PAD = 19
  422. OID_MARKER_SUPPLIES_TYPE_TRANSFER_UNIT = 20
  423. OID_MARKER_SUPPLIES_TYPE_TONER_CART = 21
  424. OID_MARKER_SUPPLIES_TYPE_FUSER_OILER = 22
  425. OID_MARKER_SUPPLIES_TYPE_ADF_MAINT_KIT = 23
  426.  
  427. OID_MARKER_SUPPLIES_COLORANT_INDEX_x = '2.11.1.1.3.1.%d'
  428. OID_MARKER_SUPPLIES_COLORANT_INDEX_x_TYPE = TYPE_SIGNED_INTEGER
  429.  
  430. OID_MARKER_SUPPLIES_MAX_x = '2.11.1.1.8.1.%d'
  431. OID_MARKER_SUPPLIES_MAX_x_TYPE = TYPE_SIGNED_INTEGER
  432.  
  433. OID_MARKER_SUPPLIES_LEVEL_x = '2.11.1.1.9.1.%d'
  434. OID_MARKER_SUPPLIES_LEVEL_x_TYPE = TYPE_SIGNED_INTEGER
  435.  
  436. OID_MARKER_COLORANT_VALUE_x = '2.12.1.1.4.1.%d'
  437. OID_MARKER_COLORANT_VALUE_x_TYPE = TYPE_STRING
  438.  
  439. OID_MARKER_STATUS_x = '2.10.2.1.15.1.%d'
  440. OID_MARKER_STATUS_x_TYPE = TYPE_SIGNED_INTEGER
  441. OID_MARKER_STATUS_OK = 0
  442. OID_MARKER_STATUS_LOW_TONER_CONT = 8
  443. OID_MARKER_STATUS_LOW_TONER_STOP = 49
  444. OID_MARKER_STATUS_MISINSTALLED = 51
  445.  
  446. OID_MARKER_SUPPLIES_DESCRIPTION_x = '2.11.1.1.6.1.%d'
  447. OID_MARKER_SUPPLIES_DESCRIPTION_x_TYPE = TYPE_BINARY
  448.  
  449. OID_DEVICE_STATUS = ('3.3.2.1.5.1', TYPE_ENUMERATION)
  450. DEVICE_STATUS_UNKNOWN = 1
  451. DEVICE_STATUS_RUNNING = 2
  452. DEVICE_STATUS_WARNING = 3
  453. DEVICE_STATUS_TESTING = 4
  454. DEVICE_STATUS_DOWN = 5
  455. #end
  456.  
  457. # alignment, cleaning, etc.
  458. OID_AUTO_ALIGNMENT = ('1.1.5.2', TYPE_ENUMERATION)
  459. AUTO_ALIGNMENT = 1100
  460. OID_ZCA = ('1.4.1.8.5.4.1', TYPE_SIGNED_INTEGER)
  461. OID_AGENT2_VERTICAL_ALIGNMENT = ('1.4.1.5.3.2.5', TYPE_SIGNED_INTEGER)
  462. OID_AGENT2_HORIZONTAL_ALIGNMENT = ('1.4.1.5.3.2.6', TYPE_SIGNED_INTEGER)
  463. OID_AGENT1_BIDIR_ADJUSTMENT = ('1.4.1.5.3.1.7', TYPE_SIGNED_INTEGER)
  464. OID_AGENT2_BIDIR_ADJUSTMENT = ('1.4.1.5.3.2.7', TYPE_SIGNED_INTEGER)
  465. OID_MARKING_AGENTS_INITIALIZED = ('1.4.1.5.1.4', TYPE_COLLECTION)
  466. OID_AGENT3_VERTICAL_ALIGNMENT = ("1.4.1.5.3.3.5", TYPE_SIGNED_INTEGER)
  467. OID_AGENT3_HORIZONTAL_ALIGNMENT = ("1.4.1.5.3.3.6", TYPE_SIGNED_INTEGER)
  468. OID_AGENT3_BIDIR_ADJUSTMENT = ("1.4.1.5.3.3.7", TYPE_SIGNED_INTEGER)
  469. OID_COLOR_CALIBRATION_SELECTION = ("1.4.1.5.1.9", TYPE_SIGNED_INTEGER)
  470.  
  471. # Type 4 color cal
  472. OID_COLOR_CALIBRATION_ARRAY_1 = ("1.4.1.1.30.1.1", TYPE_SIGNED_INTEGER) # K
  473. OID_COLOR_CALIBRATION_ARRAY_2 = ("1.4.1.1.30.1.2", TYPE_SIGNED_INTEGER) # C
  474. OID_COLOR_CALIBRATION_ARRAY_3 = ("1.4.1.1.30.1.3", TYPE_SIGNED_INTEGER) # M
  475. OID_COLOR_CALIBRATION_ARRAY_4 = ("1.4.1.1.30.1.4", TYPE_SIGNED_INTEGER) # Y
  476. OID_COLOR_CALIBRATION_ARRAY_5 = ("1.4.1.1.30.1.5", TYPE_SIGNED_INTEGER) # c
  477. OID_COLOR_CALIBRATION_ARRAY_6 = ("1.4.1.1.30.1.6", TYPE_SIGNED_INTEGER) # m
  478.  
  479. # Supported funcs
  480. OID_DEVICE_SUPPORTED_FUNCTIONS = ('1.1.2.67', TYPE_COLLECTION)
  481. DEVICE_SUPPORTED_FUNCTIONS_SCAN =                 0x00002
  482. DEVICE_SUPPORTED_FUNCTIONS_SCAN_SIMPLEX =         0x00004
  483. DEVICE_SUPPORTED_FUNCTIONS_SCAN_DUPLEX =          0x00008
  484. DEVICE_SUPPORTED_FUNCTIONS_COPY =                 0x00010
  485. DEVICE_SUPPORTED_FUNCTIONS_COPY_SIMPLEX_SIMPLEX = 0x00020
  486. DEVICE_SUPPORTED_FUNCTIONS_COPY_SIMPLEX_DUPLEX =  0x00040
  487. DEVICE_SUPPORTED_FUNCTIONS_COPY_DUPLEX_SIMPLEX =  0x00080
  488. DEVICE_SUPPORTED_FUNCTIONS_COPY_DUPLEX_DUPLEX =   0x00100
  489. DEVICE_SUPPORTED_FUNCTIONS_COPY_COLLATION =       0x00200
  490. DEVICE_SUPPORTED_FUNCTIONS_PRINT =                0x00400
  491. DEVICE_SUPPORTED_FUNCTIONS_AUTO_FEED_SIMPLEX =    0x00800
  492. DEVICE_SUPPORTED_FUNCTIONS_AUTO_FEED_DUPLEX =     0x01000
  493. DEVICE_SUPPORTED_FUNCTIONS_FAX_SEND =             0x02000
  494. DEVICE_SUPPORTED_FUNCTIONS_FAX_RECV =             0x04000
  495. DEVICE_SUPPORTED_FUNCTIONS_MASS_STORAGE =         0x08000
  496. DEVICE_SUPPORTED_FUNCTIONS_STREAMING_SAVE =       0x10000
  497. DEVICE_SUPPORTED_FUNCTIONS_FAX_CONFIG =           0x20000
  498. DEVICE_SUPPORTED_FUNCTIONS_FAX_CFG_SPEEDDIAL =    0x40000
  499. DEVICE_SUPPORTED_FUNCTIONS_FAX_CFG_GROUPDIAL =    0x80000
  500.  
  501.  
  502. OID_BATTERY_LEVEL = ('1.1.2.13', TYPE_SIGNED_INTEGER)
  503. OID_POWER_MODE = ('1.1.2.14', TYPE_ENUMERATION)
  504. POWER_MODE_ADPATER = 0x01
  505. POWER_MODE_BATTERY = 0x02
  506. POWER_MODE_CHARGING = 0x04
  507. POWER_MODE_DISCHARGING = 0x08
  508. POWER_MODE_BATTERY_LEVEL_KNOWN = 0x10
  509.  
  510. #
  511. # Fax
  512. #
  513.  
  514. OID_DEV_DOWNLOAD_TIMEOUT = ('1.1.1.17', TYPE_SIGNED_INTEGER)
  515. DEFAULT_DOWNLOAD_TIMEOUT = 60
  516.  
  517. OID_FAX_DOWNLOAD_ERROR = ('1.3.7.2.6', TYPE_SIGNED_INTEGER)
  518.  
  519. OID_FAXJOB_TX_TYPE = ('1.1.6.3.1.3', TYPE_ENUMERATION)
  520. FAXJOB_TX_TYPE_HOST_ONLY = 2
  521.  
  522. OID_FAXJOB_TX_STATUS = ('1.1.6.3.3.3.1', TYPE_ENUMERATION)
  523. FAXJOB_TX_STATUS_IDLE = 1
  524. FAXJOB_TX_STATUS_DIALING = 2
  525. FAXJOB_TX_STATUS_CONNECTING = 3
  526. FAXJOB_TX_STATUS_TRANSMITTING = 4
  527. FAXJOB_TX_STATUS_DONE = 5
  528.  
  529. FAXJOB_TX_STATUS_STR = {FAXJOB_TX_STATUS_IDLE: "Idle",
  530.                  FAXJOB_TX_STATUS_DIALING: "Dialing",
  531.                  FAXJOB_TX_STATUS_CONNECTING: "Connecting",
  532.                  FAXJOB_TX_STATUS_TRANSMITTING: "Transmitting",
  533.                  FAXJOB_TX_STATUS_DONE: "Done",}
  534.  
  535. OID_FAXJOB_RX_STATUS = ('1.1.6.3.3.1.1', TYPE_ENUMERATION)
  536. FAXJOB_RX_STATUS_IDLE = 1
  537. FAXJOB_RX_STATUS_RINGING = 2
  538. FAXJOB_RX_STATUS_ANSWERING = 3
  539. FAXJOB_RX_STATUS_RECEIVING = 4
  540. FAXJOB_RX_STATUS_DONE = 5
  541.  
  542. FAXJOB_RX_STATUS_STR = {FAXJOB_RX_STATUS_IDLE: "Idle",
  543.                         FAXJOB_RX_STATUS_RINGING: "Ringing",
  544.                         FAXJOB_RX_STATUS_ANSWERING: "Answering",
  545.                         FAXJOB_RX_STATUS_RECEIVING: "Receiving",
  546.                         FAXJOB_RX_STATUS_DONE: "Done",}
  547.  
  548. OID_FAX_DOWNLOAD = ('1.3.7.1.6', TYPE_ENUMERATION)
  549. UPDN_STATE_IDLE = 1
  550. UPDN_STATE_REQSTART = 2
  551. UPDN_STATE_XFERACTIVE = 3
  552. UPDN_STATE_ERRORABORT = 4
  553. UPDN_STATE_XFERDONE = 5
  554. UPDN_STATE_NEWPAGE = 6
  555. UPDN_STATE_DISABLED = 7
  556.  
  557. UPDN_STATE_STR = {UPDN_STATE_IDLE: "Idle",
  558.                   UPDN_STATE_REQSTART: "Request start",
  559.                   UPDN_STATE_XFERACTIVE: "Transfer active",
  560.                   UPDN_STATE_ERRORABORT: "Error abort",
  561.                   UPDN_STATE_XFERDONE: "Transfer done",
  562.                   UPDN_STATE_NEWPAGE: "New page",
  563.                   UPDN_STATE_DISABLED: "Disabled",}
  564.  
  565. OID_FAX_TOKEN = ('1.1.1.27', TYPE_BINARY)
  566.  
  567. OID_FAX_TX_ID = ('1.1.6.3.2.3', TYPE_SIGNED_INTEGER)
  568. OID_FAXJOB_TX_ERROR = ('1.1.6.3.3.4.1', TYPE_SIGNED_INTEGER)
  569.  
  570. OID_FAX_LOCAL_PHONE_NUM = ('1.1.3.8', TYPE_STRING)
  571. OID_FAX_STATION_NAME = ('1.1.3.9', TYPE_STRING)
  572. OID_FAX_LINE_TYPE = ('1.3.7.1.16', TYPE_ENUMERATION)
  573. OID_FAX_ANSWERMODE = ('1.1.9.2.1.1', TYPE_ENUMERATION)
  574. OID_FAX_RING_ENABLE = ('1.3.7.1.8', TYPE_ENUMERATION)
  575. OID_FAX_NUM_RINGS_PICKUP = ('1.1.9.2.1.2', TYPE_SIGNED_INTEGER)
  576. OID_FAX_MIN_RINGS_PICKUP = ('1.3.7.2.2', TYPE_SIGNED_INTEGER)
  577. OID_FAX_MAX_RINGS_PICKUP = ('1.3.7.2.3', TYPE_SIGNED_INTEGER)
  578. OID_FAX_RING_TYPE_PICKUP = ('1.1.9.2.1.3', TYPE_COLLECTION)
  579. OID_FAX_DIAL_MODE = ('1.1.9.1.1.1', TYPE_ENUMERATION)
  580. OID_FAX_ALLOW_REDIALS = ('1.4.2.5.3', TYPE_ENUMERATION)
  581. OID_FAX_REDIAL = ('1.1.9.1.1.2', TYPE_COLLECTION)
  582. OID_FAX_RESOLUTION = ('1.4.2.1.1', TYPE_BINARY)
  583. OID_FAX_CONTRAST = ('1.4.2.1.2', TYPE_SIGNED_INTEGER)
  584.  
  585. #OID_FAX_UPLOAD = ('1.3.7.2.1', TYPE_ENUMERATION)
  586. #OID_FAX_UPLOAD_ERROR = ('1.3.7.2.7', TYPE_SIGNED_INTEGER)
  587.  
  588. OID_FAX_CFG_UPLOAD_DATA_TYPE = ('1.1.1.14', TYPE_ENUMERATION)
  589. FAX_CFG_UPLOAD_DATA_TYPE_SPEEDDIALS = 5
  590. FAX_CFG_UPLOAD_DATA_TYPE_FAXLOGS = 6
  591. FAX_CFG_UPLOAD_DATA_TYPE_CONFIG_PARAMS = 7
  592. FAX_CFG_UPLOAD_DATA_TYPE_JUNK_FAX_DIAL_STRINGS = 8
  593.  
  594. OID_UPLOAD_TIMEOUT = ('1.1.1.18', TYPE_SIGNED_INTEGER)
  595. DEFAULT_UPLOAD_TIMEOUT = 60
  596.  
  597. OID_DEVICE_CFG_UPLOAD = ('1.1.1.13', TYPE_ENUMERATION)
  598.  
  599. #
  600. # Copier
  601. #
  602.  
  603. OID_COPIER_TOKEN = ('1.1.1.24', TYPE_BINARY)
  604. OID_COPY_SCANNER_DIMENSIONS = ('1.2.2.2.13', TYPE_STRING)
  605.  
  606. # Sticky settings
  607. OID_COPIER_CONTRAST = ('1.5.1.2', TYPE_SIGNED_INTEGER) # -125, -100, -75, -50, -25, 0, 25, 50, 75, 100, 125
  608. OID_COPIER_REDUCTION = ('1.5.1.4', TYPE_SIGNED_INTEGER) # (100%=no scaling) (OID_COPIER_FIT_TO_PAGE overrides)
  609.                                                         # range: COPIER-REDUCTION-MAXIMUM (25) - COPIER-ENLARGEMENT-MAXIMUM (400)
  610. OID_COPIER_NUM_COPIES = ('1.5.1.6', TYPE_SIGNED_INTEGER) # 1-99
  611.  
  612. OID_COPIER_COLLATION = ('1.5.1.7', TYPE_ENUMERATION)
  613. COPIER_COLLATION_DISABLED = 1
  614. COPIER_COLLATION_FORWARD = 2
  615.  
  616. OID_COPIER_ENLARGEMENT_MAXIMUM = ('1.5.1.11', TYPE_SIGNED_INTEGER) # default 400
  617. OID_COPIER_REDUCTION_MAXIMUM = ('1.5.1.12', TYPE_SIGNED_INTEGER) # default 25
  618.  
  619. OID_COPIER_QUALITY = ('1.5.1.13', TYPE_ENUMERATION)
  620. COPIER_QUALITY_FAST = 1
  621. COPIER_QUALITY_NORMAL = 2
  622. COPIER_QUALITY_PRESENTATION = 3
  623. COPIER_QUALITY_DRAFT = 4
  624. COPIER_QUALITY_BEST = 5
  625.  
  626. OID_COPIER_ADF_PAGE_COUNT = ('1.5.1.19', TYPE_SIGNED_INTEGER)
  627. OID_COPIER_PRINT_PAGE_COUNT = ('1.5.1.20', TYPE_SIGNED_INTEGER)
  628.  
  629. OID_COPIER_FIT_TO_PAGE = ('1.5.1.47', TYPE_ENUMERATION)
  630. COPIER_FIT_TO_PAGE_DISABLED = 1
  631. COPIER_FIT_TO_PAGE_ENABLED = 2
  632.  
  633. # Job (non-sticky) settings
  634. OID_COPIER_JOB_QUALITY = ('1.5.1.22', TYPE_ENUMERATION)
  635. # use enums from OID_COPIER_QUALITY
  636.  
  637. OID_COPIER_JOB_MEDIA_SIZE = ('1.5.1.21', TYPE_ENUMERATION)
  638. COPIER_JOB_MEDIA_SIZE_US_LETTER = 2
  639. COPIER_JOB_MEDIA_SIZE_US_LEGAL = 3
  640. COPIER_JOB_MEDIA_SIZE_A4 = 26
  641.  
  642. OID_COPIER_JOB_COLLATION = ('1.5.1.23', TYPE_ENUMERATION)
  643. # use enums from OID_COPIER_COLLATION
  644.  
  645. OID_COPIER_JOB_NUM_COPIES = ('1.5.1.24', TYPE_SIGNED_INTEGER)
  646. OID_COPIER_JOB_REDUCTION = ('1.5.1.25', TYPE_SIGNED_INTEGER)
  647. OID_COPIER_JOB_CONTRAST = ('1.5.1.26', TYPE_SIGNED_INTEGER) # -125, -100, -75, -50, -25, 0, 25, 50, 75, 100, 125
  648.  
  649. OID_COPIER_JOB_FIT_TO_PAGE = ('1.5.1.48', TYPE_ENUMERATION)
  650. # use enums from OID_COPIER_FIT_TO_PAGE
  651.  
  652. # Copy job
  653.  
  654. OID_COPIER_JOB = ('1.5.1.27', TYPE_ENUMERATION)
  655. COPIER_JOB_IDLE = 1
  656. COPIER_JOB_START = 2
  657. COPIER_JOB_ACTIVE = 3
  658. COPIER_JOB_ABORTING = 4
  659. COPIER_JOB_SETUP = 5
  660.  
  661. # AiO Specific Copy
  662.  
  663. OID_SCAN_TO_PRINTER = ('1.5.1.5', TYPE_SIGNED_INTEGER)
  664. SCAN_TO_PRINTER_IDLE         = 1
  665. SCAN_TO_PRINTER_START        = 2
  666. SCAN_TO_PRINTER_ACTIVE       = 3
  667. SCAN_TO_PRINTER_ABORTED      = 4
  668. SCAN_TO_PRINTER_SET_DEFAULTS = 5
  669. SCAN_TO_PRINTER_GET_DEFAULTS = 6
  670.  
  671. OID_PIXEL_DATA_TYPE = ('1.5.1.3', TYPE_SIGNED_INTEGER)
  672. PIXEL_DATA_TYPE_GRAYSCALE_256     = 8
  673. PIXEL_DATA_TYPE_COLOR_24_BIT      = 24
  674.  
  675. OID_COPIER_SPECIAL_FEATURES = ('1.5.1.16', TYPE_SIGNED_INTEGER)
  676. COPY_FEATURE_NONE     = 1
  677. COPY_FEATURE_CLONE    = 2
  678. COPY_FEATURE_POSTER   = 3
  679. COPY_FEATURE_MIRROR   = 4
  680. COPY_FEATURE_AUTOFIT  = 5
  681. COPY_FEATURE_TWOUP    = 6
  682. COPY_FEATURE_AUTOFILL = 7
  683.  
  684.  
  685. OID_COPIER_PHOTO_MODE = ('1.5.1.15', TYPE_COLLECTION)
  686. ENHANCE_LIGHT_COLORS  =  0x00000001  # Bit  0
  687. ENHANCE_TEXT          =  0x00000002  # Bit  1
  688.  
  689. OID_COPIER_NUM_COPIES_AIO = ('1.5.1.6', TYPE_SIGNED_INTEGER)
  690. OID_COPIER_CONTRAST_AIO = ('1.5.1.2', TYPE_SIGNED_INTEGER)
  691. OID_COPIER_REDUCTION_AIO = ('1.5.1.4', TYPE_SIGNED_INTEGER)
  692. OID_COPIER_QUALITY_AIO = ('1.5.1.13', TYPE_ENUMERATION)
  693.  
  694. OID_COPIER_JOB_INPUT_TRAY_SELECT = ('1.5.1.51', TYPE_SIGNED_INTEGER)
  695. COPIER_JOB_INPUT_TRAY_1 = 1
  696. COPIER_JOB_INPUT_TRAY_2 = 1
  697. COPIER_JOB_INPUT_TRAY_3 = 1
  698.  
  699. OID_COPIER_MEDIA_TYPE = ('1.5.1.14', TYPE_SIGNED_INTEGER)
  700. COPIER_MEDIA_TYPE_PLAIN               = 1
  701. COPIER_MEDIA_TYPE_BRIGHT_WHITE        = 2
  702. COPIER_MEDIA_TYPE_PREMIUM_PHOTO       = 3
  703. COPIER_MEDIA_TYPE_SPECIAL             = 4
  704. COPIER_MEDIA_TYPE_TRANSPARENCY        = 5
  705. COPIER_MEDIA_TYPE_IRON_ON             = 6
  706. COPIER_MEDIA_TYPE_FAST_TRANSPARANCEY  = 7
  707. COPIER_MEDIA_TYPE_BROCHURE_MATTE      = 8
  708. COPIER_MEDIA_TYPE_BROCHURE_GLOSSY     = 9
  709. COPIER_MEDIA_TYPE_PHOTO_GLOSSY        = 10
  710. COPIER_MEDIA_TYPE_MATTE_PAPER         = 11
  711. COPIER_MEDIA_TYPE_EVERYDAY_PHOTO      = 12
  712. COPIER_MEDIA_TYPE_PHOTO_QUAL_INKJET   = 13
  713. COPIER_MEDIA_TYPE_PHOTO               = 14 
  714. COPIER_MEDIA_TYPE_AUTOMATIC           = 15
  715. COPIER_MEDIA_TYPE_ADVANCED_PHOTO      = 16
  716. COPIER_MEDIA_TYPE_IRON_ON_MIRRORED    = 17
  717.  
  718.  
  719.  
  720. # Misc
  721.  
  722. OID_DATE_AND_TIME = ('1.1.2.17', TYPE_BINARY)
  723.  
  724.  
  725.  
  726.