기본 콘텐츠로 건너뛰기

오늘의 닭짓일기 - iOS iOS iOS... plugins

자 이제 더러운 짓을 할 때다.
각종 권한들 왕창
플러그인들도 왕창
미리 설치해놓고 잠수함 패치로 앱스토어를 거치지 않고 업데이트할 수 있도록 미리 준비하는 것이다.

TestFlight에 올리록 Archive를 하니
'Cordova/CDVViewController.h' file not found
오류가 계속 나서 stackoverflow를 전전하다 보니
아뿔싸 내 Cordova 버전이 너무 낮다. 3.5로 다시 업글
npm install -g cordova

그리고 iOS 7에선 Status bar가 내용을 가린다.
MainViewController.m을 좀 수정하자.

- (void)viewWillAppear:(BOOL)animated
{
    // View defaults to full size.  If you want to customize the view's size, or its subviews (e.g. webView),
    // you can do so here.
    //Lower screen 20px on ios 7
    if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 7) {
        if(self.webView.frame.origin.y == 0) {
            CGRect viewBounds = [self.webView bounds];
            viewBounds.origin.y = 20;
            viewBounds.size.height = viewBounds.size.height - 20;
            self.webView.frame = viewBounds;
        }
    }

    [super viewWillAppear:animated];
}

icons도 복사하고
Icon.png
Icon@2x.png
Icon-72.png
Icon-72@2x.png
Icon-Small.png
Icon-Small@2x.png
얘는 왜 자동으로 안넣는거야 귀찮게.

splash는 다 시커멓게(혹은 하얗게) 바꾸자

Default@2x~iphone.png
Default-568h@2x~iphone.png
Default-Landscape@2x~ipad.png
Default-Landscape~ipad.png
Default-Portrait@2x~ipad.png
Default-Portrait~ipad.png
Default~iphone.png

그리고 URL Scheme 지원해야하니까

<key>CFBundleURLTypes</key>
<array>
<dict>
<key>CFBundleURLSchemes</key>
<array>
<string>scheme명</string>
</array>
</dict>
</array>
*-info.plist에 추가하자. 

으아 하루종일 삽질했네.
<preference name="webviewbounce" valvue="true"/>
어디서 자꾸 죽나했더니 value에 v 들어가서 죽는거였군;
오타 한번에 하루를 통째로 날렸다. 이러니 아무리 뒤져도 안나오지.
역시 맞춤법 검사기는 소중한거여.

com.urbanairship.phonegap.PushNotification 은 세련되보였지만 서비스 종속이 있어 제거
org.apache.cordova.splashscreen 도 제거. 스플래시 스크린따위는 쓰지 않는다.

adhoc을 위해 사용자를 추가하고 있는데
역시 그냥 사용자한테 UDID를 불러달라고 하면 안되겠다.
먼저 https://developer.apple.com/account/ios/certificate/certificateList.action 에서
Certificates 에서 iOS Development, iOS Distribution 만들고 APNS 도 Dev, Dist 만들자.
Identifiers 에서 App Id도 만들고
Devices 에서 장비추가할 때 먼저 testflight로 초대장을 보내놓고
https://www.testflightapp.com/dashboard/team/all/ 같은 곧에서 추가할 사용자를 선택하여 오른쪽 Actions를 눌러서 Export iOS Devices눌러서 txt파일을 다운받고
다운 받은 파일을 https://developer.apple.com/account/ios/device/deviceCreate.action 에서 Register Multiple Devices 를 통해 일괄 등록하자.

여기서부터 좀 빡치는 점인데 매번 유저 하나 등록할 때마다 "~/Library/MobileDevice/Provisioning Profiles" 경로에서 뒤져서 기존 것을 삭제하고 mobileprovision을 등록해야한다.
그렇지 않으면

이 꼴이 난다.
물론 맨 위엣것이 옛날 것.
미치미치.
파일 이름은 또 어찌나 아름다우신지.
0C44F8C6-65F7-46BD-BEDC-E6FA6CA6577B.mobileprovision
373936C6-AC92-48A9-B73B-418F1E666EF2.mobileprovision
490E1B9A-FCC5-4800-9B5D-3EE811A9E50C.mobileprovision
55D3B3F7-8768-4859-99E4-4C5E5045C253.mobileprovision
5C0B6FAF-A807-4BFD-A5CB-5CE5C4AA3F30.mobileprovision
8EFBC62E-21F0-46A7-B215-105C29475C7E.mobileprovision
984351B5-C42F-496B-9203-CE1FB153C371.mobileprovision
B278CC8C-C2B6-42A9-B0EA-B6D30FFEFD8F.mobileprovision
C7D59812-A742-48EC-855D-BCBDF9F9884C.mobileprovision

이런다.
날짜순으로 보고 지웠는데


안되쟎아! 엉뚱한 게 날아가쟎아!


결국, 눈물 머금고 다시.
잘 보니 XCode 에서 Preference > Accounts > View Details 에서도 볼 수 있단 걸 알았지만 결국 지울 수 없어서 아무 도움 안됨.
http://stackoverflow.com/a/18923552/880991
stackoverflow가 없었으면 영원히 못지웠겠지.

