mirror of
https://github.com/psforever/PSF-LoginServer.git
synced 2026-01-19 18:44:45 +00:00
Optimisations on MD5MAC and updated Scala version to 2.13.10
Adopted ListBuffer to ArrayBuffer switch that also fixes the problem with the new Scala version
This commit is contained in:
parent
b0d7ae12d1
commit
c7a697213b
|
|
@ -3,9 +3,7 @@
|
||||||
lazy val psforeverSettings = Seq(
|
lazy val psforeverSettings = Seq(
|
||||||
organization := "net.psforever",
|
organization := "net.psforever",
|
||||||
version := "1.0.2-SNAPSHOT",
|
version := "1.0.2-SNAPSHOT",
|
||||||
// TODO 2.13.5+ breaks Md5Mac test
|
scalaVersion := "2.13.10",
|
||||||
// possibly due to ListBuffer changes? https://github.com/scala/scala/pull/9257
|
|
||||||
scalaVersion := "2.13.4",
|
|
||||||
Global / cancelable := false,
|
Global / cancelable := false,
|
||||||
semanticdbEnabled := true,
|
semanticdbEnabled := true,
|
||||||
semanticdbVersion := scalafixSemanticdb.revision,
|
semanticdbVersion := scalafixSemanticdb.revision,
|
||||||
|
|
|
||||||
|
|
@ -1,7 +1,7 @@
|
||||||
package net.psforever.util
|
package net.psforever.util
|
||||||
|
|
||||||
import scodec.bits.ByteVector
|
import scodec.bits.ByteVector
|
||||||
import scala.collection.mutable.ListBuffer
|
import scala.collection.mutable.ArrayBuffer
|
||||||
|
|
||||||
object Md5Mac {
|
object Md5Mac {
|
||||||
val BLOCKSIZE = 64
|
val BLOCKSIZE = 64
|
||||||
|
|
@ -39,12 +39,12 @@ object Md5Mac {
|
||||||
class Md5Mac(val key: ByteVector) {
|
class Md5Mac(val key: ByteVector) {
|
||||||
import Md5Mac._
|
import Md5Mac._
|
||||||
|
|
||||||
private val buffer: ListBuffer[Byte] = ListBuffer.fill(BLOCKSIZE)(0)
|
private val buffer: ArrayBuffer[Byte] = ArrayBuffer.fill(BLOCKSIZE)(0)
|
||||||
private val digest: ListBuffer[Byte] = ListBuffer.fill(DIGESTSIZE)(0)
|
private val digest: ArrayBuffer[Byte] = ArrayBuffer.fill(DIGESTSIZE)(0)
|
||||||
private val m: ListBuffer[Byte] = ListBuffer.fill(32)(0)
|
private val m: ArrayBuffer[Byte] = ArrayBuffer.fill(32)(0)
|
||||||
private val k1: ListBuffer[Byte] = ListBuffer.fill(16)(0)
|
private val k1: ArrayBuffer[Byte] = ArrayBuffer.fill(16)(0)
|
||||||
private val k2: ListBuffer[Byte] = ListBuffer.fill(16)(0)
|
private val k2: ArrayBuffer[Byte] = ArrayBuffer.fill(16)(0)
|
||||||
private val k3: ListBuffer[Byte] = ListBuffer.fill(BLOCKSIZE)(0)
|
private val k3: ArrayBuffer[Byte] = ArrayBuffer.fill(BLOCKSIZE)(0)
|
||||||
private var count: Long = 0
|
private var count: Long = 0
|
||||||
private var position: Int = 0
|
private var position: Int = 0
|
||||||
|
|
||||||
|
|
@ -58,8 +58,8 @@ class Md5Mac(val key: ByteVector) {
|
||||||
doKey()
|
doKey()
|
||||||
|
|
||||||
private def doKey(): Unit = {
|
private def doKey(): Unit = {
|
||||||
val ek: ListBuffer[Byte] = ListBuffer.fill(48)(0)
|
val ek: ArrayBuffer[Byte] = ArrayBuffer.fill(48)(0)
|
||||||
val data: ListBuffer[Byte] = ListBuffer.fill(128)(0)
|
val data: ArrayBuffer[Byte] = ArrayBuffer.fill(128)(0)
|
||||||
(0 until 16).foreach(j => {
|
(0 until 16).foreach(j => {
|
||||||
data(j) = key(j % key.length)
|
data(j) = key(j % key.length)
|
||||||
data(j + 112) = key(j % key.length)
|
data(j + 112) = key(j % key.length)
|
||||||
|
|
@ -175,7 +175,14 @@ class Md5Mac(val key: ByteVector) {
|
||||||
}
|
}
|
||||||
|
|
||||||
private def mkInt(lb: Iterable[Byte], pos: Int = 0): Int = {
|
private def mkInt(lb: Iterable[Byte], pos: Int = 0): Int = {
|
||||||
ByteVector.view(lb.slice(pos, pos + 4).toArray).toInt()
|
|
||||||
|
// get iterator
|
||||||
|
val it = lb.iterator.drop(pos)
|
||||||
|
|
||||||
|
(it.next().toInt & 0xFF) << 24 |
|
||||||
|
(it.next().toInt & 0xFF) << 16 |
|
||||||
|
(it.next().toInt & 0xFF) << 8 |
|
||||||
|
(it.next().toInt & 0xFF)
|
||||||
}
|
}
|
||||||
|
|
||||||
private def ff(a: Int, b: Int, c: Int, d: Int, msg: Int, shift: Int, magic: Int): Int = {
|
private def ff(a: Int, b: Int, c: Int, d: Int, msg: Int, shift: Int, magic: Int): Int = {
|
||||||
|
|
@ -226,7 +233,7 @@ class Md5Mac(val key: ByteVector) {
|
||||||
* @return the hash
|
* @return the hash
|
||||||
*/
|
*/
|
||||||
def doFinal(length: Int = MACLENGTH): ByteVector = {
|
def doFinal(length: Int = MACLENGTH): ByteVector = {
|
||||||
val output: ListBuffer[Byte] = ListBuffer.fill(MACLENGTH)(0)
|
val output: ArrayBuffer[Byte] = ArrayBuffer.fill(MACLENGTH)(0)
|
||||||
buffer(position) = 0x80.toByte
|
buffer(position) = 0x80.toByte
|
||||||
(position + 1 until BLOCKSIZE).foreach(i => buffer(i) = 0)
|
(position + 1 until BLOCKSIZE).foreach(i => buffer(i) = 0)
|
||||||
if (position >= BLOCKSIZE - 8) {
|
if (position >= BLOCKSIZE - 8) {
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue