[리디북스] DRM 해제하기, 한번 더 (ft. Riberty)

많이 바쁘기도 하고, 기술적으로 크게 어려워진 부분은 없었으므로 장문의 글은 게재하지 않을 예정입니다.

이전에는 Proof-of-Concept 수준의 파이썬 코드를 공개했는데, @disjukr님께서 간단한 GUI wrapper를 만들어주심에 영감을 받아서 이번에는 Riberty라는 이름의 간단한 툴로 만들어 배포합니다.

macOS만 지원하며, 10.12 (Sierra)와 10.14 (Mojave) 버전에서만 테스트 하였습니다. PyQt로 작성되었으며, 실행에 용이하도록 앱으로 패키징하는 바람에 용량이 39MB 정도로 꽤 큽니다.

PyQt를 사용한 것은 간단한 GUI를 지원하기 위함만은 아닙니다. 그러기엔 사실 용량을 고려했을때 비효율적이죠. 진짜 이유는.. 지난번 공개 이후 리디측에서 DRM 알고리즘에 약간의 변화를 두었는데 (정확히는 암호화된 content-key를 복호화하기 위한 key 도출 방법의 변화), 이 부분에서 리디북스 앱이 Qt 함수 몇 가지를 가져다가 쓰는데 직접 구현하기 귀찮아서 PyQt에서 임포트 해와서 사용하게 되었습니다.

 

사용방법

  1. 여기에서 압축파일을 다운로드 받습니다.
  2. 압축을 풀면, Riberty 앱이 나옵니다.
  3. 최초 실행 시, “확인되지 않은 개발자의 앱”이라며 경고가 뜰 수 있습니다. 이 경우, 보안 설정에 가서 예외처리 해주면 됩니다.
  4. 실행 후, 다음 화면에서 DRM이 해제된 파일들이 저장될 폴더 경로를 지정해주고 해제 버튼을 눌러주면 해제 작업이 시작됩니다.
  5. 해제 작업 진행중 모습입니다.
  6. 모든 파일에 대한 처리가 끝나면 다음과 같은 결과 화면이 나옵니다. 완료 메세지 클릭 시, 상세 내용이 나옵니다.

  7. 앞서 지정해준 폴더에 가보면 본인이 소유한 책들의 DRM-free 버전이 저장되어있는 것을 확인할 수 있습니다.

 

경고

위 프로그램은 어떠한 지원도 계획되어 있지 않으며, 해당 프로그램을 악용하여 받을 수 있는 법적 제재 또는 컴퓨터의 오류 등의 일체 문제는 사용자 본인의 몫이며 책임임을 밝힙니다.

위 프로그램은 리디북스 측의 알고리즘 변경으로 어느 시점에든 더이상 작동하지 않게 될 수 있음을 유의하시기 바랍니다.

 

You may also like...

14 Responses

  1. ㅅㄲㅁㅇ says:

    감사합니다! 딱 한장면 캡쳐해서 쓰는것도 막아놓으니 답답했는데 덕분에 쓸 수 있겠네요!

  2. 간절히 says:

    으아아아아아아 ㅠㅠ
    윈도우버전은 어떻게 안 될까요?? ㅠㅠㅠㅠ

    • Cai says:

      흑 ㅠㅠ.. 제가 윈도우를 사용 안해서.. 기회가 되면 윈도우로 포팅해보도록 하겠습니다.. (그리고 윈도우에서는 다른 알고리즘을 사용할 가능성도 있어서 장담드리진 못하겠네요)

  3. says:

    앱으로 포팅한거라서 다른 운영체제에서는 전혀 안되는가봐요…?

  4. 감사 says:

    이걸 윈도우버전으로 푸는순간 모든 방법이 차단될것 같은데요.. 리디가 또 찾아올테구요.. 포스팅 감사합니다.

  5. Nalgo says:

    윈도에서 필요하기도 하고 파이썬 공부 삼아 직접 한번 해보고 싶은데 감도 안오네요 ㄷㄷ

  6. 고마워요 says:

    받아서 실행시키니 다음과 같은 메시지가 뜹니다.

    Input strings must be a multiple of 16 in length.

    그리고 나서 처리 중이라는 메시지만 보일 뿐 진행이 안 되네요.

    뭐가 문제일까요? ㅠ.ㅠ

    • Cai says:

      흠.. AES 복호화가 잘 안되었다는 소리인데요.. 아마 제가 가진 책이 무료책들로 샘플이 적어서 많이 테스트를 못해서 놓친 케이스가 있을지도 모르겠네요 ㅠㅠ 제 페이스북이나 이메일로 따로 연락주시면 디버깅 도와드릴 수 있을것 같습니다.

  7. dwe says:

    윈도우 버전 올리면 다 엎을 가능성도…

    능력 부럽습니다. 배우고 싶네요.

    안그래도 yes24,교보문고,리디에 구입한 책이 많은데 직접 갖고 있는게 편하더군요.

    • Cai says:

      네, 이전 포스팅에도 적었지만 본인이 구매하지 않은 책을 불법복제 용도로 사용하는 사람들은 법적처벌을 받아야 함이 마땅하지만, 본인이 구매한 책은 적어도 본인이 소유할 수 있어야 한다는 것이 제 의견입니다.. 한 기기에 몰아서 볼 수도 있구요.

  8. grayer says:

    맥버전은 모르겠습니다만, 윈도우 버전을 한 번 들여다 본 적이 있는데,
    device_id가 aes -> gzip -> base64 -> 다시 aes 로 처리되어 나왔었습니다.

  9. sunjun says:

    제작 의도와는 다르게 악용될 우려가 있어, 관련 사항을 facebook 메신저로 전달해드렸습니다.

Leave a Reply

Your email address will not be published. Required fields are marked *