암튼 유저 추가시 시나리오는

  1. testflight로 UDID 수집
  2. testflight에서 export
  3. export한 txt 파일을 https://developer.apple.com/account/ios/device/deviceCreate.action 에서 등록
  4. 기존 mobileprovision을 "~/Library/MobileDevice/Provisioning Profiles"에서 삭제
  5. https://developer.apple.com/account/ios/profile/profileList.action?type=production 에서 adhoc mobileprovision을 생성, 혹은 수정하여 신규 장비 추가(수정시 체크박스 체크)
  6. adhoc mobileprovision 생성 후 다운로드 및 더블 클릭
  7. XCode에서 Preference > Accounts > View Details 에서 리프래쉬하여 확인
  8. 프로젝트 Archieve
  9. 재업로드 및 메일 공지
이정도 되겠다.
이 삽을 뜨다가 정신을 차려보니 iOS계정이 만료되어있군.
천천히 하자.



이 블로그의 인기 게시물

Mac 주의 - 약간 빡치는 git 대소문자 변환 파일명 변환(renaming)하는 법

Mac에서 종종 화나는 일 중 하나가 파일 시스템이 대소문자를 구분하지 않는 점이다.
가령, A.png를 a.png로 바꿔야할 경우 HFS 기준으론 전혀 바뀐 점이 없는 걸로 인식하는데 다소 화가난다.
하지만, 방법이 없는 것은 아닌데

A.png를 임의의 다른 파일로 바꾼다. (ex. A_.png)1에서 바꾼 상태에서 staging 한다. (git add A_.png)1의 파일을 다시 원래 바꾸려고 했던 파일로 바꾼다. (mv A_.png a.png)3을 다시 staging 한다. (git add a.png)commit 한다.https://stackoverflow.com/a/40307511/880991 에서 답변해준 Chris Barr 님에게 감사를.
* 추가

실제로 해보니 git mv --force A.png a.png 가 더 간단하다. 이는 바로 staging 영역에 add까지 해준다.

React-Native App 개발 시 Expo 선택 전에 고려해야할 것.

Expo는 지옥같은 React-Native 개발 환경 아래 섬광처럼 빛나는 훌륭한 도구지만 빛이 있으면 어둠이 있는 법.
https://docs.expo.io/versions/latest/introduction/why-not-expo.html 에선 이런 경우에 Expo를 사용을 고려하라고 전하고 있다.


독립형 앱에 이미지 같은 정적 자원(Assets)들을 함께 묶어 배포할 수 없다.background 혹은 장치가 잠자기 모드일때 코드 실행을 지원하지 않는다.일부 API를 미지원. Bluetooth, WebRTC 같은 건 아직.오버헤드가 꽤 크다. iOS 25MB, Android 20MBPush Notification의 경우 OneSignal 같은 외부서비스를 활용하려면 ExpoKit을 사용하거나 Expo가 아닌 React-Native를 사용해야한다.Staging/Production같은 다양한 디플로이 환경. 하지만 이 경우 https://github.com/oliverbenns/expo-deploy 같은 선택지도 있으니 참조할 것

즐거운 Online Prototyping Tool 들

jsbin, codepen, jsfiddle 이런 것들은 일단 생략. 너무 유명한 것들이라.

https://launchpad.graphql.com - node.js 기반 graphQL 연습장. 이것만으로도 충분히 훌륭한 백엔드
https://codesandbox.io/ npm 사용이 가능한 클라이언트 사이드 연습장. webpackbin이 너무 문제가 많아서 찾아본 것.

https://scrimba.com 이건 codesandbox+ asciinema(https://asciinema.org/) 같은 느낌인데 키 녹화와 음성 녹화 기능이 추가되었다. 다 좋은데 화살표 키로 빨리감기 뒤로감기 기능이 안되고 익스포트(youtube등)으로 지원이 없는게 아쉽다.

이 둘이 만나면? https://codesandbox.io/s/jvlrl98xw3?from-embed
뭐야 이거 무서워 하지마 ㄷㄷ;  graphql+react-native-web(부왘ㅋㅋ)

https://repl.it/languages 전통을 자랑하는 REPL 도구. 지원 언어 종류가 -_-;;;;;

https://tio.run/# repl.it? 장난함? 얘는 지원 언어가 무려 386종류. J랑 아희도 있다.

https://play.golang.org/ 즐거운 go playground. 소스 포멧팅 넘 좋아.

http://decaffeinate-project.org/repl/ 최고의 coffeescript REPL. 원래 용도는 coffee를 ecma6코드로 바꾸는 것이지만...

https://scaphold.io
https://www.graph.cool/ graphql backend service. scaphold.io는 설치도 필요없는 클라우드. graphcool은 호스팅+클라우드 다있음. 둘 다 막상막하. 푸쉬서버도 되고 뭐 미친득.

https://glitch.com/ gomix에서 결국 glitch로 안착.  node.js

https://www.shadertoy.com 잘하고 싶다! 쉐이다! 오디오도 된다!

http:/…